| 
									
										
										
										
											2009-11-25 16:41:04 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * imx-pcm-dma-mx2.c  --  ALSA Soc Audio Layer | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright 2009 Sascha Hauer <s.hauer@pengutronix.de> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This code is based on code copyrighted by Freescale, | 
					
						
							|  |  |  |  * Liam Girdwood, Javier Martin and probably others. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  This program is free software; you can redistribute  it and/or modify it | 
					
						
							|  |  |  |  *  under  the terms of  the GNU General  Public License as published by the | 
					
						
							|  |  |  |  *  Free Software Foundation;  either version 2 of the  License, or (at your | 
					
						
							|  |  |  |  *  option) any later version. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #include <linux/platform_device.h>
 | 
					
						
							| 
									
										
										
										
											2010-11-04 17:05:43 +01:00
										 |  |  | #include <linux/dmaengine.h>
 | 
					
						
							| 
									
										
										
										
											2012-02-01 16:12:19 +05:30
										 |  |  | #include <linux/types.h>
 | 
					
						
							| 
									
										
										
										
											2013-08-16 12:07:19 +01:00
										 |  |  | #include <linux/module.h>
 | 
					
						
							| 
									
										
										
										
											2009-11-25 16:41:04 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <sound/core.h>
 | 
					
						
							|  |  |  | #include <sound/pcm.h>
 | 
					
						
							|  |  |  | #include <sound/soc.h>
 | 
					
						
							| 
									
										
										
										
											2012-02-22 10:49:09 +01:00
										 |  |  | #include <sound/dmaengine_pcm.h>
 | 
					
						
							| 
									
										
										
										
											2009-11-25 16:41:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-05 22:30:55 +08:00
										 |  |  | #include "imx-pcm.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-25 16:41:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-04 17:05:43 +01:00
										 |  |  | static bool filter(struct dma_chan *chan, void *param) | 
					
						
							| 
									
										
										
										
											2009-11-25 16:41:04 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-11-04 17:05:43 +01:00
										 |  |  | 	if (!imx_dma_is_general_purpose(chan)) | 
					
						
							|  |  |  | 		return false; | 
					
						
							| 
									
										
										
										
											2009-11-25 16:41:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-19 21:38:26 +01:00
										 |  |  | 	chan->private = param; | 
					
						
							| 
									
										
										
										
											2010-04-08 11:31:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-22 10:49:09 +01:00
										 |  |  | 	return true; | 
					
						
							| 
									
										
										
										
											2012-02-22 10:49:06 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-15 19:19:59 +02:00
										 |  |  | static const struct snd_pcm_hardware imx_pcm_hardware = { | 
					
						
							| 
									
										
										
										
											2009-11-25 16:41:04 +01:00
										 |  |  | 	.info = SNDRV_PCM_INFO_INTERLEAVED | | 
					
						
							|  |  |  | 		SNDRV_PCM_INFO_BLOCK_TRANSFER | | 
					
						
							|  |  |  | 		SNDRV_PCM_INFO_MMAP | | 
					
						
							|  |  |  | 		SNDRV_PCM_INFO_MMAP_VALID | | 
					
						
							|  |  |  | 		SNDRV_PCM_INFO_PAUSE | | 
					
						
							|  |  |  | 		SNDRV_PCM_INFO_RESUME, | 
					
						
							|  |  |  | 	.buffer_bytes_max = IMX_SSI_DMABUF_SIZE, | 
					
						
							|  |  |  | 	.period_bytes_min = 128, | 
					
						
							| 
									
										
										
										
											2010-11-04 17:05:43 +01:00
										 |  |  | 	.period_bytes_max = 65535, /* Limited by SDMA engine */ | 
					
						
							| 
									
										
										
										
											2009-11-25 16:41:04 +01:00
										 |  |  | 	.periods_min = 2, | 
					
						
							|  |  |  | 	.periods_max = 255, | 
					
						
							|  |  |  | 	.fifo_size = 0, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-15 19:19:59 +02:00
										 |  |  | static const struct snd_dmaengine_pcm_config imx_dmaengine_pcm_config = { | 
					
						
							|  |  |  | 	.pcm_hardware = &imx_pcm_hardware, | 
					
						
							|  |  |  | 	.prepare_slave_config = snd_dmaengine_pcm_prepare_slave_config, | 
					
						
							|  |  |  | 	.compat_filter_fn = filter, | 
					
						
							|  |  |  | 	.prealloc_buffer_size = IMX_SSI_DMABUF_SIZE, | 
					
						
							| 
									
										
										
										
											2009-11-25 16:41:04 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-28 14:25:43 +08:00
										 |  |  | int imx_pcm_dma_init(struct platform_device *pdev) | 
					
						
							| 
									
										
										
										
											2009-11-25 16:41:04 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-11-28 08:50:35 +01:00
										 |  |  | 	return devm_snd_dmaengine_pcm_register(&pdev->dev, | 
					
						
							|  |  |  | 		&imx_dmaengine_pcm_config, | 
					
						
							| 
									
										
										
										
											2013-04-15 19:19:59 +02:00
										 |  |  | 		SND_DMAENGINE_PCM_FLAG_COMPAT); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2013-04-25 11:18:50 +08:00
										 |  |  | EXPORT_SYMBOL_GPL(imx_pcm_dma_init); | 
					
						
							| 
									
										
										
										
											2013-04-15 19:19:59 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-16 12:07:19 +01:00
										 |  |  | MODULE_LICENSE("GPL"); |