From 2dd79d55c77e400a8dacf79a10d4700f31f95db5 Mon Sep 17 00:00:00 2001
From: Gabor Juhos <juhosg@openwrt.org>
Date: Thu, 1 Dec 2011 22:48:41 +0000
Subject: [PATCH] ramips: Sparklan wcr-150gn board fixes

 * Fix partition sizes.
 * Add buttons and leds.
 * Register usb.
 * Remove unnecessary stuff from image Makefile
 * Fix rt2x00 eeprom extract.

Signed-off-by: Roman Yeryomin <roman@advem.lv>

SVN-Revision: 29380
---
 .../etc/hotplug.d/firmware/10-rt2x00-eeprom   |  2 +-
 .../arch/mips/ralink/rt305x/mach-wcr150gn.c   | 54 ++++++++++++++++++-
 target/linux/ramips/image/Makefile            |  9 +---
 3 files changed, 54 insertions(+), 11 deletions(-)

diff --git a/target/linux/ramips/base-files/etc/hotplug.d/firmware/10-rt2x00-eeprom b/target/linux/ramips/base-files/etc/hotplug.d/firmware/10-rt2x00-eeprom
index d8b35ae30e..920c8a33a2 100644
--- a/target/linux/ramips/base-files/etc/hotplug.d/firmware/10-rt2x00-eeprom
+++ b/target/linux/ramips/base-files/etc/hotplug.d/firmware/10-rt2x00-eeprom
@@ -55,7 +55,7 @@ case "$FIRMWARE" in
 	nw718 | \
 	rt-n15 | \
 	v22rw-2x2 | \
-	wcr150gn | \
+	wcr-150gn | \
 	whr-g300n | \
 	wr512-3gn)
 		rt2x00_eeprom_extract "factory" 0 272
diff --git a/target/linux/ramips/files/arch/mips/ralink/rt305x/mach-wcr150gn.c b/target/linux/ramips/files/arch/mips/ralink/rt305x/mach-wcr150gn.c
index 984bab7b85..0da27359b1 100644
--- a/target/linux/ramips/files/arch/mips/ralink/rt305x/mach-wcr150gn.c
+++ b/target/linux/ramips/files/arch/mips/ralink/rt305x/mach-wcr150gn.c
@@ -22,6 +22,44 @@
 
 #include "devices.h"
 
+#define WCR150GN_GPIO_LED_USER                 12
+#define WCR150GN_GPIO_LED_POWER                        8
+#define WCR150GN_GPIO_BUTTON_WPS               10
+#define WCR150GN_GPIO_BUTTON_RESET             0
+#define WCR150GN_BUTTONS_POLL_INTERVAL         20
+
+static struct gpio_led wcr150gn_leds_gpio[] __initdata = {
+	{
+		.name       = "wcr150gn:amber:user",
+		.gpio       = WCR150GN_GPIO_LED_USER,
+		.active_low = 1,
+	},
+	{
+		.name       = "wcr150gn:amber:power",
+		.gpio       = WCR150GN_GPIO_LED_POWER,
+		.active_low = 1,
+	}
+};
+
+static struct gpio_button wcr150gn_gpio_buttons[] __initdata = {
+	{
+		.desc       = "wps",
+		.type       = EV_KEY,
+		.code       = KEY_WPS_BUTTON,
+		.threshold  = 3,
+		.gpio       = WCR150GN_GPIO_BUTTON_WPS,
+		.active_low = 1,
+	},
+	{
+		.desc       = "reset",
+		.type       = EV_KEY,
+		.code       = KEY_RESTART,
+		.threshold  = 10,
+		.gpio       = WCR150GN_GPIO_BUTTON_RESET,
+		.active_low = 1,
+	}
+};
+
 #ifdef CONFIG_MTD_PARTITIONS
 static struct mtd_partition wcr150gn_partitions[] = {
 	{
@@ -33,18 +71,24 @@ static struct mtd_partition wcr150gn_partitions[] = {
 		.name	= "config",
 		.offset	= 0x030000,
 		.size	= 0x040000,
+		.mask_flags = MTD_WRITEABLE,
 	}, {
 		.name	= "factory",
 		.offset	= 0x040000,
 		.size	= 0x050000,
+		.mask_flags = MTD_WRITEABLE,
 	}, {
 		.name	= "kernel",
 		.offset	= 0x050000,
-		.size	= 0x120000,
+		.size   = 0x0d0000,
 	}, {
 		.name	= "rootfs",
 		.offset	= 0x120000,
-		.size	= 0x400000,
+		.size   = 0x2e0000,
+	}, {
+		.name   = "firmware",
+		.offset = 0x050000,
+		.size   = 0x3b0000,
 	}
 };
 #endif /* CONFIG_MTD_PARTITIONS */
@@ -60,10 +104,16 @@ static void __init wcr150gn_init(void)
 {
 	rt305x_gpio_init(RT305X_GPIO_MODE_GPIO << RT305X_GPIO_MODE_UART0_SHIFT);
 	rt305x_register_flash(0, &wcr150gn_flash_data);
+	ramips_register_gpio_leds(-1, ARRAY_SIZE(wcr150gn_leds_gpio),
+				  wcr150gn_leds_gpio);
+	ramips_register_gpio_buttons(-1, WCR150GN_BUTTONS_POLL_INTERVAL,
+				     ARRAY_SIZE(wcr150gn_gpio_buttons),
+				     wcr150gn_gpio_buttons);
 	rt305x_esw_data.vlan_config = RT305X_ESW_VLAN_CONFIG_LLLLW;
 	rt305x_register_ethernet();
 	rt305x_register_wifi();
 	rt305x_register_wdt();
+	rt305x_register_usb();
 }
 
 MIPS_MACHINE(RAMIPS_MACH_WCR150GN, "WCR150GN", "Sparklan WCR-150GN",
diff --git a/target/linux/ramips/image/Makefile b/target/linux/ramips/image/Makefile
index 7d32155dc7..7f0ef00e46 100644
--- a/target/linux/ramips/image/Makefile
+++ b/target/linux/ramips/image/Makefile
@@ -202,15 +202,8 @@ define Image/Build/Profile/MOFI35003GN
 	$(call Image/Build/Template/GENERIC_8M,$(1),mofi3500-3gn,MOFI3500-3GN)
 endef
 
-mtdlayout_wcr150gn=mtdparts=physmap-flash.0:192k(bootloader)ro,64k(config),64k(factory),832k(kernel),2944k(rootfs),3776k@0x50000(firmware)
-mtd_wcr150gn_kernel_part_size=851968
-mtd_wcr150gn_rootfs_part_size=3014656
-define Image/Build/Template/WCR150GN
-	$(call BuildFirmware/Generic,$(1),$(2),board=$(3),mtdlayout_wcr150gn,$(mtd_wcr150gn_kernel_part_size),$(mtd_wcr150gn_rootfs_part_size))
-endef
-
 define Image/Build/Profile/WCR150GN
-	$(call Image/Build/Template/WCR150GN,$(1),wcr150gn,WCR150GN)
+	$(call Image/Build/Template/GENERIC_4M,$(1),wcr150gn,WCR150GN)
 endef
 
 
-- 
GitLab