186 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			186 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/****************************************************************************
 | 
						|
 ****************************************************************************
 | 
						|
 ***
 | 
						|
 ***   This header was automatically generated from a Linux kernel header
 | 
						|
 ***   of the same name, to make information necessary for userspace to
 | 
						|
 ***   call into the kernel available to libc.  It contains only constants,
 | 
						|
 ***   structures, and macros generated from the original header, and thus,
 | 
						|
 ***   contains no copyrightable information.
 | 
						|
 ***
 | 
						|
 ****************************************************************************
 | 
						|
 ****************************************************************************/
 | 
						|
#ifndef __ASM_ARCH_OMAP_MCBSP_H
 | 
						|
#define __ASM_ARCH_OMAP_MCBSP_H
 | 
						|
 | 
						|
#include <asm/hardware.h>
 | 
						|
 | 
						|
#define OMAP730_MCBSP1_BASE 0xfffb1000
 | 
						|
#define OMAP730_MCBSP2_BASE 0xfffb1800
 | 
						|
 | 
						|
#define OMAP1510_MCBSP1_BASE 0xe1011800
 | 
						|
#define OMAP1510_MCBSP2_BASE 0xfffb1000
 | 
						|
#define OMAP1510_MCBSP3_BASE 0xe1017000
 | 
						|
 | 
						|
#define OMAP1610_MCBSP1_BASE 0xe1011800
 | 
						|
#define OMAP1610_MCBSP2_BASE 0xfffb1000
 | 
						|
#define OMAP1610_MCBSP3_BASE 0xe1017000
 | 
						|
 | 
						|
#define OMAP24XX_MCBSP1_BASE 0x48074000
 | 
						|
#define OMAP24XX_MCBSP2_BASE 0x48076000
 | 
						|
 | 
						|
#define OMAP_MCBSP_READ(base, reg) __raw_readw((base) + OMAP_MCBSP_REG_##reg)
 | 
						|
#define OMAP_MCBSP_WRITE(base, reg, val) __raw_writew((val), (base) + OMAP_MCBSP_REG_##reg)
 | 
						|
 | 
						|
#define RRST 0x0001
 | 
						|
#define RRDY 0x0002
 | 
						|
#define RFULL 0x0004
 | 
						|
#define RSYNC_ERR 0x0008
 | 
						|
#define RINTM(value) ((value)<<4)  
 | 
						|
#define ABIS 0x0040
 | 
						|
#define DXENA 0x0080
 | 
						|
#define CLKSTP(value) ((value)<<11)  
 | 
						|
#define RJUST(value) ((value)<<13)  
 | 
						|
#define DLB 0x8000
 | 
						|
 | 
						|
#define XRST 0x0001
 | 
						|
#define XRDY 0x0002
 | 
						|
#define XEMPTY 0x0004
 | 
						|
#define XSYNC_ERR 0x0008
 | 
						|
#define XINTM(value) ((value)<<4)  
 | 
						|
#define GRST 0x0040
 | 
						|
#define FRST 0x0080
 | 
						|
#define SOFT 0x0100
 | 
						|
#define FREE 0x0200
 | 
						|
 | 
						|
#define CLKRP 0x0001
 | 
						|
#define CLKXP 0x0002
 | 
						|
#define FSRP 0x0004
 | 
						|
#define FSXP 0x0008
 | 
						|
#define DR_STAT 0x0010
 | 
						|
#define DX_STAT 0x0020
 | 
						|
#define CLKS_STAT 0x0040
 | 
						|
#define SCLKME 0x0080
 | 
						|
#define CLKRM 0x0100
 | 
						|
#define CLKXM 0x0200
 | 
						|
#define FSRM 0x0400
 | 
						|
#define FSXM 0x0800
 | 
						|
#define RIOEN 0x1000
 | 
						|
#define XIOEN 0x2000
 | 
						|
#define IDLE_EN 0x4000
 | 
						|
 | 
						|
#define RWDLEN1(value) ((value)<<5)  
 | 
						|
#define RFRLEN1(value) ((value)<<8)  
 | 
						|
 | 
						|
#define XWDLEN1(value) ((value)<<5)  
 | 
						|
#define XFRLEN1(value) ((value)<<8)  
 | 
						|
 | 
						|
#define RDATDLY(value) (value)  
 | 
						|
#define RFIG 0x0004
 | 
						|
#define RCOMPAND(value) ((value)<<3)  
 | 
						|
#define RWDLEN2(value) ((value)<<5)  
 | 
						|
#define RFRLEN2(value) ((value)<<8)  
 | 
						|
#define RPHASE 0x8000
 | 
						|
 | 
						|
#define XDATDLY(value) (value)  
 | 
						|
#define XFIG 0x0004
 | 
						|
#define XCOMPAND(value) ((value)<<3)  
 | 
						|
#define XWDLEN2(value) ((value)<<5)  
 | 
						|
#define XFRLEN2(value) ((value)<<8)  
 | 
						|
