162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * edma-pcm.c - eDMA PCM driver using dmaengine for AM3xxx, AM4xxx 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2014 Texas Instruments, Inc. 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Author: Peter Ujfalusi <peter.ujfalusi@ti.com> 862306a36Sopenharmony_ci * 962306a36Sopenharmony_ci * Based on: sound/soc/tegra/tegra_pcm.c 1062306a36Sopenharmony_ci */ 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#include <linux/module.h> 1362306a36Sopenharmony_ci#include <sound/core.h> 1462306a36Sopenharmony_ci#include <sound/pcm.h> 1562306a36Sopenharmony_ci#include <sound/pcm_params.h> 1662306a36Sopenharmony_ci#include <sound/soc.h> 1762306a36Sopenharmony_ci#include <sound/dmaengine_pcm.h> 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci#include "edma-pcm.h" 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_cistatic const struct snd_pcm_hardware edma_pcm_hardware = { 2262306a36Sopenharmony_ci .info = SNDRV_PCM_INFO_MMAP | 2362306a36Sopenharmony_ci SNDRV_PCM_INFO_MMAP_VALID | 2462306a36Sopenharmony_ci SNDRV_PCM_INFO_PAUSE | SNDRV_PCM_INFO_RESUME | 2562306a36Sopenharmony_ci SNDRV_PCM_INFO_NO_PERIOD_WAKEUP | 2662306a36Sopenharmony_ci SNDRV_PCM_INFO_INTERLEAVED, 2762306a36Sopenharmony_ci .buffer_bytes_max = 128 * 1024, 2862306a36Sopenharmony_ci .period_bytes_min = 32, 2962306a36Sopenharmony_ci .period_bytes_max = 64 * 1024, 3062306a36Sopenharmony_ci .periods_min = 2, 3162306a36Sopenharmony_ci .periods_max = 19, /* Limit by edma dmaengine driver */ 3262306a36Sopenharmony_ci}; 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_cistatic const struct snd_dmaengine_pcm_config edma_dmaengine_pcm_config = { 3562306a36Sopenharmony_ci .pcm_hardware = &edma_pcm_hardware, 3662306a36Sopenharmony_ci .prepare_slave_config = snd_dmaengine_pcm_prepare_slave_config, 3762306a36Sopenharmony_ci .prealloc_buffer_size = 128 * 1024, 3862306a36Sopenharmony_ci}; 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ciint edma_pcm_platform_register(struct device *dev) 4162306a36Sopenharmony_ci{ 4262306a36Sopenharmony_ci struct snd_dmaengine_pcm_config *config; 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ci if (dev->of_node) 4562306a36Sopenharmony_ci return devm_snd_dmaengine_pcm_register(dev, 4662306a36Sopenharmony_ci &edma_dmaengine_pcm_config, 0); 4762306a36Sopenharmony_ci 4862306a36Sopenharmony_ci config = devm_kzalloc(dev, sizeof(*config), GFP_KERNEL); 4962306a36Sopenharmony_ci if (!config) 5062306a36Sopenharmony_ci return -ENOMEM; 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_ci *config = edma_dmaengine_pcm_config; 5362306a36Sopenharmony_ci 5462306a36Sopenharmony_ci config->chan_names[0] = "tx"; 5562306a36Sopenharmony_ci config->chan_names[1] = "rx"; 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ci return devm_snd_dmaengine_pcm_register(dev, config, 0); 5862306a36Sopenharmony_ci} 5962306a36Sopenharmony_ciEXPORT_SYMBOL_GPL(edma_pcm_platform_register); 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_ciMODULE_AUTHOR("Peter Ujfalusi <peter.ujfalusi@ti.com>"); 6262306a36Sopenharmony_ciMODULE_DESCRIPTION("eDMA PCM ASoC platform driver"); 6362306a36Sopenharmony_ciMODULE_LICENSE("GPL"); 64