diff options
Diffstat (limited to 'target/linux/lantiq/files-3.3/arch/mips')
| -rw-r--r-- | target/linux/lantiq/files-3.3/arch/mips/lantiq/xway/mach-p2601hnfx.c | 61 | 
1 files changed, 35 insertions, 26 deletions
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 ea7e6e890..247dfb572 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 <lantiq_soc.h>  #include <lantiq_platform.h> +#include <dev-gpio-leds.h> +#include <dev-gpio-buttons.h>  #include "../machtypes.h"  #include "devices.h" -#include "../dev-gpio-leds.h"  #include "dev-dwc_otg.h" -  static struct mtd_partition p2601hnfx_partitions[] __initdata =  {  	{ @@ -36,21 +36,16 @@ static struct mtd_partition p2601hnfx_partitions[] __initdata =  		.offset	= 0x0,  		.size	= 0x20000,  	}, -/*	{ +	{  		.name	= "uboot_env",  		.offset	= 0x20000,  		.size	= 0x20000,  	}, -*/	{ +	{  		.name	= "linux", -		.offset	= 0x020000, +		.offset	= 0x40000,  		.size	= 0xfc0000,  	}, -	{ -		.name	= "board_config", -		.offset	= 0xfe0000, -		.size	= 0x20000, -	},  };  static struct physmap_flash_data p2601hnfx_flash_data __initdata = { @@ -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);  | 
