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