diff options
author | Gabor Juhos <juhosg@openwrt.org> | 2007-07-17 15:43:58 +0000 |
---|---|---|
committer | Gabor Juhos <juhosg@openwrt.org> | 2007-07-17 15:43:58 +0000 |
commit | f192b6afc86c4209fb887ae2e58d52ccbaa1485d (patch) | |
tree | 17cbe59be4f1df516a392ea86f1467cc5e903bee /target/linux/adm5120-2.6/files/arch | |
parent | 42aa5752e245f152ffc44012a6a27d109dd76bda (diff) | |
download | upstream-f192b6afc86c4209fb887ae2e58d52ccbaa1485d.tar.gz upstream-f192b6afc86c4209fb887ae2e58d52ccbaa1485d.tar.bz2 upstream-f192b6afc86c4209fb887ae2e58d52ccbaa1485d.zip |
[adm5120] restore support for Infineon's EASY 5120 boards
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@8021 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/adm5120-2.6/files/arch')
-rw-r--r-- | target/linux/adm5120-2.6/files/arch/mips/adm5120/boards/infineon.c | 83 | ||||
-rw-r--r-- | target/linux/adm5120-2.6/files/arch/mips/adm5120/prom.c | 4 |
2 files changed, 79 insertions, 8 deletions
diff --git a/target/linux/adm5120-2.6/files/arch/mips/adm5120/boards/infineon.c b/target/linux/adm5120-2.6/files/arch/mips/adm5120/boards/infineon.c index ca377d1af4..e1426cca9d 100644 --- a/target/linux/adm5120-2.6/files/arch/mips/adm5120/boards/infineon.c +++ b/target/linux/adm5120-2.6/files/arch/mips/adm5120/boards/infineon.c @@ -44,7 +44,19 @@ static void switch_bank_gpio3(unsigned bank) } } -static struct mtd_partition easy83000_partitions[] = { +static void switch_bank_gpio5(unsigned bank) +{ + switch (bank) { + case 0: + gpio_set_value(ADM5120_GPIO_PIN5, 0); + break; + case 1: + gpio_set_value(ADM5120_GPIO_PIN5, 1); + break; + } +} + +static struct mtd_partition easy_partitions[] = { { .name = "admboot", .offset = 0, @@ -61,27 +73,83 @@ static struct mtd_partition easy83000_partitions[] = { } }; +static struct platform_device *easy5120pata_devices[] __initdata = { + &adm5120_flash0_device, + /* TODO: add VINETIC2 device? */ +}; + +static struct platform_device *easy5120rt_devices[] __initdata = { + &adm5120_flash0_device, + &adm5120_usbc_device +}; + +static struct platform_device *easy5120wvoip_devices[] __initdata = { + &adm5120_flash0_device, + /* TODO: add VINETIC2 device? */ +}; + static struct platform_device *easy83000_devices[] __initdata = { &adm5120_flash0_device, + /* TODO: add VINAX device? */ }; -static void __init easy83000_setup(void) +static void __init easy_setup_pqfp(void) { gpio_request(ADM5120_GPIO_PIN3, NULL); /* for flash A20 line */ gpio_direction_output(ADM5120_GPIO_PIN3, 0); /* setup data for flash0 device */ adm5120_flash0_data.switch_bank = switch_bank_gpio3; - adm5120_flash0_data.nr_parts = ARRAY_SIZE(easy83000_partitions); - adm5120_flash0_data.parts = easy83000_partitions; + adm5120_flash0_data.nr_parts = ARRAY_SIZE(easy_partitions); + adm5120_flash0_data.parts = easy_partitions; + + /* TODO: setup mac addresses */ +} + +static void __init easy_setup_bga(void) +{ + gpio_request(ADM5120_GPIO_PIN5, NULL); /* for flash A20 line */ + gpio_direction_output(ADM5120_GPIO_PIN5, 0); + + /* setup data for flash0 device */ + adm5120_flash0_data.switch_bank = switch_bank_gpio5; + adm5120_flash0_data.nr_parts = ARRAY_SIZE(easy_partitions); + adm5120_flash0_data.parts = easy_partitions; /* TODO: setup mac addresses */ } +static struct adm5120_board easy5120pata_board __initdata = { + .mach_type = MACH_ADM5120_EASY5120PATA, + .name = "Infineon EASY 5120P-ATA Reference Board", + .board_setup = easy_setup_pqfp, + .num_eth_ports = 6, + .num_devices = ARRAY_SIZE(easy5120pata_devices), + .devices = easy5120pata_devices, +}; + +static struct adm5120_board easy5120rt_board __initdata = { + .mach_type = MACH_ADM5120_EASY5120RT, + .name = "Infineon EASY 5120-RT Reference Board", + .board_setup = easy_setup_bga, + .num_eth_ports = 5, + .num_devices = ARRAY_SIZE(easy5120rt_devices), + .devices = easy5120rt_devices, +}; + +static struct adm5120_board easy5120wvoip_board __initdata = { + .mach_type = MACH_ADM5120_EASY5120WVOIP, + .name = "Infineon EASY 5120-WVoIP Reference Board", + .board_setup = easy_setup_bga, + .num_eth_ports = 6, + .num_devices = ARRAY_SIZE(easy5120wvoip_devices), + .devices = easy5120wvoip_devices, +}; + static struct adm5120_board easy83000_board __initdata = { .mach_type = MACH_ADM5120_EASY83000, - .name = "Infineon EASY-83000", - .board_setup = easy83000_setup, + .name = "Infineon EASY 83000 Reference Board", + .board_setup = easy_setup_pqfp, .num_eth_ports = 6, .num_devices = ARRAY_SIZE(easy83000_devices), .devices = easy83000_devices, @@ -89,6 +157,9 @@ static struct adm5120_board easy83000_board __initdata = { static int __init register_boards(void) { + adm5120_board_register(&easy5120pata_board); + adm5120_board_register(&easy5120rt_board); + adm5120_board_register(&easy5120wvoip_board); adm5120_board_register(&easy83000_board); return 0; } diff --git a/target/linux/adm5120-2.6/files/arch/mips/adm5120/prom.c b/target/linux/adm5120-2.6/files/arch/mips/adm5120/prom.c index db8037f3be..c14c172299 100644 --- a/target/linux/adm5120-2.6/files/arch/mips/adm5120/prom.c +++ b/target/linux/adm5120-2.6/files/arch/mips/adm5120/prom.c @@ -62,9 +62,9 @@ static struct board_desc common_boards[] __initdata = { DEFBOARD("BR-6104K", MACH_ADM5120_BR6104K), DEFBOARD("BR-6104KP", MACH_ADM5120_BR6104K), /* Infineon boards */ - DEFBOARD("EASY 5120", MACH_ADM5120_EASY5120), - DEFBOARD("EASY 5120-RT", MACH_ADM5120_EASY5120RT), DEFBOARD("EASY 5120P-ATA", MACH_ADM5120_EASY5120PATA), + DEFBOARD("EASY 5120-RT", MACH_ADM5120_EASY5120RT), + DEFBOARD("EASY 5120-WVoIP", MACH_ADM5120_EASY5120WVOIP), DEFBOARD("EASY 83000", MACH_ADM5120_EASY83000), /* Mikrotik RouterBOARDs */ DEFBOARD("111", MACH_ADM5120_RB_111), |