#ifndef BCM63XX_DEV_SPI_H #define BCM63XX_DEV_SPI_H #include <linux/types.h> #include <bcm63xx_io.h> #include <bcm63xx_regs.h> int __init bcm63xx_spi_register(void); struct bcm63xx_spi_pdata { unsigned int fifo_size; unsigned int msg_type_shift; unsigned int msg_ctl_width; int bus_num; int num_chipselect; }; enum bcm63xx_regs_spi { SPI_CMD, SPI_INT_STATUS, SPI_INT_MASK_ST, SPI_INT_MASK, SPI_ST, SPI_CLK_CFG, SPI_FILL_BYTE, SPI_MSG_TAIL, SPI_RX_TAIL, SPI_MSG_CTL, SPI_MSG_DATA, SPI_RX_DATA, }; #define __GEN_SPI_REGS_TABLE(__cpu) \ [SPI_CMD] = SPI_## __cpu ##_CMD, \ [SPI_INT_STATUS] = SPI_## __cpu ##_INT_STATUS, \ [SPI_INT_MASK_ST] = SPI_## __cpu ##_INT_MASK_ST, \ [SPI_INT_MASK] = SPI_## __cpu ##_INT_MASK, \ [SPI_ST] = SPI_## __cpu ##_ST, \ [SPI_CLK_CFG] = SPI_## __cpu ##_CLK_CFG, \ [SPI_FILL_BYTE] = SPI_## __cpu ##_FILL_BYTE, \ [SPI_MSG_TAIL] = SPI_## __cpu ##_MSG_TAIL, \ [SPI_RX_TAIL] = SPI_## __cpu ##_RX_TAIL, \ [SPI_MSG_CTL] = SPI_## __cpu ##_MSG_CTL, \ [SPI_MSG_DATA] = SPI_## __cpu ##_MSG_DATA, \ [SPI_RX_DATA] = SPI_## __cpu ##_RX_DATA, static inline unsigned long bcm63xx_spireg(enum bcm63xx_regs_spi reg) { extern const unsigned long *bcm63xx_regs_spi; return bcm63xx_regs_spi[reg]; } #endif /* BCM63XX_DEV_SPI_H */