X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/c44ee422c3f7fb736b69ded2793a3673d0e51266..0dad89e259fbc5115631b0cfa54ea512eb411121:/target/linux/ramips/files/arch/mips/ralink/rt305x/mach-whr-g300n.c diff --git a/target/linux/ramips/files/arch/mips/ralink/rt305x/mach-whr-g300n.c b/target/linux/ramips/files/arch/mips/ralink/rt305x/mach-whr-g300n.c index 4e0e810bb..fdcd6b320 100644 --- a/target/linux/ramips/files/arch/mips/ralink/rt305x/mach-whr-g300n.c +++ b/target/linux/ramips/files/arch/mips/ralink/rt305x/mach-whr-g300n.c @@ -31,9 +31,9 @@ #define WHR_G300N_GPIO_BUTTON_ROUTER_ON 8 /* active low */ #define WHR_G300N_GPIO_BUTTON_ROUTER_OFF 11 /* active low */ -#define WHR_G300N_BUTTONS_POLL_INTERVAL 20 +#define WHR_G300N_KEYS_POLL_INTERVAL 20 +#define WHR_G300N_KEYS_DEBOUNCE_INTERVAL (3 * WHR_G300N_KEYS_POLL_INTERVAL) -#ifdef CONFIG_MTD_PARTITIONS static struct mtd_partition whr_g300n_partitions[] = { { .name = "u-boot", @@ -63,19 +63,11 @@ static struct mtd_partition whr_g300n_partitions[] = { .offset = 0x3f0000, .size = 0x010000, }, { - .name = "openwrt", + .name = "firmware", .offset = 0x050000, .size = 0x3a0000, } }; -#endif /* CONFIG_MTD_PARTITIONS */ - -static struct physmap_flash_data whr_g300n_flash_data = { -#ifdef CONFIG_MTD_PARTITIONS - .nr_parts = ARRAY_SIZE(whr_g300n_partitions), - .parts = whr_g300n_partitions, -#endif -}; static struct gpio_led whr_g300n_leds_gpio[] __initdata = { { @@ -93,33 +85,33 @@ static struct gpio_led whr_g300n_leds_gpio[] __initdata = { } }; -static struct gpio_button whr_g300n_gpio_buttons[] __initdata = { +static struct gpio_keys_button whr_g300n_gpio_buttons[] __initdata = { { .desc = "reset", .type = EV_KEY, - .code = BTN_0, - .threshold = 3, + .code = KEY_RESTART, + .debounce_interval = WHR_G300N_KEYS_DEBOUNCE_INTERVAL, .gpio = WHR_G300N_GPIO_BUTTON_RESET, .active_low = 1, }, { .desc = "aoss", .type = EV_KEY, - .code = BTN_1, - .threshold = 3, + .code = KEY_WPS_BUTTON, + .debounce_interval = WHR_G300N_KEYS_DEBOUNCE_INTERVAL, .gpio = WHR_G300N_GPIO_BUTTON_AOSS, .active_low = 1, }, { .desc = "router-off", .type = EV_KEY, .code = BTN_2, - .threshold = 3, + .debounce_interval = WHR_G300N_KEYS_DEBOUNCE_INTERVAL, .gpio = WHR_G300N_GPIO_BUTTON_ROUTER_OFF, .active_low = 1, }, { .desc = "router-on", .type = EV_KEY, .code = BTN_3, - .threshold = 3, + .debounce_interval = WHR_G300N_KEYS_DEBOUNCE_INTERVAL, .gpio = WHR_G300N_GPIO_BUTTON_ROUTER_ON, .active_low = 1, } @@ -129,14 +121,19 @@ static void __init whr_g300n_init(void) { rt305x_gpio_init(RT305X_GPIO_MODE_GPIO << RT305X_GPIO_MODE_UART0_SHIFT); - rt305x_register_flash(0, &whr_g300n_flash_data); + rt305x_flash0_data.nr_parts = ARRAY_SIZE(whr_g300n_partitions); + rt305x_flash0_data.parts = whr_g300n_partitions; + rt305x_register_flash(0); + + rt305x_esw_data.vlan_config = RT305X_ESW_VLAN_CONFIG_LLLLW; rt305x_register_ethernet(); ramips_register_gpio_leds(-1, ARRAY_SIZE(whr_g300n_leds_gpio), whr_g300n_leds_gpio); - ramips_register_gpio_buttons(-1, WHR_G300N_BUTTONS_POLL_INTERVAL, + ramips_register_gpio_buttons(-1, WHR_G300N_KEYS_POLL_INTERVAL, ARRAY_SIZE(whr_g300n_gpio_buttons), whr_g300n_gpio_buttons); rt305x_register_wifi(); + rt305x_register_wdt(); } MIPS_MACHINE(RAMIPS_MACH_WHR_G300N, "WHR-G300N", "Buffalo WHR-G300N",