[adm5120] add support for LEDs on the NP28G board, thanks to kenny (closes: #2825)
[openwrt/svn-archive/archive.git] / target / linux / adm5120 / files / arch / mips / adm5120 / boards / compex.c
index d1e2edd02422758bd5ec0c297aa5e69da9a217f0..d1c6bc42a60fe6bf7cd4500746eb925377432cfb 100644 (file)
 #include <adm5120_platform.h>
 #include <adm5120_irq.h>
 
-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 void wp54_reset(void)
-{
-       gpio_set_value(ADM5120_GPIO_PIN3, 0);
-}
-
 static struct adm5120_pci_irq wp54_pci_irqs[] __initdata = {
        PCIIRQ(2, 0, 1, ADM5120_IRQ_PCI0),
 };
@@ -87,11 +70,62 @@ static struct platform_device *wp54_devices[] __initdata = {
        &adm5120_flash0_device,
 };
 
-static void __init np2xg_setup(void)
+unsigned char np27g_vlans[6] __initdata = {
+       /* FIXME: untested */
+       0x41, 0x42, 0x44, 0x48, 0x50, 0x00
+};
+
+unsigned char np28g_vlans[6] __initdata = {
+       0x50, 0x42, 0x44, 0x48, 0x00, 0x00
+};
+
+unsigned char wp54_vlans[6] __initdata = {
+       0x41, 0x42, 0x00, 0x00, 0x00, 0x00
+};
+
+/*--------------------------------------------------------------------------*/
+
+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 void wp54_reset(void)
+{
+       gpio_set_value(ADM5120_GPIO_PIN3, 0);
+}
+
+static void np28g_reset(void)
+{
+       gpio_set_value(ADM5120_GPIO_PIN4, 0);
+}
+
+static void __init np27g_setup(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;
+
+       /* TODO: setup mac address */
+}
+
+static void __init np28g_setup(void)
 {
        gpio_request(ADM5120_GPIO_PIN5, NULL); /* for flash A20 line */
        gpio_direction_output(ADM5120_GPIO_PIN5, 0);
 
+       gpio_request(ADM5120_GPIO_PIN4, NULL); /* for system reset */
+       gpio_direction_output(ADM5120_GPIO_PIN4, 1);
+
        /* setup data for flash0 device */
        adm5120_flash0_data.switch_bank = switch_bank_gpio5;
 
@@ -106,7 +140,6 @@ static void __init wp54_setup(void)
        gpio_request(ADM5120_GPIO_PIN3, NULL); /* for system reset */
        gpio_direction_output(ADM5120_GPIO_PIN3, 1);
 
-
        /* setup data for flash0 device */
        adm5120_flash0_data.switch_bank = switch_bank_gpio5;
 
@@ -129,44 +162,28 @@ static void __init wp54_wrt_setup(void)
        /* TODO: setup mac address */
 }
 
-unsigned char np27g_vlans[6] __initdata = {
-       /* FIXME: untested */
-       0x41, 0x42, 0x44, 0x48, 0x50, 0x00
-};
-
-unsigned char np28g_vlans[6] __initdata = {
-       0x50, 0x42, 0x44, 0x48, 0x00, 0x00
-};
+/*--------------------------------------------------------------------------*/
 
-unsigned char wp54_vlans[6] __initdata = {
-       0x41, 0x42, 0x00, 0x00, 0x00, 0x00
-};
-
-static struct adm5120_board np27g_board __initdata = {
-       .mach_type      = MACH_ADM5120_NP27G,
-       .name           = "Compex NetPassage 27G",
-       .board_setup    = np2xg_setup,
+ADM5120_BOARD_START(NP27G, "Compex NetPassage 27G")
+       .board_setup    = np27g_setup,
        .eth_num_ports  = 5,
        .eth_vlans      = np27g_vlans,
        .num_devices    = ARRAY_SIZE(np2xg_devices),
        .devices        = np2xg_devices,
-};
+       /* TODO: add PCI IRQ map */
+ADM5120_BOARD_END
 
-static struct adm5120_board np28g_board __initdata = {
-       .mach_type      = MACH_ADM5120_NP28G,
-       .name           = "Compex NetPassage 28G",
-       .board_setup    = np2xg_setup,
+ADM5120_BOARD_START(NP28G, "Compex NetPassage 28G")
+       .board_setup    = np28g_setup,
        .eth_num_ports  = 4,
        .eth_vlans      = np28g_vlans,
        .num_devices    = ARRAY_SIZE(np2xg_devices),
        .devices        = np2xg_devices,
        .pci_nr_irqs    = ARRAY_SIZE(np28g_pci_irqs),
        .pci_irq_map    = np28g_pci_irqs,
-};
+ADM5120_BOARD_END
 
-static struct adm5120_board wp54ag_board __initdata = {
-       .mach_type      = MACH_ADM5120_WP54AG,
-       .name           = "Compex WP54AG",
+ADM5120_BOARD_START(WP54AG, "Compex WP54AG")
        .board_setup    = wp54_setup,
        .board_reset    = wp54_reset,
        .eth_num_ports  = 2,
@@ -175,11 +192,9 @@ static struct adm5120_board wp54ag_board __initdata = {
        .devices        = wp54_devices,
        .pci_nr_irqs    = ARRAY_SIZE(wp54_pci_irqs),
        .pci_irq_map    = wp54_pci_irqs,
-};
+ADM5120_BOARD_END
 
-static struct adm5120_board wp54g_board __initdata = {
-       .mach_type      = MACH_ADM5120_WP54G,
-       .name           = "Compex WP54G",
+ADM5120_BOARD_START(WP54G, "Compex WP54G")
        .board_setup    = wp54_setup,
        .board_reset    = wp54_reset,
        .eth_num_ports  = 2,
@@ -188,11 +203,9 @@ static struct adm5120_board wp54g_board __initdata = {
        .devices        = wp54_devices,
        .pci_nr_irqs    = ARRAY_SIZE(wp54_pci_irqs),
        .pci_irq_map    = wp54_pci_irqs,
-};
+ADM5120_BOARD_END
 
-static struct adm5120_board wp54g_wrt_board __initdata = {
-       .mach_type      = MACH_ADM5120_WP54G_WRT,
-       .name           = "Compex WP54G-WRT",
+ADM5120_BOARD_START(WP54G_WRT, "Compex WP54G-WRT")
        .board_setup    = wp54_wrt_setup,
        .board_reset    = wp54_reset,
        .eth_num_ports  = 2,
@@ -201,11 +214,9 @@ static struct adm5120_board wp54g_wrt_board __initdata = {
        .devices        = wp54_devices,
        .pci_nr_irqs    = ARRAY_SIZE(wp54_pci_irqs),
        .pci_irq_map    = wp54_pci_irqs,
-};
+ADM5120_BOARD_END
 
-static struct adm5120_board wpp54ag_board __initdata = {
-       .mach_type      = MACH_ADM5120_WPP54AG,
-       .name           = "Compex WPP54AG",
+ADM5120_BOARD_START(WPP54AG, "Compex WPP54AG")
        .board_setup    = wp54_setup,
        .board_reset    = wp54_reset,
        .eth_num_ports  = 2,
@@ -214,11 +225,9 @@ static struct adm5120_board wpp54ag_board __initdata = {
        .devices        = wp54_devices,
        .pci_nr_irqs    = ARRAY_SIZE(wp54_pci_irqs),
        .pci_irq_map    = wp54_pci_irqs,
-};
+ADM5120_BOARD_END
 
-static struct adm5120_board wpp54g_board __initdata = {
-       .mach_type      = MACH_ADM5120_WPP54G,
-       .name           = "Compex WPP54G",
+ADM5120_BOARD_START(WPP54G, "Compex WPP54G")
        .board_setup    = wp54_setup,
        .board_reset    = wp54_reset,
        .eth_num_ports  = 2,
@@ -227,18 +236,4 @@ static struct adm5120_board wpp54g_board __initdata = {
        .devices        = wp54_devices,
        .pci_nr_irqs    = ARRAY_SIZE(wp54_pci_irqs),
        .pci_irq_map    = wp54_pci_irqs,
-};
-
-static int __init register_boards(void)
-{
-       adm5120_board_register(&np27g_board);
-       adm5120_board_register(&np28g_board);
-       adm5120_board_register(&wp54ag_board);
-       adm5120_board_register(&wp54g_board);
-       adm5120_board_register(&wp54g_wrt_board);
-       adm5120_board_register(&wpp54ag_board);
-       adm5120_board_register(&wpp54g_board);
-       return 0;
-}
-
-pure_initcall(register_boards);
+ADM5120_BOARD_END