From 5b0c83edd9b5f8286dfbf31fc7b6e0993a9fe91a Mon Sep 17 00:00:00 2001
From: Gabor Juhos <juhosg@openwrt.org>
Date: Fri, 10 Dec 2010 17:57:48 +0000
Subject: [PATCH] ar71xx: add support for the TP-LINK TL-MR3220 v1 board

SVN-Revision: 24439
---
 .../etc/defconfig/tl-mr3220/network           | 24 ++++++
 target/linux/ar71xx/base-files/etc/diag.sh    |  4 +-
 target/linux/ar71xx/base-files/lib/ar71xx.sh  |  3 +
 .../ar71xx/base-files/lib/upgrade/platform.sh |  2 +-
 target/linux/ar71xx/config-2.6.32             |  2 +-
 target/linux/ar71xx/config-2.6.36             |  2 +-
 target/linux/ar71xx/config-2.6.37             |  2 +-
 .../ar71xx/files/arch/mips/ar71xx/Kconfig     |  4 +-
 .../ar71xx/files/arch/mips/ar71xx/Makefile    |  2 +-
 .../{mach-tl-mr3420.c => mach-tl-mr3x20.c}    | 73 ++++++++++---------
 .../ar71xx/files/arch/mips/ar71xx/machtype.h  |  1 +
 .../linux/ar71xx/generic/profiles/tp-link.mk  | 11 +++
 target/linux/ar71xx/image/Makefile            |  5 ++
 13 files changed, 91 insertions(+), 44 deletions(-)
 create mode 100644 target/linux/ar71xx/base-files/etc/defconfig/tl-mr3220/network
 rename target/linux/ar71xx/files/arch/mips/ar71xx/{mach-tl-mr3420.c => mach-tl-mr3x20.c} (57%)

diff --git a/target/linux/ar71xx/base-files/etc/defconfig/tl-mr3220/network b/target/linux/ar71xx/base-files/etc/defconfig/tl-mr3220/network
new file mode 100644
index 0000000000..de201bf5ec
--- /dev/null
+++ b/target/linux/ar71xx/base-files/etc/defconfig/tl-mr3220/network
@@ -0,0 +1,24 @@
+config interface loopback
+	option ifname	lo
+	option proto	static
+	option ipaddr	127.0.0.1
+	option netmask	255.0.0.0
+
+config interface lan
+	option ifname	eth0
+	option type	bridge
+	option proto	static
+	option ipaddr	192.168.1.1
+	option netmask	255.255.255.0
+
+config interface wan
+	option ifname	eth1
+	option proto	dhcp
+
+config switch eth0
+	option enable_vlan	1
+
+config switch_vlan
+	option device	eth0
+	option vlan	1
+	option ports	"0 1 2 3 4"
diff --git a/target/linux/ar71xx/base-files/etc/diag.sh b/target/linux/ar71xx/base-files/etc/diag.sh
index a89ede9493..7abedc0a2f 100755
--- a/target/linux/ar71xx/base-files/etc/diag.sh
+++ b/target/linux/ar71xx/base-files/etc/diag.sh
@@ -81,8 +81,8 @@ get_status_led() {
 	tew-632brp)
 		status_led="tew-632brp:green:status"
 		;;
-	tl-mr3420)
-		status_led="tl-mr3420:green:system"
+	tl-mr3220 | tl-mr3420)
+		status_led="tl-mr3x20:green:system"
 		;;
 	tl-wa901nd)
 		status_led="tl-wa901nd:green:system"
diff --git a/target/linux/ar71xx/base-files/lib/ar71xx.sh b/target/linux/ar71xx/base-files/lib/ar71xx.sh
index ec3aa5b62a..ae50a23c52 100755
--- a/target/linux/ar71xx/base-files/lib/ar71xx.sh
+++ b/target/linux/ar71xx/base-files/lib/ar71xx.sh
@@ -100,6 +100,9 @@ ar71xx_board_name() {
 	*"DIR-615 rev. C1")
 		name="dir-615-c1"
 		;;
+	*TL-MR3220)
+		name="tl-mr3220"
+		;;
 	*TL-MR3420)
 		name="tl-mr3420"
 		;;
