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