From 32e5c59b904d87d7c748c126b3a771a4365a8b23 Mon Sep 17 00:00:00 2001 From: Gabor Juhos Date: Sat, 24 May 2008 06:45:35 +0000 Subject: [PATCH] [ixp4xx] add inital support for the kendin switch on the gtwx5717 board SVN-Revision: 11251 --- .../patches-2.6.25/310-gtwx5717_spi_bus.patch | 55 +++++++++++++++++++ .../311-gtwx5717_mac_plat_info.patch | 42 ++++++++++++++ 2 files changed, 97 insertions(+) create mode 100644 target/linux/ixp4xx/patches-2.6.25/310-gtwx5717_spi_bus.patch create mode 100644 target/linux/ixp4xx/patches-2.6.25/311-gtwx5717_mac_plat_info.patch diff --git a/target/linux/ixp4xx/patches-2.6.25/310-gtwx5717_spi_bus.patch b/target/linux/ixp4xx/patches-2.6.25/310-gtwx5717_spi_bus.patch new file mode 100644 index 0000000000..4d26fa6ce7 --- /dev/null +++ b/target/linux/ixp4xx/patches-2.6.25/310-gtwx5717_spi_bus.patch @@ -0,0 +1,55 @@ +Index: linux-2.6.25.4/arch/arm/mach-ixp4xx/gtwx5715-setup.c +=================================================================== +--- linux-2.6.25.4.orig/arch/arm/mach-ixp4xx/gtwx5715-setup.c ++++ linux-2.6.25.4/arch/arm/mach-ixp4xx/gtwx5715-setup.c +@@ -29,6 +29,8 @@ + #include + #include + ++#include ++ + #include + #include + #include +@@ -121,9 +123,41 @@ static struct platform_device gtwx5715_f + .resource = >wx5715_flash_resource, + }; + ++static int gtwx5715_spi_boardinfo_setup(struct spi_board_info *bi, ++ struct spi_master *master, void *data) ++{ ++ ++ strlcpy(bi->modalias, "spi-ks8995", sizeof(bi->modalias)); ++ ++ bi->max_speed_hz = 5000000 /* Hz */; ++ bi->bus_num = master->bus_num; ++ bi->mode = SPI_MODE_0; ++ ++ return 0; ++} ++ ++static struct spi_gpio_platform_data gtwx5715_spi_bus_data = { ++ .pin_cs = GTWX5715_KSSPI_SELECT, ++ .pin_clk = GTWX5715_KSSPI_CLOCK, ++ .pin_miso = GTWX5715_KSSPI_RXD, ++ .pin_mosi = GTWX5715_KSSPI_TXD, ++ .cs_activelow = 1, ++ .no_spi_delay = 1, ++ .boardinfo_setup = gtwx5715_spi_boardinfo_setup, ++}; ++ ++static struct platform_device gtwx5715_spi_bus = { ++ .name = "spi-gpio", ++ .id = 0, ++ .dev = { ++ .platform_data = >wx5715_spi_bus_data, ++ }, ++}; ++ + static struct platform_device *gtwx5715_devices[] __initdata = { + >wx5715_uart_device, + >wx5715_flash, ++ >wx5715_spi_bus, + }; + + static void __init gtwx5715_init(void) diff --git a/target/linux/ixp4xx/patches-2.6.25/311-gtwx5717_mac_plat_info.patch b/target/linux/ixp4xx/patches-2.6.25/311-gtwx5717_mac_plat_info.patch new file mode 100644 index 0000000000..2ae0f9af4c --- /dev/null +++ b/target/linux/ixp4xx/patches-2.6.25/311-gtwx5717_mac_plat_info.patch @@ -0,0 +1,42 @@ +Index: linux-2.6.25.4/arch/arm/mach-ixp4xx/gtwx5715-setup.c +=================================================================== +--- linux-2.6.25.4.orig/arch/arm/mach-ixp4xx/gtwx5715-setup.c ++++ linux-2.6.25.4/arch/arm/mach-ixp4xx/gtwx5715-setup.c +@@ -154,10 +154,37 @@ static struct platform_device gtwx5715_s + }, + }; + ++static struct eth_plat_info gtwx5715_npeb_data = { ++ .phy = IXP4XX_ETH_PHY_MAX_ADDR, ++ .phy_mask = 0x1e, /* ports 1-4 of the KS8995 switch */ ++ .rxq = 3, ++ .txreadyq = 20, ++}; ++ ++static struct eth_plat_info gtwx5715_npec_data = { ++ .phy = 5, /* port 5 of the KS8995 switch */ ++ .rxq = 4, ++ .txreadyq = 21, ++}; ++ ++static struct platform_device gtwx5715_npeb_device = { ++ .name = "ixp4xx_eth", ++ .id = IXP4XX_ETH_NPEB, ++ .dev.platform_data = >wx5715_npeb_data, ++}; ++ ++static struct platform_device gtwx5715_npec_device = { ++ .name = "ixp4xx_eth", ++ .id = IXP4XX_ETH_NPEC, ++ .dev.platform_data = >wx5715_npec_data, ++}; ++ + static struct platform_device *gtwx5715_devices[] __initdata = { + >wx5715_uart_device, + >wx5715_flash, + >wx5715_spi_bus, ++ >wx5715_npeb_device, ++ >wx5715_npec_device, + }; + + static void __init gtwx5715_init(void) -- 2.30.2