/* * Copyright (C) 2010 Samsung Electronics Co. Ltd. * Jaswinder Singh * * 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. */ #ifndef __DMA_PL330_H_ #define __DMA_PL330_H_ __FILE__ /* * PL330 can assign any channel to communicate with * any of the peripherals attched to the DMAC. * For the sake of consistency across client drivers, * We keep the channel names unchanged and only add * missing peripherals are added. * Order is not important since DMA PL330 API driver * use these just as IDs. */ enum dma_ch { DMACH_UART0_RX = 0, DMACH_UART0_TX, DMACH_UART1_RX, DMACH_UART1_TX, DMACH_UART2_RX, DMACH_UART2_TX, DMACH_UART3_RX, DMACH_UART3_TX, DMACH_UART4_RX, DMACH_UART4_TX, DMACH_UART5_RX, DMACH_UART5_TX, DMACH_USI_RX, DMACH_USI_TX, DMACH_IRDA, DMACH_I2S0_RX, DMACH_I2S0_TX, DMACH_I2S0S_TX, DMACH_I2S1_RX, DMACH_I2S1_TX, DMACH_I2S2_RX, DMACH_I2S2_TX, DMACH_SPI0_RX, DMACH_SPI0_TX, DMACH_SPI1_RX, DMACH_SPI1_TX, DMACH_SPI2_RX, DMACH_SPI2_TX, DMACH_AC97_MICIN, DMACH_AC97_PCMIN, DMACH_AC97_PCMOUT, DMACH_EXTERNAL, DMACH_PWM, DMACH_SPDIF, DMACH_HSI_RX, DMACH_HSI_TX, DMACH_PCM0_TX, DMACH_PCM0_RX, DMACH_PCM1_TX, DMACH_PCM1_RX, DMACH_PCM2_TX, DMACH_PCM2_RX, DMACH_MSM_REQ3, DMACH_MSM_REQ2, DMACH_MSM_REQ1, DMACH_MSM_REQ0, DMACH_SLIMBUS0_RX, DMACH_SLIMBUS0_TX, DMACH_SLIMBUS0AUX_RX, DMACH_SLIMBUS0AUX_TX, DMACH_SLIMBUS1_RX, DMACH_SLIMBUS1_TX, DMACH_SLIMBUS2_RX, DMACH_SLIMBUS2_TX, DMACH_SLIMBUS3_RX, DMACH_SLIMBUS3_TX, DMACH_SLIMBUS4_RX, DMACH_SLIMBUS4_TX, DMACH_SLIMBUS5_RX, DMACH_SLIMBUS5_TX, DMACH_MIPI_HSI0, DMACH_MIPI_HSI1, DMACH_MIPI_HSI2, DMACH_MIPI_HSI3, DMACH_MIPI_HSI4, DMACH_MIPI_HSI5, DMACH_MIPI_HSI6, DMACH_MIPI_HSI7, DMACH_DISP1, DMACH_MTOM_0, DMACH_MTOM_1, DMACH_MTOM_2, DMACH_MTOM_3, DMACH_MTOM_4, DMACH_MTOM_5, DMACH_MTOM_6, DMACH_MTOM_7, /* END Marker, also used to denote a reserved channel */ DMACH_MAX, }; struct s3c2410_dma_client { char *name; }; static inline bool samsung_dma_has_circular(void) { return true; } static inline bool samsung_dma_is_dmadev(void) { return true; } static inline bool samsung_dma_has_infiniteloop(void) { return true; } #include struct samsung_dma_req { enum dma_transaction_type cap; struct s3c2410_dma_client *client; }; struct samsung_dma_prep { enum dma_transaction_type cap; enum dma_transfer_direction direction; dma_addr_t buf; unsigned long period; unsigned long len; void (*fp)(void *data); void *fp_param; unsigned int infiniteloop; }; struct samsung_dma_config { enum dma_transfer_direction direction; enum dma_slave_buswidth width; u32 maxburst; dma_addr_t fifo; }; struct samsung_dma_ops { unsigned long(*request)(enum dma_ch ch, struct samsung_dma_req *param, struct device *dev, char *ch_name); int (*release)(unsigned long ch, void *param); int (*config)(unsigned long ch, struct samsung_dma_config *param); int (*prepare)(unsigned long ch, struct samsung_dma_prep *param); int (*trigger)(unsigned long ch); int (*started)(unsigned long ch); int (*getposition)(unsigned long ch, dma_addr_t *src, dma_addr_t *dst); int (*flush)(unsigned long ch); int (*stop)(unsigned long ch); int (*debug)(unsigned long ch); }; extern void *samsung_dmadev_get_ops(void); extern void *s3c_dma_get_ops(void); static inline void *__samsung_dma_get_ops(void) { if (samsung_dma_is_dmadev()) return samsung_dmadev_get_ops(); else return s3c_dma_get_ops(); } /* * samsung_dma_get_ops * get the set of samsung dma operations */ #ifdef CONFIG_SAMSUNG_DMADEV #define samsung_dma_get_ops() __samsung_dma_get_ops() #else #define samsung_dma_get_ops() NULL #endif #endif /* __DMA_PL330_H_ */