From 65d7ce607bd4a831c3da00884d7bf00fc412928f Mon Sep 17 00:00:00 2001 From: Jason Liu Date: Wed, 7 Jul 2010 05:34:55 +0800 Subject: ENGR00124908 CSPI: make spi_get_cfg platform specific CSPI: make spi_get_cfg platform specific move the spi_get_cfg out of the cspi/ecspi driver Signed-off-by:Jason Liu --- board/freescale/mx25_3stack/mx25_3stack.c | 20 ++++++++++++++++++++ board/freescale/mx51_bbg/config.mk | 6 +++++- board/freescale/mx51_bbg/mx51_bbg.c | 31 +++++++++++++++++++++++++++++++ 3 files changed, 56 insertions(+), 1 deletion(-) (limited to 'board') diff --git a/board/freescale/mx25_3stack/mx25_3stack.c b/board/freescale/mx25_3stack/mx25_3stack.c index db16c32..b8bb256 100644 --- a/board/freescale/mx25_3stack/mx25_3stack.c +++ b/board/freescale/mx25_3stack/mx25_3stack.c @@ -186,6 +186,26 @@ int board_mmc_init(bd_t *bis) } #endif +s32 spi_get_cfg(struct imx_spi_dev_t *dev) +{ + switch (dev->slave.cs) { + case 0: + /* cpld */ + dev->base = CSPI1_BASE; + dev->freq = 25000000; + dev->ss_pol = IMX_SPI_ACTIVE_LOW; + dev->ss = 0; + dev->fifo_sz = 32; + dev->us_delay = 0; + break; + default: + printf("Invalid Bus ID! \n"); + break; + } + + return 0; +} + void spi_io_init(struct imx_spi_dev_t *dev) { switch (dev->base) { diff --git a/board/freescale/mx51_bbg/config.mk b/board/freescale/mx51_bbg/config.mk index 705aa34..97e8856 100644 --- a/board/freescale/mx51_bbg/config.mk +++ b/board/freescale/mx51_bbg/config.mk @@ -1,3 +1,7 @@ LDSCRIPT := $(SRCTREE)/board/$(VENDOR)/$(BOARD)/u-boot.lds -TEXT_BASE = 0x97800000 +sinclude $(OBJTREE)/board/$(VENDOR)/$(BOARD)/config.tmp + +ifndef TEXT_BASE + TEXT_BASE = 0x97800000 +endif diff --git a/board/freescale/mx51_bbg/mx51_bbg.c b/board/freescale/mx51_bbg/mx51_bbg.c index 43fe121..dadc4e9 100644 --- a/board/freescale/mx51_bbg/mx51_bbg.c +++ b/board/freescale/mx51_bbg/mx51_bbg.c @@ -31,8 +31,10 @@ #include #include #include "board-imx51.h" +#ifdef #ifdef CONFIG_IMX_ECSPI #include #include +#endif #include @@ -307,6 +309,35 @@ static void setup_expio(void) } #ifdef CONFIG_IMX_ECSPI +s32 spi_get_cfg(struct imx_spi_dev_t *dev) +{ + switch (dev->slave.cs) { + case 0: + /* pmic */ + dev->base = CSPI1_BASE_ADDR; + dev->freq = 2500000; + dev->ss_pol = IMX_SPI_ACTIVE_HIGH; + dev->ss = 0; + dev->fifo_sz = 64 * 4; + dev->us_delay = 0; + break; + case 1: + /* spi_nor */ + dev->base = CSPI1_BASE_ADDR; + dev->freq = 2500000; + dev->ss_pol = IMX_SPI_ACTIVE_LOW; + dev->ss = 1; + dev->fifo_sz = 64 * 4; + dev->us_delay = 0; + break; + default: + printf("Invalid Bus ID! \n"); + break; + } + + return 0; +} + void spi_io_init(struct imx_spi_dev_t *dev) { switch (dev->base) { -- cgit v1.1