ar71xx: add TP-Link TL-WA901ND-v4 support
[openwrt/svn-archive/archive.git] / target / linux / ar71xx / files / arch / mips / ath79 / mach-tl-wr841n-v8.c
index 976c7ee26111e0669dc00f8c926cea8dcc1fb756..73cfdd9cc6f569c2cc063a7caa260af24b6b93c1 100644 (file)
 #define TL_MR3420V2_GPIO_LED_3G        11
 #define TL_MR3420V2_GPIO_USB_POWER     4
 
+#define TL_WR941NDV5_GPIO_LED_WLAN     13
+#define TL_WR941NDV5_GPIO_LED_QSS      15
+#define TL_WR941NDV5_GPIO_LED_WAN      18
+#define TL_WR941NDV5_GPIO_LED_LAN1     19
+#define TL_WR941NDV5_GPIO_LED_LAN2     20
+#define TL_WR941NDV5_GPIO_LED_LAN3     2
+#define TL_WR941NDV5_GPIO_LED_LAN4     3
+#define TL_WR941NDV5_GPIO_LED_SYSTEM   14
+
 #define TL_WR841NV8_KEYS_POLL_INTERVAL 20      /* msecs */
 #define TL_WR841NV8_KEYS_DEBOUNCE_INTERVAL (3 * TL_WR841NV8_KEYS_POLL_INTERVAL)
 
@@ -127,15 +136,62 @@ static struct gpio_keys_button tl_mr3420v2_gpio_keys[] __initdata = {
        }
 };
 
+static struct gpio_led tl_wr941nd_v5_leds_gpio[] __initdata = {
+       {
+               .name           = "tp-link:green:lan1",
+               .gpio           = TL_WR941NDV5_GPIO_LED_LAN1,
+               .active_low     = 1,
+       }, {
+               .name           = "tp-link:green:lan2",
+               .gpio           = TL_WR941NDV5_GPIO_LED_LAN2,
+               .active_low     = 1,
+       }, {
+               .name           = "tp-link:green:lan3",
+               .gpio           = TL_WR941NDV5_GPIO_LED_LAN3,
+               .active_low     = 1,
+       }, {
+               .name           = "tp-link:green:lan4",
+               .gpio           = TL_WR941NDV5_GPIO_LED_LAN4,
+               .active_low     = 1,
+       }, {
+               .name           = "tp-link:green:qss",
+               .gpio           = TL_WR941NDV5_GPIO_LED_QSS,
+               .active_low     = 1,
+       }, {
+               .name           = "tp-link:green:system",
+               .gpio           = TL_WR941NDV5_GPIO_LED_SYSTEM,
+               .active_low     = 1,
+       }, {
+               .name           = "tp-link:green:wan",
+               .gpio           = TL_WR941NDV5_GPIO_LED_WAN,
+               .active_low     = 1,
+       }, {
+               .name           = "tp-link:green:wlan",
+               .gpio           = TL_WR941NDV5_GPIO_LED_WLAN,
+               .active_low     = 1,
+       },
+};
+
 static void __init tl_ap123_setup(void)
 {
        u8 *mac = (u8 *) KSEG1ADDR(0x1f01fc00);
        u8 *ee = (u8 *) KSEG1ADDR(0x1fff1000);
 
+       /* Disable JTAG, enabling GPIOs 0-3 */
+       /* Configure OBS4 line, for GPIO 4*/
+       ath79_gpio_function_setup(AR934X_GPIO_FUNC_JTAG_DISABLE,
+                                AR934X_GPIO_FUNC_CLK_OBS4_EN);
+
+       /* config gpio4 as normal gpio function */
+       ath79_gpio_output_select(TL_MR3420V2_GPIO_USB_POWER,
+                                AR934X_GPIO_OUT_GPIO);
+
        ath79_register_m25p80(&tl_wr841n_v8_flash_data);
 
        ath79_setup_ar934x_eth_cfg(AR934X_ETH_CFG_SW_PHY_SWAP);
 
+       ath79_register_mdio(1, 0x0);
+
        ath79_init_mac(ath79_eth0_data.mac_addr, mac, -1);
        ath79_init_mac(ath79_eth1_data.mac_addr, mac, 0);
 
@@ -164,13 +220,33 @@ static void __init tl_wr841n_v8_setup(void)
        ath79_register_gpio_keys_polled(1, TL_WR841NV8_KEYS_POLL_INTERVAL,
                                        ARRAY_SIZE(tl_wr841n_v8_gpio_keys),
                                        tl_wr841n_v8_gpio_keys);
-
-       ath79_register_mdio(1, 0x0);
 }
 
 MIPS_MACHINE(ATH79_MACH_TL_WR841N_V8, "TL-WR841N-v8", "TP-LINK TL-WR841N/ND v8",
             tl_wr841n_v8_setup);
 
+
+static void __init tl_wr842n_v2_setup(void)
+{
+       tl_ap123_setup();
+
+       ath79_register_leds_gpio(-1, ARRAY_SIZE(tl_wr841n_v8_leds_gpio),
+                                tl_wr841n_v8_leds_gpio);
+
+       ath79_register_gpio_keys_polled(1, TL_WR841NV8_KEYS_POLL_INTERVAL,
+                                       ARRAY_SIZE(tl_wr841n_v8_gpio_keys),
+                                       tl_wr841n_v8_gpio_keys);
+
+       gpio_request_one(TL_MR3420V2_GPIO_USB_POWER,
+                        GPIOF_OUT_INIT_HIGH | GPIOF_EXPORT_DIR_FIXED,
+                        "USB power");
+
+       ath79_register_usb();
+}
+
+MIPS_MACHINE(ATH79_MACH_TL_WR842N_V2, "TL-WR842N-v2", "TP-LINK TL-WR842N/ND v2",
+            tl_wr842n_v2_setup);
+
 static void __init tl_mr3420v2_setup(void)
 {
        tl_ap123_setup();
@@ -182,8 +258,6 @@ static void __init tl_mr3420v2_setup(void)
                                ARRAY_SIZE(tl_mr3420v2_gpio_keys),
                                tl_mr3420v2_gpio_keys);
 
-       ath79_register_mdio(0, 0x0);
-
        /* enable power for the USB port */
        gpio_request_one(TL_MR3420V2_GPIO_USB_POWER,
                         GPIOF_OUT_INIT_HIGH | GPIOF_EXPORT_DIR_FIXED,
@@ -194,3 +268,19 @@ static void __init tl_mr3420v2_setup(void)
 
 MIPS_MACHINE(ATH79_MACH_TL_MR3420_V2, "TL-MR3420-v2", "TP-LINK TL-MR3420 v2",
             tl_mr3420v2_setup);
+
+
+static void __init tl_wr941nd_v5_setup(void)
+{
+       tl_ap123_setup();
+
+       ath79_register_leds_gpio(-1, ARRAY_SIZE(tl_wr941nd_v5_leds_gpio),
+                                tl_wr941nd_v5_leds_gpio);
+
+       ath79_register_gpio_keys_polled(1, TL_WR841NV8_KEYS_POLL_INTERVAL,
+                                       ARRAY_SIZE(tl_wr841n_v8_gpio_keys),
+                                       tl_wr841n_v8_gpio_keys);
+}
+
+MIPS_MACHINE(ATH79_MACH_TL_WR941ND_V5, "TL-WR941ND-v5", "TP-LINK TL-WR941N/ND v5",
+            tl_wr941nd_v5_setup);