Browse Source

fixes zyxel p2601hnfx

moves the linux partition, removes the config partition and the
buttons settings have small adjustments.

Signed-off-by: Luka Perkov <[email protected]>

SVN-Revision: 31909
John Crispin 13 years ago
parent
commit
6e8fe84472
1 changed files with 35 additions and 26 deletions
  1. 35 26
      target/linux/lantiq/files-3.3/arch/mips/lantiq/xway/mach-p2601hnfx.c

+ 35 - 26
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(&ltq_eth_data);
 	xway_register_dwc(P2601HNFX_USB);