[OpenWrt-Devel] [PATCH] [brcm63xx] Add support for Plusnet 2704N

Matt Goring matt.goring at googlemail.com
Tue Jul 28 00:28:13 EDT 2015


BCM6318: add support for Plusnet / Sagem 2704N (V1)
Signed-off-by: Matt Goring <matt.goring at googlemail.com>
---
 target/linux/brcm63xx/base-files/etc/diag.sh       |    3 +
 .../brcm63xx/base-files/etc/uci-defaults/01_leds   |    3 +
 .../base-files/etc/uci-defaults/02_network         |    1 +
 target/linux/brcm63xx/base-files/lib/brcm63xx.sh   |    3 +
 target/linux/brcm63xx/dts/fast2704n.dts            |   84 ++++++++++++++++++++
 target/linux/brcm63xx/image/Makefile               |    2 +
 .../patches-3.18/571-board_fast2704n.patch         |   65 +++++++++++++++
 .../brcm63xx/patches-4.1/571-board_fast2704n.patch |   65 +++++++++++++++
 target/linux/brcm63xx/profiles/sagem.mk            |   10 +++
 9 files changed, 236 insertions(+)
 create mode 100644 target/linux/brcm63xx/dts/fast2704n.dts
 create mode 100644 target/linux/brcm63xx/patches-3.18/571-board_fast2704n.patch
 create mode 100644 target/linux/brcm63xx/patches-4.1/571-board_fast2704n.patch

diff --git a/target/linux/brcm63xx/base-files/etc/diag.sh b/target/linux/brcm63xx/base-files/etc/diag.sh
index 1b0d26d..7916ac2 100644
--- a/target/linux/brcm63xx/base-files/etc/diag.sh
+++ b/target/linux/brcm63xx/base-files/etc/diag.sh
@@ -70,6 +70,9 @@ set_state() {
 	fast2504n)
 		status_led="fast2504n:green:ok"
 		;;
+	fast2704n)
+		status_led2="F at ST2704N:red:power"
+		;;
 	fast2704v2)
 		status_led="F at ST2704V2:green:power"
 		;;
diff --git a/target/linux/brcm63xx/base-files/etc/uci-defaults/01_leds b/target/linux/brcm63xx/base-files/etc/uci-defaults/01_leds
index b964bdb..bdb3dad 100644
--- a/target/linux/brcm63xx/base-files/etc/uci-defaults/01_leds
+++ b/target/linux/brcm63xx/base-files/etc/uci-defaults/01_leds
@@ -22,6 +22,9 @@ dgnd3700v1_dgnd3800b)
 	ucidef_set_led_usbdev "usb1" "USB1" "DGND3700v1_3800B:green:usb-back" "1-1"
 	ucidef_set_led_usbdev "usb2" "USB2" "DGND3700v1_3800B:green:usb-front" "1-2"
 	;;
+fast2704n)
+	ucidef_set_led_netdev "wan" "WAN" "F at ST2704N:green:inet" "eth0.2"
+	;;
 fast2704v2)
 	ucidef_set_led_usbdev "usb" "USB" "F at ST2704V2:green:usb" "1-1"
 	;;
diff --git a/target/linux/brcm63xx/base-files/etc/uci-defaults/02_network b/target/linux/brcm63xx/base-files/etc/uci-defaults/02_network
index e5880eb..2ff9e45 100644
--- a/target/linux/brcm63xx/base-files/etc/uci-defaults/02_network
+++ b/target/linux/brcm63xx/base-files/etc/uci-defaults/02_network
@@ -114,6 +114,7 @@ wap-5831n)
 	ucidef_add_switch_vlan "eth0" "2" "4 5t"
 	;;
 
+fast2704n |\
 dgnd3700v1_dgnd3800b)
 	ucidef_set_interfaces_lan_wan "eth0.1" "eth0.2"
 	ucidef_add_switch "eth0" "1" "1"
diff --git a/target/linux/brcm63xx/base-files/lib/brcm63xx.sh b/target/linux/brcm63xx/base-files/lib/brcm63xx.sh
index 0eb9a75..92fa5f2 100755
--- a/target/linux/brcm63xx/base-files/lib/brcm63xx.sh
+++ b/target/linux/brcm63xx/base-files/lib/brcm63xx.sh
@@ -198,6 +198,9 @@ brcm63xx_dt_detect() {
 	"Sagem F at ST2604")
 		board_name="fast2604"
 		;;
+	"Sagem F at ST2704N")
+		board_name="fast2704n"
+		;;
 	"Sagem F at ST2704V2")
 		board_name="fast2704v2"
 		;;
