2 * TrendNET TEW-632BRP board support
4 * Copyright (C) 2008-2012 Gabor Juhos <juhosg@openwrt.org>
5 * Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org>
7 * This program is free software; you can redistribute it and/or modify it
8 * under the terms of the GNU General Public License version 2 as published
9 * by the Free Software Foundation.
12 #include <asm/mach-ath79/ath79.h>
15 #include "dev-gpio-buttons.h"
16 #include "dev-leds-gpio.h"
17 #include "dev-m25p80.h"
19 #include "machtypes.h"
22 #define TEW_632BRP_GPIO_LED_STATUS 1
23 #define TEW_632BRP_GPIO_LED_WPS 3
24 #define TEW_632BRP_GPIO_LED_WLAN 6
25 #define TEW_632BRP_GPIO_BTN_WPS 12
26 #define TEW_632BRP_GPIO_BTN_RESET 21
28 #define TEW_632BRP_KEYS_POLL_INTERVAL 20 /* msecs */
29 #define TEW_632BRP_KEYS_DEBOUNCE_INTERVAL (3 * TEW_632BRP_KEYS_POLL_INTERVAL)
31 #define TEW_632BRP_CONFIG_ADDR 0x1f020000
32 #define TEW_632BRP_CONFIG_SIZE 0x10000
34 static struct gpio_led tew_632brp_leds_gpio
[] __initdata
= {
36 .name
= "tew-632brp:green:status",
37 .gpio
= TEW_632BRP_GPIO_LED_STATUS
,
40 .name
= "tew-632brp:blue:wps",
41 .gpio
= TEW_632BRP_GPIO_LED_WPS
,
44 .name
= "tew-632brp:green:wlan",
45 .gpio
= TEW_632BRP_GPIO_LED_WLAN
,
50 static struct gpio_keys_button tew_632brp_gpio_keys
[] __initdata
= {
55 .debounce_interval
= TEW_632BRP_KEYS_DEBOUNCE_INTERVAL
,
56 .gpio
= TEW_632BRP_GPIO_BTN_RESET
,
61 .code
= KEY_WPS_BUTTON
,
62 .debounce_interval
= TEW_632BRP_KEYS_DEBOUNCE_INTERVAL
,
63 .gpio
= TEW_632BRP_GPIO_BTN_WPS
,
68 #define TEW_632BRP_LAN_PHYMASK BIT(0)
69 #define TEW_632BRP_WAN_PHYMASK BIT(4)
70 #define TEW_632BRP_MDIO_MASK (~(TEW_632BRP_LAN_PHYMASK | \
71 TEW_632BRP_WAN_PHYMASK))
73 static void __init
tew_632brp_setup(void)
75 const char *config
= (char *) KSEG1ADDR(TEW_632BRP_CONFIG_ADDR
);
76 u8
*eeprom
= (u8
*) KSEG1ADDR(0x1fff1000);
80 if (ath79_nvram_parse_mac_addr(config
, TEW_632BRP_CONFIG_SIZE
,
81 "lan_mac=", mac
) == 0) {
82 ath79_init_mac(ath79_eth0_data
.mac_addr
, mac
, 0);
83 ath79_init_mac(ath79_eth1_data
.mac_addr
, mac
, 1);
87 ath79_register_mdio(0, TEW_632BRP_MDIO_MASK
);
89 ath79_eth0_data
.phy_if_mode
= PHY_INTERFACE_MODE_RMII
;
90 ath79_eth0_data
.phy_mask
= TEW_632BRP_LAN_PHYMASK
;
92 ath79_eth1_data
.phy_if_mode
= PHY_INTERFACE_MODE_RMII
;
93 ath79_eth1_data
.phy_mask
= TEW_632BRP_WAN_PHYMASK
;
95 ath79_register_eth(0);
96 ath79_register_eth(1);
98 ath79_register_m25p80(NULL
);
100 ath79_register_leds_gpio(-1, ARRAY_SIZE(tew_632brp_leds_gpio
),
101 tew_632brp_leds_gpio
);
103 ath79_register_gpio_keys_polled(-1, TEW_632BRP_KEYS_POLL_INTERVAL
,
104 ARRAY_SIZE(tew_632brp_gpio_keys
),
105 tew_632brp_gpio_keys
);
107 ath79_register_wmac(eeprom
, wlan_mac
);
110 MIPS_MACHINE(ATH79_MACH_TEW_632BRP
, "TEW-632BRP", "TRENDnet TEW-632BRP",