1
0
mirror of git://projects.qi-hardware.com/openwrt-xburst.git synced 2024-11-24 00:52:27 +02:00

[ifxmips] adds support for airties wav-281/arcor a800/arcaydian arv452

git-svn-id: svn://svn.openwrt.org/openwrt/trunk@20402 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
blogic 2010-03-24 15:55:23 +00:00
parent 3f128a6ae9
commit 6eed60365d

View File

@ -0,0 +1,79 @@
Index: linux-2.6.30.10/arch/mips/ifxmips/board.c
===================================================================
--- linux-2.6.30.10.orig/arch/mips/ifxmips/board.c 2010-03-24 16:45:31.000000000 +0100
+++ linux-2.6.30.10/arch/mips/ifxmips/board.c 2010-03-24 16:53:18.000000000 +0100
@@ -52,6 +52,7 @@
EASY50712,
EASY4010,
ARV4519,
+ ARV452,
};
extern int ifxmips_pci_external_clock;
@@ -141,6 +142,15 @@
{ .name = "ifx:green:usb", .gpio = 19, .active_low = 1, },
};
+static struct gpio_led arv452_gpio_leds[] = {
+ { .name = "ifx:blue:power", .gpio = 3, .active_low = 1, },
+ { .name = "ifx:blue:adsl", .gpio = 4, .active_low = 1, },
+ { .name = "ifx:pink:internet", .gpio = 5, .active_low = 1, },
+ { .name = "ifx:red:power", .gpio = 6, .active_low = 1, },
+ { .name = "ifx:yello:wps", .gpio = 7, .active_low = 1, },
+ { .name = "ifx:red:wps", .gpio = 9, .active_low = 1, },
+};
+
static struct gpio_led_platform_data ifxmips_gpio_led_data;
static struct platform_device ifxmips_gpio_leds = {
@@ -192,6 +202,14 @@
#endif
};
+struct platform_device *arv542_devs[] = {
+ /*&ifxmips_gpio,*/ &ifxmips_mii, &ifxmips_mtd,
+ &ifxmips_gpio_dev, &ifxmips_wdt, &dwc_usb,
+#ifdef CONFIG_LEDS_GPIO
+ &ifxmips_gpio_leds,
+#endif
+};
+
static struct gpio_led easy50712_leds[] = {
{ .name = "ifx:green:test0", .gpio = 0,},
{ .name = "ifx:green:test1", .gpio = 1,},
@@ -237,7 +255,20 @@
.devs = arv5419_devs,
.reset_resource = {.name = "reset", .start = 1, .end = 14},
.pci_external_clock = 1,
+#ifdef CONFIG_LEDS_GPIO
.gpio_leds = arv4519_gpio_leds,
+#endif
+ }, {
+ /* arcaydian annex-b board used by airties, arcor */
+ .type = ARV452,
+ .name = "ARV452",
+ .system_type = SYSTEM_DANUBE_CHIPID2,
+ .devs = arv542_devs,
+ .reset_resource = {.name = "reset", .start = 1, .end = 14},
+ .pci_external_clock = 1,
+#ifdef CONFIG_LEDS_GPIO
+ .gpio_leds = arv452_gpio_leds,
+#endif
},
};
@@ -382,6 +413,14 @@
ifxmips_gpio_led_data.num_leds = ARRAY_SIZE(arv4519_gpio_leds);
#endif
break;
+ case ARV452:
+ /* set some sane defaults for the gpios */
+ board->num_devs = ARRAY_SIZE(arv542_devs);
+ ifxmips_w32(0x8001e7ff, IFXMIPS_EBU_BUSCON1);
+#ifdef CONFIG_LEDS_GPIO
+ ifxmips_gpio_led_data.num_leds = ARRAY_SIZE(arv452_gpio_leds);
+#endif
+ break;
}
#ifdef CONFIG_LEDS_GPIO
ifxmips_gpio_led_data.leds = board->gpio_leds;