BCM6318: add support for Plusnet / Sagem 2704N (V1) Signed-off-by: Matt Goring <matt.goring@googlemail.com> Signed-off-by: Jonas Gorski <jogo@openwrt.org> SVN-Revision: 46562master
parent
65654a3c54
commit
a105688c87
@ -0,0 +1,84 @@ |
||||
/dts-v1/; |
||||
|
||||
#include "bcm6318.dtsi" |
||||
|
||||
#include <dt-bindings/input/input.h> |
||||
|
||||
/ { |
||||
model = "Sagem F@ST2704N"; |
||||
compatible = "sagem,f@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@ST2704N:green:wps"; |
||||
gpios = <&gpio0 2 1>; |
||||
}; |
||||
lan1_green { |
||||
label = "F@ST2704N:green:lan1"; |
||||
gpios = <&gpio0 4 1>; |
||||
}; |
||||
lan2_green { |
||||
label = "F@ST2704N:green:lan2"; |
||||
gpios = <&gpio0 5 1>; |
||||
}; |
||||
lan3_green { |
||||
label = "F@ST2704N:green:lan3"; |
||||
gpios = <&gpio0 6 1>; |
||||
}; |
||||
lan4_green { |
||||
label = "F@ST2704N:green:lan4"; |
||||
gpios = <&gpio0 7 1>; |
||||
}; |
||||
inet_green { |
||||
label = "F@ST2704N:green:inet"; |
||||
gpios = <&gpio0 8 1>; |
||||
}; |
||||
inet_red { |
||||
label = "F@ST2704N:red:inet"; |
||||
gpios = <&gpio0 9 1>; |
||||
}; |
||||
dsl_green { |
||||
label = "F@ST2704N:green:dsl"; |
||||
gpios = <&gpio0 10 1>; |
||||
}; |
||||
power_red { |
||||
label = "F@ST2704N:red:power"; |
||||
gpios = <&gpio0 11 1>; |
||||
}; |
||||
power_green { |
||||
label = "F@ST2704N:green:power"; |
||||
gpios = <&gpio1 15 1>; |
||||
default-state = "on"; |
||||
}; |
||||
usb_green { |
||||
label = "F@ST2704N:green:usb"; |
||||
gpios = <&gpio1 17 1>; |
||||
}; |
||||
}; |
||||
}; |
@ -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@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@st2704n", .data = &board_FAST2704N, },
|
||||
#endif
|
||||
#ifdef CONFIG_BCM63XX_CPU_6328
|
||||
{ .compatible = "adb,a4001n", .data = &board_A4001N, },
|
@ -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@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@st2704n", .data = &board_FAST2704N, },
|
||||
#endif
|
||||
#ifdef CONFIG_BCM63XX_CPU_6328
|
||||
{ .compatible = "adb,a4001n", .data = &board_A4001N, },
|
Loading…
Reference in new issue