162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * imx-pcm-dma-mx2.c -- ALSA Soc Audio Layer 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright 2009 Sascha Hauer <s.hauer@pengutronix.de> 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * This code is based on code copyrighted by Freescale, 862306a36Sopenharmony_ci * Liam Girdwood, Javier Martin and probably others. 962306a36Sopenharmony_ci */ 1062306a36Sopenharmony_ci#include <linux/platform_device.h> 1162306a36Sopenharmony_ci#include <linux/dmaengine.h> 1262306a36Sopenharmony_ci#include <linux/types.h> 1362306a36Sopenharmony_ci#include <linux/module.h> 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci#include <sound/core.h> 1662306a36Sopenharmony_ci#include <sound/pcm.h> 1762306a36Sopenharmony_ci#include <sound/soc.h> 1862306a36Sopenharmony_ci#include <sound/dmaengine_pcm.h> 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_ci#include "imx-pcm.h" 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_cistatic bool filter(struct dma_chan *chan, void *param) 2362306a36Sopenharmony_ci{ 2462306a36Sopenharmony_ci if (!imx_dma_is_general_purpose(chan)) 2562306a36Sopenharmony_ci return false; 2662306a36Sopenharmony_ci 2762306a36Sopenharmony_ci chan->private = param; 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_ci return true; 3062306a36Sopenharmony_ci} 3162306a36Sopenharmony_ci 3262306a36Sopenharmony_cistatic const struct snd_dmaengine_pcm_config imx_dmaengine_pcm_config = { 3362306a36Sopenharmony_ci .prepare_slave_config = snd_dmaengine_pcm_prepare_slave_config, 3462306a36Sopenharmony_ci .compat_filter_fn = filter, 3562306a36Sopenharmony_ci}; 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ciint imx_pcm_dma_init(struct platform_device *pdev) 3862306a36Sopenharmony_ci{ 3962306a36Sopenharmony_ci struct snd_dmaengine_pcm_config *config; 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_ci config = devm_kzalloc(&pdev->dev, 4262306a36Sopenharmony_ci sizeof(struct snd_dmaengine_pcm_config), GFP_KERNEL); 4362306a36Sopenharmony_ci if (!config) 4462306a36Sopenharmony_ci return -ENOMEM; 4562306a36Sopenharmony_ci *config = imx_dmaengine_pcm_config; 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_ci return devm_snd_dmaengine_pcm_register(&pdev->dev, 4862306a36Sopenharmony_ci config, 4962306a36Sopenharmony_ci SND_DMAENGINE_PCM_FLAG_COMPAT); 5062306a36Sopenharmony_ci} 5162306a36Sopenharmony_ciEXPORT_SYMBOL_GPL(imx_pcm_dma_init); 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_ciMODULE_LICENSE("GPL"); 54