2010-03-30 17:33:42 +04:00
/*
2010-08-09 16:08:34 +04:00
* Copyright ( C ) ST - Ericsson SA 2007 - 2010
2010-10-06 13:05:28 +04:00
* Author : Per Forlin < per . forlin @ stericsson . com > for ST - Ericsson
2010-08-09 16:08:34 +04:00
* Author : Jonas Aaberg < jonas . aberg @ stericsson . com > for ST - Ericsson
2010-03-30 17:33:42 +04:00
* License terms : GNU General Public License ( GPL ) version 2
*/
# ifndef STE_DMA40_H
# define STE_DMA40_H
# include <linux/dmaengine.h>
# include <linux/workqueue.h>
# include <linux/interrupt.h>
2010-12-20 20:31:38 +03:00
/*
* Maxium size for a single dma descriptor
* Size is limited to 16 bits .
* Size is in the units of addr - widths ( 1 , 2 , 4 , 8 bytes )
* Larger transfers will be split up to multiple linked desc
*/
# define STEDMA40_MAX_SEG_SIZE 0xFFFF
2010-03-30 17:33:42 +04:00
/* dev types for memcpy */
# define STEDMA40_DEV_DST_MEMORY (-1)
# define STEDMA40_DEV_SRC_MEMORY (-1)
2010-10-12 17:00:51 +04:00
enum stedma40_mode {
STEDMA40_MODE_LOGICAL = 0 ,
STEDMA40_MODE_PHYSICAL ,
STEDMA40_MODE_OPERATION ,
} ;
2010-03-30 17:33:42 +04:00
2010-10-12 17:00:52 +04:00
enum stedma40_mode_opt {
STEDMA40_PCHAN_BASIC_MODE = 0 ,
STEDMA40_LCHAN_SRC_LOG_DST_LOG = 0 ,
STEDMA40_PCHAN_MODULO_MODE ,
STEDMA40_PCHAN_DOUBLE_DST_MODE ,
STEDMA40_LCHAN_SRC_PHY_DST_LOG ,
STEDMA40_LCHAN_SRC_LOG_DST_PHY ,
} ;
2010-03-30 17:33:42 +04:00
# define STEDMA40_ESIZE_8_BIT 0x0
# define STEDMA40_ESIZE_16_BIT 0x1
# define STEDMA40_ESIZE_32_BIT 0x2
# define STEDMA40_ESIZE_64_BIT 0x3
/* The value 4 indicates that PEN-reg shall be set to 0 */
# define STEDMA40_PSIZE_PHY_1 0x4
# define STEDMA40_PSIZE_PHY_2 0x0
# define STEDMA40_PSIZE_PHY_4 0x1
# define STEDMA40_PSIZE_PHY_8 0x2
# define STEDMA40_PSIZE_PHY_16 0x3
/*
* The number of elements differ in logical and
* physical mode
*/
# define STEDMA40_PSIZE_LOG_1 STEDMA40_PSIZE_PHY_2
# define STEDMA40_PSIZE_LOG_4 STEDMA40_PSIZE_PHY_4
# define STEDMA40_PSIZE_LOG_8 STEDMA40_PSIZE_PHY_8
# define STEDMA40_PSIZE_LOG_16 STEDMA40_PSIZE_PHY_16
2010-08-09 16:08:34 +04:00
/* Maximum number of possible physical channels */
# define STEDMA40_MAX_PHYS 32
2010-03-30 17:33:42 +04:00
enum stedma40_flow_ctrl {
STEDMA40_NO_FLOW_CTRL ,
STEDMA40_FLOW_CTRL ,
} ;
enum stedma40_periph_data_width {
STEDMA40_BYTE_WIDTH = STEDMA40_ESIZE_8_BIT ,
STEDMA40_HALFWORD_WIDTH = STEDMA40_ESIZE_16_BIT ,
STEDMA40_WORD_WIDTH = STEDMA40_ESIZE_32_BIT ,
STEDMA40_DOUBLEWORD_WIDTH = STEDMA40_ESIZE_64_BIT
} ;
enum stedma40_xfer_dir {
2010-08-09 16:07:36 +04:00
STEDMA40_MEM_TO_MEM = 1 ,
2010-03-30 17:33:42 +04:00
STEDMA40_MEM_TO_PERIPH ,
STEDMA40_PERIPH_TO_MEM ,
STEDMA40_PERIPH_TO_PERIPH
} ;
2010-08-09 16:09:21 +04:00
/**
* struct stedma40_chan_cfg - dst / src channel configuration
*
2010-10-12 17:00:54 +04:00
* @ big_endian : true if the src / dst should be read as big endian
2010-08-09 16:09:21 +04:00
* @ data_width : Data width of the src / dst hardware
* @ p_size : Burst size
* @ flow_ctrl : Flow control on / off .
*/
struct stedma40_half_channel_info {
2010-10-12 17:00:54 +04:00
bool big_endian ;
2010-08-09 16:09:21 +04:00
enum stedma40_periph_data_width data_width ;
int psize ;
enum stedma40_flow_ctrl flow_ctrl ;
} ;
2010-03-30 17:33:42 +04:00
/**
* struct stedma40_chan_cfg - Structure to be filled by client drivers .
*
* @ dir : MEM 2 MEM , PERIPH 2 MEM , MEM 2 PERIPH , PERIPH 2 PERIPH
2010-10-12 17:00:50 +04:00
* @ high_priority : true if high - priority
2010-10-12 17:00:51 +04:00
* @ mode : channel mode : physical , logical , or operation
2010-10-12 17:00:52 +04:00
* @ mode_opt : options for the chosen channel mode
2010-03-30 17:33:42 +04:00
* @ src_dev_type : Src device type
* @ dst_dev_type : Dst device type
* @ src_info : Parameters for dst half channel
* @ dst_info : Parameters for dst half channel
*
*
* This structure has to be filled by the client drivers .
* It is recommended to do all dma configurations for clients in the machine .
*
*/
struct stedma40_chan_cfg {
enum stedma40_xfer_dir dir ;
2010-10-12 17:00:50 +04:00
bool high_priority ;
2010-10-12 17:00:51 +04:00
enum stedma40_mode mode ;
2010-10-12 17:00:52 +04:00
enum stedma40_mode_opt mode_opt ;
2010-03-30 17:33:42 +04:00
int src_dev_type ;
int dst_dev_type ;
struct stedma40_half_channel_info src_info ;
struct stedma40_half_channel_info dst_info ;
} ;
/**
* struct stedma40_platform_data - Configuration struct for the dma device .
*
* @ dev_len : length of dev_tx and dev_rx
* @ dev_tx : mapping between destination event line and io address
* @ dev_rx : mapping between source event line and io address
* @ memcpy : list of memcpy event lines
* @ memcpy_len : length of memcpy
* @ memcpy_conf_phy : default configuration of physical channel memcpy
* @ memcpy_conf_log : default configuration of logical channel memcpy
2010-06-21 01:26:45 +04:00
* @ disabled_channels : A vector , ending with - 1 , that marks physical channels
* that are for different reasons not available for the driver .
2010-03-30 17:33:42 +04:00
*/
struct stedma40_platform_data {
u32 dev_len ;
const dma_addr_t * dev_tx ;
const dma_addr_t * dev_rx ;
int * memcpy ;
u32 memcpy_len ;
struct stedma40_chan_cfg * memcpy_conf_phy ;
struct stedma40_chan_cfg * memcpy_conf_log ;
2010-08-09 16:08:34 +04:00
int disabled_channels [ STEDMA40_MAX_PHYS ] ;
2010-03-30 17:33:42 +04:00
} ;
2010-10-06 13:05:29 +04:00
# ifdef CONFIG_STE_DMA40
2010-03-30 17:33:42 +04:00
/**
* stedma40_filter ( ) - Provides stedma40_chan_cfg to the
* ste_dma40 dma driver via the dmaengine framework .
* does some checking of what ' s provided .
*
* Never directly called by client . It used by dmaengine .
* @ chan : dmaengine handle .
* @ data : Must be of type : struct stedma40_chan_cfg and is
* the configuration of the framework .
*
*
*/
bool stedma40_filter ( struct dma_chan * chan , void * data ) ;
/**
* stedma40_memcpy_sg ( ) - extension of the dma framework , memcpy to / from
* scattergatter lists .
*
* @ chan : dmaengine handle
* @ sgl_dst : Destination scatter list
* @ sgl_src : Source scatter list
* @ sgl_len : The length of each scatterlist . Both lists must be of equal length
* and each element must match the corresponding element in the other scatter
* list .
* @ flags : is actually enum dma_ctrl_flags . See dmaengine . h
*/
struct dma_async_tx_descriptor * stedma40_memcpy_sg ( struct dma_chan * chan ,
struct scatterlist * sgl_dst ,
struct scatterlist * sgl_src ,
unsigned int sgl_len ,
unsigned long flags ) ;
/**
* stedma40_slave_mem ( ) - Transfers a raw data buffer to or from a slave
* ( = device )
*
* @ chan : dmaengine handle
* @ addr : source or destination physicall address .
* @ size : bytes to transfer
* @ direction : direction of transfer
* @ flags : is actually enum dma_ctrl_flags . See dmaengine . h
*/
static inline struct
dma_async_tx_descriptor * stedma40_slave_mem ( struct dma_chan * chan ,
dma_addr_t addr ,
unsigned int size ,
enum dma_data_direction direction ,
unsigned long flags )
{
struct scatterlist sg ;
sg_init_table ( & sg , 1 ) ;
sg . dma_address = addr ;
sg . length = size ;
return chan - > device - > device_prep_slave_sg ( chan , & sg , 1 ,
direction , flags ) ;
}
2010-10-06 13:05:29 +04:00
# else
static inline bool stedma40_filter ( struct dma_chan * chan , void * data )
{
return false ;
}
static inline struct
dma_async_tx_descriptor * stedma40_slave_mem ( struct dma_chan * chan ,
dma_addr_t addr ,
unsigned int size ,
enum dma_data_direction direction ,
unsigned long flags )
{
return NULL ;
}
# endif
2010-03-30 17:33:42 +04:00
# endif