| /* define spi-uart debug constrains */ |
| /* code for MRST early printk */ |
| #ifndef _SPI_UART |
| #define _SPI_UART |
| |
| #include "types.h" |
| |
| #define MRST_REGBASE_SPI0 0xff128000 |
| #define MRST_REGBASE_SPI1 0xff128400 |
| #define MRST_REGBASE_SPI2 0xff128800 |
| |
| #define CTP_REGBASE_SPI0 0xff128000 |
| #define CTP_REGBASE_SPI1 0xff135000 |
| #define CTP_REGBASE_SPI2 0xff136000 |
| |
| /* HW info for MRST CLk Control Unit, one 32b reg */ |
| #define MRST_SPI_CLK_BASE 100000000 /* 100m */ |
| #define MRST_CLK_SPI0_REG 0xff11d86c |
| #define CLK_SPI_BDIV_OFFSET 0 |
| #define CLK_SPI_BDIV_MASK 0x00000007 |
| #define CLK_SPI_CDIV_OFFSET 9 |
| #define CLK_SPI_CDIV_MASK 0x00000e00 |
| #define CLK_SPI_CDIV_100M 0x0 |
| #define CLK_SPI_CDIV_50M 0x1 |
| #define CLK_SPI_CDIV_33M 0x2 |
| #define CLK_SPI_CDIV_25M 0x3 |
| #define CLK_SPI_DISABLE_OFFSET 8 |
| |
| struct mrst_spi_reg { |
| vu32 ctrlr0; /* control reg 0 */ |
| vu32 ctrlr1; /* control reg 1 */ |
| vu32 ssienr; /* SSI enable reg */ |
| vu32 mwcr; /* Microwire control reg */ |
| |
| vu32 ser; /* slave enable reg */ |
| vu32 baudr; |
| vu32 txftlr; |
| vu32 rxftlr; |
| |
| vu32 txflr; |
| vu32 rxflr; |
| vu32 sr; |
| vu32 imr; |
| |
| vu32 isr; |
| vu32 risr; |
| vu32 txoicr; |
| vu32 rxoicr; |
| |
| vu32 rxuicr; |
| vu32 msticr; |
| vu32 icr; |
| vu32 dmacr; |
| |
| vu32 dmatdlr; |
| vu32 dmardlr; |
| vu32 idr; |
| vu32 ssi_comp_version; |
| |
| vu32 dr[16]; /* 16 bits access for each 32bit space */ |
| }; |
| |
| /* bit fields in CTRLR0 */ |
| #define SPI_DFS_OFFSET 0 |
| #define SPI_FRF_OFFSET 4 |
| #define FRF_SPI 0x0 |
| #define FRF_SSP 0x1 |
| #define FRF_MICROWIRE 0x2 |
| #define FRF_RESV 0x3 |
| #define SPI_SCPH_OFFSET 6 |
| #define SPI_SCOL_OFFSET 7 |
| #define SPI_TMOD_OFFSET 8 |
| #define TMOD_TR 0x0 /* xmit & recv */ |
| #define TMOD_TO 0x1 /* xmit only */ |
| #define TMOD_RO 0x2 /* recv only */ |
| #define TMOD_EPROMREAD 0x3 /* eeprom read mode */ |
| |
| #define SPI_SLVOE_OFFSET 10 |
| #define SPI_SRL_OFFSET 11 |
| #define SPI_CFS_OFFSET 12 |
| |
| /* bit fields in SR, 7 bits */ |
| #define SR_MASK 0x7f /* cover 7 bits */ |
| #define SR_BUSY (1 << 0) |
| #define SR_TF_NOT_FULL (1 << 1) |
| #define SR_TF_EMPT (1 << 2) |
| #define SR_RF_NOT_EMPT (1 << 3) |
| #define SR_RF_FULL (1 << 4) |
| #define SR_TX_ERR (1 << 5) |
| #define SR_DCOL (1 << 6) |
| |
| /* bit fields in ISR, IMR, RISR, 7 bits */ |
| #define SPI_INT_TXEI (1 << 0) |
| #define SPI_INT_TXOI (1 << 1) |
| #define SPI_INT_RXUI (1 << 2) |
| #define SPI_INT_RXOI (1 << 3) |
| #define SPI_INT_RXFI (1 << 4) |
| #define SPI_INT_MSTI (1 << 5) |
| |
| extern void bs_spi_printk(const char *str); |
| |
| #endif |