diff --git a/target/linux/brcm63xx/dts/fast2704n.dts b/target/linux/brcm63xx/dts/fast2704n.dts
new file mode 100644
index 0000000..232d4d1
--- /dev/null
+++ b/target/linux/brcm63xx/dts/fast2704n.dts
@@ -0,0 +1,84 @@
+/dts-v1/;
+
+#include "bcm6318.dtsi"
+
+#include <dt-bindings/input/input.h>
+
+/ {
+	model = "Sagem F at ST2704N";
+	compatible = "sagem,f at st2704n", "brcm,bcm6318";
+
+	gpio-keys-polled {
+		compatible = "gpio-keys-polled";
+		#address-cells = <1>;
+		#size-cells = <0>;
+		poll-interval = <20>;
+		debounce-interval = <60>;
+
+		wlan {
+			label = "wlan";
+			gpios = <&gpio0 1 0>;
+			linux,code = <KEY_WLAN>;
+		};
+		wps {
+			label = "wps";
+			gpios = <&gpio1 1 1>;
+			linux,code = <KEY_WPS_BUTTON>;
+		};
+		reset {
+			label = "reset";
+			gpios = <&gpio1 2 1>;
+			linux,code = <KEY_RESTART>;
+		};
+	};
+
+	gpio-leds {
+		compatible = "gpio-leds";
+
+		wps_green {
+			label = "F at ST2704N:green:wps";
+			gpios = <&gpio0 2 1>;
+		};
+		lan1_green {
+			label = "F at ST2704N:green:lan1";
+			gpios = <&gpio0 4 1>;
+		};
+		lan2_green {
+			label = "F at ST2704N:green:lan2";
+			gpios = <&gpio0 5 1>;
+		};
+		lan3_green {
+			label = "F at ST2704N:green:lan3";
+			gpios = <&gpio0 6 1>;
+		};
+		lan4_green {
+			label = "F at ST2704N:green:lan4";
+			gpios = <&gpio0 7 1>;
+		};
+		inet_green {
+			label = "F at ST2704N:green:inet";
+			gpios = <&gpio0 8 1>;
+		};
+		inet_red {
+			label = "F at ST2704N:red:inet";
+			gpios = <&gpio0 9 1>;
+		};
+		dsl_green {
+			label = "F at ST2704N:green:dsl";
+			gpios = <&gpio0 10 1>;
+		};
+		power_red {
+			label = "F at ST2704N:red:power";
+			gpios = <&gpio0 11 1>;
+		};
+		power_green {
+			label = "F at ST2704N:green:power";
+			gpios = <&gpio1 15 1>;
+			default-state = "on";
+		};
+		usb_green {
+			label = "F at ST2704N:green:usb";
+			gpios = <&gpio1 17 1>;
+		};
+	};
+};
diff --git a/target/linux/brcm63xx/image/Makefile b/target/linux/brcm63xx/image/Makefile
index 9efec87..e27adc7 100755
--- a/target/linux/brcm63xx/image/Makefile
+++ b/target/linux/brcm63xx/image/Makefile
@@ -623,6 +623,8 @@ $(eval $(call bcm63xxCfe,FAST2404,F at ST2404,fast2404,F at ST2404,6348))
 $(eval $(call bcm63xxCfe,FAST2504n,F at ST2504n,fast2504n,F at ST2504n,6362))
 # Sagem F at ST2604
 $(eval $(call bcm63xxCfe,FAST2604,F at ST2604,fast2604,F at ST2604,6348))
+# Sagem F at ST2704N V1 / Plusnet F at ST2704N V1
+$(eval $(call bcm63xxCfe,FAST2704N,FAST2704N,fast2704n,F at ST2704N,6318,--pad 4))
 # Sagem F at ST2704V2
 $(eval $(call bcm63xxCfe,FAST2704V2,F at ST2704V2,fast2704v2,F at ST2704V2,6328))
 # SFR Neufbox 4
