18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * edma-pcm.c - eDMA PCM driver using dmaengine for AM3xxx, AM4xxx 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * Copyright (C) 2014 Texas Instruments, Inc. 68c2ecf20Sopenharmony_ci * 78c2ecf20Sopenharmony_ci * Author: Peter Ujfalusi <peter.ujfalusi@ti.com> 88c2ecf20Sopenharmony_ci * 98c2ecf20Sopenharmony_ci * Based on: sound/soc/tegra/tegra_pcm.c 108c2ecf20Sopenharmony_ci */ 118c2ecf20Sopenharmony_ci 128c2ecf20Sopenharmony_ci#include <linux/module.h> 138c2ecf20Sopenharmony_ci#include <sound/core.h> 148c2ecf20Sopenharmony_ci#include <sound/pcm.h> 158c2ecf20Sopenharmony_ci#include <sound/pcm_params.h> 168c2ecf20Sopenharmony_ci#include <sound/soc.h> 178c2ecf20Sopenharmony_ci#include <sound/dmaengine_pcm.h> 188c2ecf20Sopenharmony_ci 198c2ecf20Sopenharmony_ci#include "edma-pcm.h" 208c2ecf20Sopenharmony_ci 218c2ecf20Sopenharmony_cistatic const struct snd_pcm_hardware edma_pcm_hardware = { 228c2ecf20Sopenharmony_ci .info = SNDRV_PCM_INFO_MMAP | 238c2ecf20Sopenharmony_ci SNDRV_PCM_INFO_MMAP_VALID | 248c2ecf20Sopenharmony_ci SNDRV_PCM_INFO_PAUSE | SNDRV_PCM_INFO_RESUME | 258c2ecf20Sopenharmony_ci SNDRV_PCM_INFO_NO_PERIOD_WAKEUP | 268c2ecf20Sopenharmony_ci SNDRV_PCM_INFO_INTERLEAVED, 278c2ecf20Sopenharmony_ci .buffer_bytes_max = 128 * 1024, 288c2ecf20Sopenharmony_ci .period_bytes_min = 32, 298c2ecf20Sopenharmony_ci .period_bytes_max = 64 * 1024, 308c2ecf20Sopenharmony_ci .periods_min = 2, 318c2ecf20Sopenharmony_ci .periods_max = 19, /* Limit by edma dmaengine driver */ 328c2ecf20Sopenharmony_ci}; 338c2ecf20Sopenharmony_ci 348c2ecf20Sopenharmony_cistatic const struct snd_dmaengine_pcm_config edma_dmaengine_pcm_config = { 358c2ecf20Sopenharmony_ci .pcm_hardware = &edma_pcm_hardware, 368c2ecf20Sopenharmony_ci .prepare_slave_config = snd_dmaengine_pcm_prepare_slave_config, 378c2ecf20Sopenharmony_ci .prealloc_buffer_size = 128 * 1024, 388c2ecf20Sopenharmony_ci}; 398c2ecf20Sopenharmony_ci 408c2ecf20Sopenharmony_ciint edma_pcm_platform_register(struct device *dev) 418c2ecf20Sopenharmony_ci{ 428c2ecf20Sopenharmony_ci struct snd_dmaengine_pcm_config *config; 438c2ecf20Sopenharmony_ci 448c2ecf20Sopenharmony_ci if (dev->of_node) 458c2ecf20Sopenharmony_ci return devm_snd_dmaengine_pcm_register(dev, 468c2ecf20Sopenharmony_ci &edma_dmaengine_pcm_config, 0); 478c2ecf20Sopenharmony_ci 488c2ecf20Sopenharmony_ci config = devm_kzalloc(dev, sizeof(*config), GFP_KERNEL); 498c2ecf20Sopenharmony_ci if (!config) 508c2ecf20Sopenharmony_ci return -ENOMEM; 518c2ecf20Sopenharmony_ci 528c2ecf20Sopenharmony_ci *config = edma_dmaengine_pcm_config; 538c2ecf20Sopenharmony_ci 548c2ecf20Sopenharmony_ci config->chan_names[0] = "tx"; 558c2ecf20Sopenharmony_ci config->chan_names[1] = "rx"; 568c2ecf20Sopenharmony_ci 578c2ecf20Sopenharmony_ci return devm_snd_dmaengine_pcm_register(dev, config, 0); 588c2ecf20Sopenharmony_ci} 598c2ecf20Sopenharmony_ciEXPORT_SYMBOL_GPL(edma_pcm_platform_register); 608c2ecf20Sopenharmony_ci 618c2ecf20Sopenharmony_ciMODULE_AUTHOR("Peter Ujfalusi <peter.ujfalusi@ti.com>"); 628c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("eDMA PCM ASoC platform driver"); 638c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL"); 64