#define XPHASE 0x8000
 | 
						|
 | 
						|
#define CLKGDV(value) (value)  
 | 
						|
#define FWID(value) ((value)<<8)  
 | 
						|
 | 
						|
#define FPER(value) (value)  
 | 
						|
#define FSGM 0x1000
 | 
						|
#define CLKSM 0x2000
 | 
						|
#define CLKSP 0x4000
 | 
						|
#define GSYNC 0x8000
 | 
						|
 | 
						|
#define RMCM 0x0001
 | 
						|
#define RCBLK(value) ((value)<<2)  
 | 
						|
#define RPABLK(value) ((value)<<5)  
 | 
						|
#define RPBBLK(value) ((value)<<7)  
 | 
						|
 | 
						|
#define XMCM(value) (value)  
 | 
						|
#define XCBLK(value) ((value)<<2)  
 | 
						|
#define XPABLK(value) ((value)<<5)  
 | 
						|
#define XPBBLK(value) ((value)<<7)  
 | 
						|
 | 
						|
struct omap_mcbsp_reg_cfg {
 | 
						|
 u16 spcr2;
 | 
						|
 u16 spcr1;
 | 
						|
 u16 rcr2;
 | 
						|
 u16 rcr1;
 | 
						|
 u16 xcr2;
 | 
						|
 u16 xcr1;
 | 
						|
 u16 srgr2;
 | 
						|
 u16 srgr1;
 | 
						|
 u16 mcr2;
 | 
						|
 u16 mcr1;
 | 
						|
 u16 pcr0;
 | 
						|
 u16 rcerc;
 | 
						|
 u16 rcerd;
 | 
						|
 u16 xcerc;
 | 
						|
 u16 xcerd;
 | 
						|
 u16 rcere;
 | 
						|
 u16 rcerf;
 | 
						|
 u16 xcere;
 | 
						|
 u16 xcerf;
 | 
						|
 u16 rcerg;
 | 
						|
 u16 rcerh;
 | 
						|
 u16 xcerg;
 | 
						|
 u16 xcerh;
 | 
						|
};
 | 
						|
 | 
						|
typedef enum {
 | 
						|
 OMAP_MCBSP1 = 0,
 | 
						|
 OMAP_MCBSP2,
 | 
						|
 OMAP_MCBSP3,
 | 
						|
} omap_mcbsp_id;
 | 
						|
 | 
						|
typedef int __bitwise omap_mcbsp_io_type_t;
 | 
						|
#define OMAP_MCBSP_IRQ_IO ((__force omap_mcbsp_io_type_t) 1)
 | 
						|
#define OMAP_MCBSP_POLL_IO ((__force omap_mcbsp_io_type_t) 2)
 | 
						|
 | 
						|
typedef enum {
 | 
						|
 OMAP_MCBSP_WORD_8 = 0,
 | 
						|
 OMAP_MCBSP_WORD_12,
 | 
						|
 OMAP_MCBSP_WORD_16,
 | 
						|
 OMAP_MCBSP_WORD_20,
 | 
						|
 OMAP_MCBSP_WORD_24,
 | 
						|
 OMAP_MCBSP_WORD_32,
 | 
						|
} omap_mcbsp_word_length;
 | 
						|
 | 
						|
typedef enum {
 | 
						|
 OMAP_MCBSP_CLK_RISING = 0,
 | 
						|
 OMAP_MCBSP_CLK_FALLING,
 | 
						|
} omap_mcbsp_clk_polarity;
 | 
						|
 | 
						|
typedef enum {
 | 
						|
 OMAP_MCBSP_FS_ACTIVE_HIGH = 0,
 | 
						|
 OMAP_MCBSP_FS_ACTIVE_LOW,
 | 
						|
} omap_mcbsp_fs_polarity;
 | 
						|
 | 
						|
typedef enum {
 | 
						|
 OMAP_MCBSP_CLK_STP_MODE_NO_DELAY = 0,
 | 
						|
 OMAP_MCBSP_CLK_STP_MODE_DELAY,
 | 
						|
} omap_mcbsp_clk_stp_mode;
 | 
						|
 | 
						|
typedef enum {
 | 
						|
 OMAP_MCBSP_SPI_MASTER = 0,
 | 
						|
 OMAP_MCBSP_SPI_SLAVE,
 | 
						|
} omap_mcbsp_spi_mode;
 | 
						|
 | 
						|
struct omap_mcbsp_spi_cfg {
 | 
						|
 omap_mcbsp_spi_mode spi_mode;
 | 
						|
 omap_mcbsp_clk_polarity rx_clock_polarity;
 | 
						|
 omap_mcbsp_clk_polarity tx_clock_polarity;
 | 
						|
 omap_mcbsp_fs_polarity fsx_polarity;
 | 
						|
 u8 clk_div;
 | 
						|
 omap_mcbsp_clk_stp_mode clk_stp_mode;
 | 
						|
 omap_mcbsp_word_length word_length;
 | 
						|
};
 | 
						|
 | 
						|
#endif
 |