diff --git a/target/linux/brcm63xx/patches-3.18/571-board_fast2704n.patch b/target/linux/brcm63xx/patches-3.18/571-board_fast2704n.patch
new file mode 100644
index 0000000..7b8b727
--- /dev/null
+++ b/target/linux/brcm63xx/patches-3.18/571-board_fast2704n.patch
@@ -0,0 +1,65 @@
+--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
++++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
+@@ -225,6 +225,46 @@ static struct board_info __initdata board_dsl_2751b_d1 = {
+ 		.num_board_fixups		= ARRAY_SIZE(dsl2751b_e1_fixups),
+ 	},
+ };
++
++static struct board_info __initdata board_FAST2704N = {
++	.name				= "F at ST2704N",
++	.expected_cpu_id		= 0x6318,
++
++	.has_uart0			= 1,
++	.has_pci			= 1,
++	.use_fallback_sprom		= 1,
++
++	.has_enetsw			= 1,
++
++	.has_ohci0			= 1,
++	.has_ehci0			= 1,
++	.num_usbh_ports			= 1,
++
++	.enetsw = {
++		.used_ports = {
++			[0] = {
++				.used	= 1,
++				.phy_id = 1,
++				.name	= "Port 1",
++			},
++			[1] = {
++				.used	= 1,
++				.phy_id	= 2,
++				.name	= "Port 2",
++			},
++			[2] = {
++				.used	= 1,
++				.phy_id	= 3,
++				.name	= "Port 3",
++			},
++			[3] = {
++				.used	= 1,
++				.phy_id	= 4,
++				.name	= "Port 4",
++			},
++		},
++	},
++};
+ #endif /* CONFIG_BCM63XX_CPU_6318 */
+ 
+ /*
+@@ -2352,6 +2392,7 @@ static const struct board_info __initconst *bcm963xx_boards[] = {
+ 	&board_96318ref,
+ 	&board_96318ref_p300,
+ 	&board_dsl_2751b_d1,
++	&board_FAST2704N,
+ #endif
+ #ifdef CONFIG_BCM63XX_CPU_6328
+ 	&board_96328avng,
+@@ -2449,6 +2490,7 @@ static struct of_device_id const bcm963xx_boards_dt[] = {
+ 	{ .compatible = "brcm,bcm96318ref", .data = &board_96318ref, },
+ 	{ .compatible = "brcm,bcm96318ref_p300", .data = &board_96318ref_p300, },
+ 	{ .compatible = "d-link,dsl-275xb-d", .data = &board_dsl_2751b_d1, },
++	{ .compatible = "sagem,f at st2704n", .data = &board_FAST2704N, },
+ #endif
+ #ifdef CONFIG_BCM63XX_CPU_6328
+ 	{ .compatible = "adb,a4001n", .data = &board_A4001N, },
diff --git a/target/linux/brcm63xx/patches-4.1/571-board_fast2704n.patch b/target/linux/brcm63xx/patches-4.1/571-board_fast2704n.patch
new file mode 100644
index 0000000..7b8b727
--- /dev/null
+++ b/target/linux/brcm63xx/patches-4.1/571-board_fast2704n.patch
@@ -0,0 +1,65 @@
+--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
++++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
+@@ -225,6 +225,46 @@ static struct board_info __initdata board_dsl_2751b_d1 = {
+ 		.num_board_fixups		= ARRAY_SIZE(dsl2751b_e1_fixups),
+ 	},
+ };
++
++static struct board_info __initdata board_FAST2704N = {
++	.name				= "F at ST2704N",
++	.expected_cpu_id		= 0x6318,
++
++	.has_uart0			= 1,
++	.has_pci			= 1,
++	.use_fallback_sprom		= 1,
++
++	.has_enetsw			= 1,
++
++	.has_ohci0			= 1,
++	.has_ehci0			= 1,
++	.num_usbh_ports			= 1,
++
++	.enetsw = {
++		.used_ports = {
++			[0] = {
++				.used	= 1,
++				.phy_id = 1,
++				.name	= "Port 1",
++			},
++			[1] = {
++				.used	= 1,
++				.phy_id	= 2,
++				.name	= "Port 2",
++			},
++			[2] = {
++				.used	= 1,
++				.phy_id	= 3,
++				.name	= "Port 3",
++			},
++			[3] = {
++				.used	= 1,
++				.phy_id	= 4,
++				.name	= "Port 4",
++			},
++		},
++	},
++};
+ #endif /* CONFIG_BCM63XX_CPU_6318 */
+ 
+ /*
+@@ -2352,6 +2392,7 @@ static const struct board_info __initconst *bcm963xx_boards[] = {
+ 	&board_96318ref,
+ 	&board_96318ref_p300,
+ 	&board_dsl_2751b_d1,
++	&board_FAST2704N,
+ #endif
+ #ifdef CONFIG_BCM63XX_CPU_6328
+ 	&board_96328avng,
+@@ -2449,6 +2490,7 @@ static struct of_device_id const bcm963xx_boards_dt[] = {
+ 	{ .compatible = "brcm,bcm96318ref", .data = &board_96318ref, },
+ 	{ .compatible = "brcm,bcm96318ref_p300", .data = &board_96318ref_p300, },
+ 	{ .compatible = "d-link,dsl-275xb-d", .data = &board_dsl_2751b_d1, },
++	{ .compatible = "sagem,f at st2704n", .data = &board_FAST2704N, },
+ #endif
+ #ifdef CONFIG_BCM63XX_CPU_6328
+ 	{ .compatible = "adb,a4001n", .data = &board_A4001N, },
diff --git a/target/linux/brcm63xx/profiles/sagem.mk b/target/linux/brcm63xx/profiles/sagem.mk
index 5afb2b7..7d9a160 100644
--- a/target/linux/brcm63xx/profiles/sagem.mk
+++ b/target/linux/brcm63xx/profiles/sagem.mk
@@ -32,6 +32,16 @@ define Profile/FAST2604/Description
 endef
 $(eval $(call Profile,FAST2604))
 
+define Profile/FAST2704N
+  NAME:=Sagem F at ST2704N
+  PACKAGES:=kmod-b43 wpad-mini \
+	kmod-usb2 kmod-usb-ohci
+endef
+define Profile/FAST2704N/Description
+  Package set optimized for F at ST2704N.
+endef
+$(eval $(call Profile,FAST2704N))
+
 define Profile/FAST2704V2
   NAME:=Sagem F at ST2704V2
   PACKAGES:=kmod-b43 wpad-mini\
-- 
1.7.9.5
_______________________________________________
openwrt-devel mailing list
openwrt-devel at lists.openwrt.org
https://lists.openwrt.org/cgi-bin/mailman/listinfo/openwrt-devel



More information about the openwrt-devel mailing list