diff --git a/target/linux/lantiq/files-3.3/arch/mips/lantiq/xway/mach-p2601hnfx.c b/target/linux/lantiq/files-3.3/arch/mips/lantiq/xway/mach-p2601hnfx.c index ea7e6e8900..247dfb572c 100644 --- a/target/linux/lantiq/files-3.3/arch/mips/lantiq/xway/mach-p2601hnfx.c +++ b/target/linux/lantiq/files-3.3/arch/mips/lantiq/xway/mach-p2601hnfx.c @@ -22,13 +22,13 @@ #include #include +#include +#include #include "../machtypes.h" #include "devices.h" -#include "../dev-gpio-leds.h" #include "dev-dwc_otg.h" - static struct mtd_partition p2601hnfx_partitions[] __initdata = { { @@ -36,20 +36,15 @@ static struct mtd_partition p2601hnfx_partitions[] __initdata = .offset = 0x0, .size = 0x20000, }, -/* { + { .name = "uboot_env", .offset = 0x20000, .size = 0x20000, }, -*/ { - .name = "linux", - .offset = 0x020000, - .size = 0xfc0000, - }, { - .name = "board_config", - .offset = 0xfe0000, - .size = 0x20000, + .name = "linux", + .offset = 0x40000, + .size = 0xfc0000, }, }; @@ -58,22 +53,36 @@ static struct physmap_flash_data p2601hnfx_flash_data __initdata = { .parts = p2601hnfx_partitions, }; -static struct gpio_led p2601hnfx_leds_gpio[] __initdata = { - { .name = "soc:red:power", .gpio = 29, .active_low = 1, .default_trigger = "default-off" }, - { .name = "soc:yellow:phone", .gpio = 64, .active_low = 1, .default_trigger = "default-off" }, - { .name = "soc:green:phone", .gpio = 65, .active_low = 1, .default_trigger = "default-off" }, - { .name = "soc:yellow:wlan", .gpio = 66, .active_low = 1, .default_trigger = "default-off" }, - { .name = "soc:green:power", .gpio = 67, .active_low = 1, .default_trigger = "default-on" }, - { .name = "soc:red:internet", .gpio = 68, .active_low = 1, .default_trigger = "default-off" }, - { .name = "soc:green:internet", .gpio = 69, .active_low = 1, .default_trigger = "default-off" }, - { .name = "soc:green:dsl", .gpio = 70, .active_low = 1, .default_trigger = "default-off" }, - { .name = "soc:green:wlan", .gpio = 71, .active_low = 1, .default_trigger = "default-off" }, +static struct gpio_led +p2601hnfx_leds_gpio[] __initdata = { + { .name = "soc:yellow:phone", .gpio = 216, .active_low = 1 }, + { .name = "soc:green:phone", .gpio = 217, .active_low = 1 }, + { .name = "soc:yellow:wifi", .gpio = 218, .active_low = 1 }, + { .name = "soc:green:power", .gpio = 219, .active_low = 1 }, + { .name = "soc:red:internet", .gpio = 220, .active_low = 1 }, + { .name = "soc:green:internet", .gpio = 221, .active_low = 1 }, + { .name = "soc:green:dsl", .gpio = 222, .active_low = 1 }, + { .name = "soc:green:wifi", .gpio = 223, .active_low = 1 }, }; -static struct gpio_button -p2601hnfx_gpio_buttons[] /* __initdata */ = { - { .desc = "reset", .type = EV_KEY, .code = BTN_0, .threshold = 3, .gpio = 53, .active_low = 1, }, - { .desc = "wlan", .type = EV_KEY, .code = BTN_1, .threshold = 1, .gpio = 54, .active_low = 1, }, +static struct gpio_keys_button +p2601hnfx_gpio_keys[] __initdata = { + { + .desc = "reset", + .type = EV_KEY, + .code = BTN_0, + .debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL, + .gpio = 53, + .active_low = 1, + }, + { + .desc = "wifi", + .type = EV_KEY, + .code = BTN_1, + .debounce_interval = LTQ_KEYS_DEBOUNCE_INTERVAL, + .gpio = 54, + .active_low = 1, + }, }; static struct ltq_eth_data ltq_eth_data = { @@ -86,9 +95,9 @@ p2601hnfx_init(void) #define P2601HNFX_USB 9 ltq_register_gpio_stp(); - ltq_add_device_gpio_leds(-1, ARRAY_SIZE(p2601hnfx_leds_gpio), p2601hnfx_leds_gpio); - ltq_register_gpio_buttons(p2601hnfx_gpio_buttons, ARRAY_SIZE(p2601hnfx_gpio_buttons)); ltq_register_nor(&p2601hnfx_flash_data); + ltq_add_device_gpio_leds(-1, ARRAY_SIZE(p2601hnfx_leds_gpio), p2601hnfx_leds_gpio); + ltq_register_gpio_keys_polled(-1, LTQ_KEYS_POLL_INTERVAL, ARRAY_SIZE(p2601hnfx_gpio_keys), p2601hnfx_gpio_keys); ltq_register_etop(<q_eth_data); xway_register_dwc(P2601HNFX_USB);