diff --git a/target/linux/ar71xx/base-files/lib/upgrade/platform.sh b/target/linux/ar71xx/base-files/lib/upgrade/platform.sh
index 36e2b2146f..1cbde8bc66 100755
--- a/target/linux/ar71xx/base-files/lib/upgrade/platform.sh
+++ b/target/linux/ar71xx/base-files/lib/upgrade/platform.sh
@@ -75,7 +75,7 @@ platform_check_image() {
 		}
 		return 0
 		;;
-	tl-mr3420 | tl-wa901nd | tl-wr741nd | tl-wr841n-v1 | tl-wr941nd | tl-wr1043nd)
+	tl-mr3220 | tl-mr3420 | tl-wa901nd | tl-wr741nd | tl-wr841n-v1 | tl-wr941nd | tl-wr1043nd)
 		[ "$magic" != "0100" ] && {
 			echo "Invalid image type."
 			return 1
diff --git a/target/linux/ar71xx/config-2.6.32 b/target/linux/ar71xx/config-2.6.32
index 5d21acfaac..559c800221 100644
--- a/target/linux/ar71xx/config-2.6.32
+++ b/target/linux/ar71xx/config-2.6.32
@@ -34,7 +34,7 @@ CONFIG_AR71XX_MACH_PB92=y
 CONFIG_AR71XX_MACH_RB4XX=y
 CONFIG_AR71XX_MACH_RB750=y
 CONFIG_AR71XX_MACH_TEW_632BRP=y
-CONFIG_AR71XX_MACH_TL_MR3420=y
+CONFIG_AR71XX_MACH_TL_MR3X20=y
 CONFIG_AR71XX_MACH_TL_WA901ND=y
 CONFIG_AR71XX_MACH_TL_WR1043ND=y
 CONFIG_AR71XX_MACH_TL_WR741ND=y
diff --git a/target/linux/ar71xx/config-2.6.36 b/target/linux/ar71xx/config-2.6.36
index b2c3cd7b3b..108855f14c 100644
--- a/target/linux/ar71xx/config-2.6.36
+++ b/target/linux/ar71xx/config-2.6.36
@@ -30,7 +30,7 @@ CONFIG_AR71XX_MACH_PB92=y
 CONFIG_AR71XX_MACH_RB4XX=y
 CONFIG_AR71XX_MACH_RB750=y
 CONFIG_AR71XX_MACH_TEW_632BRP=y
-CONFIG_AR71XX_MACH_TL_MR3420=y
+CONFIG_AR71XX_MACH_TL_MR3X20=y
 CONFIG_AR71XX_MACH_TL_WA901ND=y
 CONFIG_AR71XX_MACH_TL_WR1043ND=y
 CONFIG_AR71XX_MACH_TL_WR741ND=y
diff --git a/target/linux/ar71xx/config-2.6.37 b/target/linux/ar71xx/config-2.6.37
index b2c3cd7b3b..108855f14c 100644
--- a/target/linux/ar71xx/config-2.6.37
+++ b/target/linux/ar71xx/config-2.6.37
@@ -30,7 +30,7 @@ CONFIG_AR71XX_MACH_PB92=y
 CONFIG_AR71XX_MACH_RB4XX=y
 CONFIG_AR71XX_MACH_RB750=y
 CONFIG_AR71XX_MACH_TEW_632BRP=y
-CONFIG_AR71XX_MACH_TL_MR3420=y
+CONFIG_AR71XX_MACH_TL_MR3X20=y
 CONFIG_AR71XX_MACH_TL_WA901ND=y
 CONFIG_AR71XX_MACH_TL_WR1043ND=y
 CONFIG_AR71XX_MACH_TL_WR741ND=y
diff --git a/target/linux/ar71xx/files/arch/mips/ar71xx/Kconfig b/target/linux/ar71xx/files/arch/mips/ar71xx/Kconfig
index 87c59046cc..3524dfe6b8 100644
--- a/target/linux/ar71xx/files/arch/mips/ar71xx/Kconfig
+++ b/target/linux/ar71xx/files/arch/mips/ar71xx/Kconfig
@@ -183,8 +183,8 @@ config AR71XX_MACH_NBG460N
 	select AR71XX_DEV_LEDS_GPIO
 	default n
 
-config AR71XX_MACH_TL_MR3420
-	bool "TP-LINK TL-MR3420 support"
+config AR71XX_MACH_TL_MR3X20
+	bool "TP-LINK TL-MR3220/3420 support"
 	select AR71XX_DEV_M25P80
 	select AR71XX_DEV_AP91_PCI if PCI
 	select AR71XX_DEV_GPIO_BUTTONS
diff --git a/target/linux/ar71xx/files/arch/mips/ar71xx/Makefile b/target/linux/ar71xx/files/arch/mips/ar71xx/Makefile
index f6ceb0a98f..b5b971a781 100644
--- a/target/linux/ar71xx/files/arch/mips/ar71xx/Makefile
+++ b/target/linux/ar71xx/files/arch/mips/ar71xx/Makefile
@@ -45,7 +45,7 @@ obj-$(CONFIG_AR71XX_MACH_PB92)		+= mach-pb92.o
 obj-$(CONFIG_AR71XX_MACH_RB4XX)		+= mach-rb4xx.o
 obj-$(CONFIG_AR71XX_MACH_RB750)		+= mach-rb750.o
 obj-$(CONFIG_AR71XX_MACH_TEW_632BRP)	+= mach-tew-632brp.o
-obj-$(CONFIG_AR71XX_MACH_TL_MR3420)	+= mach-tl-mr3420.o
+obj-$(CONFIG_AR71XX_MACH_TL_MR3X20)	+= mach-tl-mr3x20.o
 obj-$(CONFIG_AR71XX_MACH_TL_WA901ND)	+= mach-tl-wa901nd.o
 obj-$(CONFIG_AR71XX_MACH_TL_WR741ND)	+= mach-tl-wr741nd.o
 obj-$(CONFIG_AR71XX_MACH_TL_WR841N_V1)	+= mach-tl-wr841n.o
diff --git a/target/linux/ar71xx/files/arch/mips/ar71xx/mach-tl-mr3420.c b/target/linux/ar71xx/files/arch/mips/ar71xx/mach-tl-mr3x20.c
similarity index 57%
rename from target/linux/ar71xx/files/arch/mips/ar71xx/mach-tl-mr3420.c
rename to target/linux/ar71xx/files/arch/mips/ar71xx/mach-tl-mr3x20.c
index c1888cac84..db415597eb 100644
--- a/target/linux/ar71xx/files/arch/mips/ar71xx/mach-tl-mr3420.c
+++ b/target/linux/ar71xx/files/arch/mips/ar71xx/mach-tl-mr3x20.c
@@ -1,5 +1,5 @@
 /*
- *  TP-LINK TL-MR3420 board support
+ *  TP-LINK TL-MR3220/3420 board support
  *
  *  Copyright (C) 2010 Gabor Juhos <juhosg@openwrt.org>
  *
@@ -22,19 +22,19 @@
 #include "dev-leds-gpio.h"
 #include "dev-usb.h"
 
-#define TL_MR3420_GPIO_LED_QSS		0
-#define TL_MR3420_GPIO_LED_SYSTEM	1
-#define TL_MR3420_GPIO_LED_3G		8
+#define TL_MR3X20_GPIO_LED_QSS		0
+#define TL_MR3X20_GPIO_LED_SYSTEM	1
+#define TL_MR3X20_GPIO_LED_3G		8
 
-#define TL_MR3420_GPIO_BTN_RESET	11
-#define TL_MR3420_GPIO_BTN_QSS		12
+#define TL_MR3X20_GPIO_BTN_RESET	11
+#define TL_MR3X20_GPIO_BTN_QSS		12
 
-#define TL_MR3420_GPIO_USB_POWER	6
+#define TL_MR3X20_GPIO_USB_POWER	6
 
-#define TL_MR3420_BUTTONS_POLL_INTERVAL	20
+#define TL_MR3X20_BUTTONS_POLL_INTERVAL	20
 
 #ifdef CONFIG_MTD_PARTITIONS
-static struct mtd_partition tl_mr3420_partitions[] = {
+static struct mtd_partition tl_mr3x20_partitions[] = {
 	{
 		.name		= "u-boot",
 		.offset		= 0,
@@ -59,68 +59,68 @@ static struct mtd_partition tl_mr3420_partitions[] = {
 		.size		= 0x3d0000,
 	}
 };
-#define tl_mr3420_num_partitions	ARRAY_SIZE(tl_mr3420_partitions)
+#define tl_mr3x20_num_partitions	ARRAY_SIZE(tl_mr3x20_partitions)
 #else
-#define tl_mr3420_partitions		NULL
-#define tl_mr3420_num_partitions	0
+#define tl_mr3x20_partitions		NULL
+#define tl_mr3x20_num_partitions	0
 #endif /* CONFIG_MTD_PARTITIONS */
 
-static struct flash_platform_data tl_mr3420_flash_data = {
-	.parts		= tl_mr3420_partitions,
-	.nr_parts	= tl_mr3420_num_partitions,
+static struct flash_platform_data tl_mr3x20_flash_data = {
+	.parts		= tl_mr3x20_partitions,
+	.nr_parts	= tl_mr3x20_num_partitions,
 };
 
-static struct gpio_led tl_mr3420_leds_gpio[] __initdata = {
+static struct gpio_led tl_mr3x20_leds_gpio[] __initdata = {
 	{
-		.name		= "tl-mr3420:green:system",
-		.gpio		= TL_MR3420_GPIO_LED_SYSTEM,
+		.name		= "tl-mr3x20:green:system",
+		.gpio		= TL_MR3X20_GPIO_LED_SYSTEM,
 		.active_low	= 1,
 	}, {
-		.name		= "tl-mr3420:green:qss",
-		.gpio		= TL_MR3420_GPIO_LED_QSS,
+		.name		= "tl-mr3x20:green:qss",
+		.gpio		= TL_MR3X20_GPIO_LED_QSS,
 		.active_low	= 1,
 	}, {
-		.name		= "tl-mr3420:green:3g",
-		.gpio		= TL_MR3420_GPIO_LED_3G,
+		.name		= "tl-mr3x20:green:3g",
+		.gpio		= TL_MR3X20_GPIO_LED_3G,
 		.active_low	= 1,
 	}
 };
 
-static struct gpio_button tl_mr3420_gpio_buttons[] __initdata = {
+static struct gpio_button tl_mr3x20_gpio_buttons[] __initdata = {
 	{
 		.desc		= "reset",
 		.type		= EV_KEY,
 		.code		= KEY_RESTART,
 		.threshold	= 3,
-		.gpio		= TL_MR3420_GPIO_BTN_RESET,
+		.gpio		= TL_MR3X20_GPIO_BTN_RESET,
 		.active_low	= 1,
 	}, {
 		.desc		= "qss",
 		.type		= EV_KEY,
 		.code		= KEY_WPS_BUTTON,
 		.threshold	= 3,
-		.gpio		= TL_MR3420_GPIO_BTN_QSS,
+		.gpio		= TL_MR3X20_GPIO_BTN_QSS,
 		.active_low	= 1,
 	}
 };
 
-static void __init tl_mr3420_setup(void)
+static void __init tl_mr3x20_setup(void)
 {
 	u8 *mac = (u8 *) KSEG1ADDR(0x1f01fc00);
 	u8 *ee = (u8 *) KSEG1ADDR(0x1fff1000);
 
 	/* enable power for the USB port */
-	gpio_request(TL_MR3420_GPIO_USB_POWER, "USB power");
-	gpio_direction_output(TL_MR3420_GPIO_USB_POWER, 1);
+	gpio_request(TL_MR3X20_GPIO_USB_POWER, "USB power");
+	gpio_direction_output(TL_MR3X20_GPIO_USB_POWER, 1);
 
-	ar71xx_add_device_m25p80(&tl_mr3420_flash_data);
+	ar71xx_add_device_m25p80(&tl_mr3x20_flash_data);
 
-	ar71xx_add_device_leds_gpio(-1, ARRAY_SIZE(tl_mr3420_leds_gpio),
-					tl_mr3420_leds_gpio);
+	ar71xx_add_device_leds_gpio(-1, ARRAY_SIZE(tl_mr3x20_leds_gpio),
+					tl_mr3x20_leds_gpio);
 
-	ar71xx_add_device_gpio_buttons(-1, TL_MR3420_BUTTONS_POLL_INTERVAL,
-					ARRAY_SIZE(tl_mr3420_gpio_buttons),
-					tl_mr3420_gpio_buttons);
+	ar71xx_add_device_gpio_buttons(-1, TL_MR3X20_BUTTONS_POLL_INTERVAL,
+					ARRAY_SIZE(tl_mr3x20_gpio_buttons),
+					tl_mr3x20_gpio_buttons);
 
 	ar71xx_eth1_data.has_ar7240_switch = 1;
 	ar71xx_init_mac(ar71xx_eth0_data.mac_addr, mac, 0);
@@ -145,4 +145,7 @@ static void __init tl_mr3420_setup(void)
 	ap91_pci_init(ee, mac);
 }
 MIPS_MACHINE(AR71XX_MACH_TL_MR3420, "TL-MR3420", "TP-LINK TL-MR3420",
-	     tl_mr3420_setup);
+	     tl_mr3x20_setup);
+
+MIPS_MACHINE(AR71XX_MACH_TL_MR3220, "TL-MR3220", "TP-LINK TL-MR3220",
+	     tl_mr3x20_setup);
diff --git a/target/linux/ar71xx/files/arch/mips/ar71xx/machtype.h b/target/linux/ar71xx/files/arch/mips/ar71xx/machtype.h
index ec35677be2..620e009677 100644
--- a/target/linux/ar71xx/files/arch/mips/ar71xx/machtype.h
+++ b/target/linux/ar71xx/files/arch/mips/ar71xx/machtype.h
@@ -38,6 +38,7 @@ enum ar71xx_mach_type {
 	AR71XX_MACH_MZK_W300NH,	/* Planex MZK-W300NH */
 	AR71XX_MACH_NBG460N,	/* Zyxel NBG460N/550N/550NH */
 	AR71XX_MACH_TEW_632BRP,	/* TRENDnet TEW-632BRP */
+	AR71XX_MACH_TL_MR3220,	/* TP-LINK TL-MR3220 */
 	AR71XX_MACH_TL_MR3420,	/* TP-LINK TL-MR3420 */
 	AR71XX_MACH_TL_WA901ND,	/* TP-LINK TL-WA901ND */
 	AR71XX_MACH_TL_WR741ND,	/* TP-LINK TL-WR741ND */
diff --git a/target/linux/ar71xx/generic/profiles/tp-link.mk b/target/linux/ar71xx/generic/profiles/tp-link.mk
index 890e4b28a8..a36e1756f6 100644
--- a/target/linux/ar71xx/generic/profiles/tp-link.mk
+++ b/target/linux/ar71xx/generic/profiles/tp-link.mk
@@ -5,6 +5,17 @@
 # See /LICENSE for more information.
 #
 
+define Profile/TLMR3220V1
+	NAME:=TP-LINK TL-MR3220 v1
+	PACKAGES:=kmod-ath9k wpad-mini kmod-usb-core kmod-usb2
+endef
+
+define Profile/TLMR3220V1/Description
+	Package set optimized for the TP-LINK TL-MR3220 v1.
+endef
+
+$(eval $(call Profile,TLMR3220V1))
+
 define Profile/TLMR3420V1
 	NAME:=TP-LINK TL-MR3420 v1
 	PACKAGES:=kmod-ath9k wpad-mini kmod-usb-core kmod-usb2
diff --git a/target/linux/ar71xx/image/Makefile b/target/linux/ar71xx/image/Makefile
index 44c030e4e0..66be14b48f 100644
--- a/target/linux/ar71xx/image/Makefile
+++ b/target/linux/ar71xx/image/Makefile
@@ -570,6 +570,10 @@ define Image/Build/Profile/NBG_460N_550N_550NH
 	$(call Image/Build/Template/$(fs_64k)/$(1),ZyXEL,nbg460n_550n_550nh,board=NBG460N,NBG-460N)
 endef
 
+define Image/Build/Profile/TLMR3220V1
+	$(call Image/Build/Template/$(fs_4k)/$(1),TPLINK,tl-mr3220-v1,board=TL-MR3220,TL-MR3220v1)
+endef
+
 define Image/Build/Profile/TLMR3420V1
 	$(call Image/Build/Template/$(fs_4k)/$(1),TPLINK,tl-mr3420-v1,board=TL-MR3420,TL-MR3420v1)
 endef
@@ -664,6 +668,7 @@ define Image/Build/Profile/Default
 	$(call Image/Build/Profile/PB92,$(1))
 	$(call Image/Build/Profile/TEW632BRP,$(1))
 	$(call Image/Build/Profile/TEW652BRP,$(1))
+	$(call Image/Build/Profile/TLMR3220V1,$(1))
 	$(call Image/Build/Profile/TLMR3420V1,$(1))
 	$(call Image/Build/Profile/TLWA901NDV1,$(1))
 	$(call Image/Build/Profile/TLWR741NDV1,$(1))
-- 
GitLab