Message ID | 1463957783-9346-1-git-send-email-xotic750@gmail.com |
---|---|
State | Accepted |
Delegated to: | Álvaro Fernández |
Headers | show |
Hello Graham, Pulled into my staging tree with some changes (whitespace fixes, cleanups...): https://git.lede-project.org/?p=lede/noltari/staging.git;a=shortlog;h=refs/heads/brcm63xx-next Regards, Álvaro. El 23/5/16 a las 0:56, Xotic750 escribió: > From: Graham Fairweather <xotic750@gmail.com> > > This patch adds support for the Netgear EVG2000 VoIP Gateway to the > bcm63xx targets. > Ran 'make target/linux/refresh V=s' after update to kernel 4.4.10 from > 4.4.8 where the initial patch was added. > This device was not sold to the general public, but rather is/was > provided by telcos to customers in Sweden, Australia, Singapore and > other parts of asia. > System-On-Chip: Broadcom BCM6369 (2 * BMIPS4350 v3.1 / 400 MHz) > Flash size: 16 MiB > RAM size: 64 MiB > Wireless: BCM4322 802.11b/g/n (onboard) > Ethernet: Broadcom BCM53115 > USB: 2 x USB 2.0 > Known issues: > - Unable to detect 53115 switch. This appear to be a problem with > probing for the PHY using MDIO and results in error 5. Doesn't seem to > be a problem with the configuration, and could use someone with > experience to have a look at it. > - Uses the b43 driver as using the OpenWRT/LEDE broadcom-wl driver > fails to load the firmware for the 4322, so 802.11n is not supported. > The factory build uses a newer broadcom-wl driver. > - No support for the 2 VoIP ports (not attempted) > More info on the device and the research can be found at: > https://wiki.openwrt.org/toh/netgear/evg2000 > https://wikidevi.com/wiki/Netgear_EVG2000 > https://github.com/Xotic750/mirror-lede/tree/evg2000 > https://forum.openwrt.org/viewtopic.php?id=63950 > Signed-off-by: Graham Fairweather <xotic750@gmail.com> > --- > .../linux/brcm63xx/base-files/etc/board.d/01_leds | 7 ++ > .../brcm63xx/base-files/etc/board.d/02_network | 1 + > target/linux/brcm63xx/base-files/etc/diag.sh | 3 + > .../base-files/etc/uci-defaults/09_fix_crc | 2 +- > target/linux/brcm63xx/base-files/lib/brcm63xx.sh | 3 + > .../lib/preinit/05_init_interfaces_brcm63xx | 1 + > target/linux/brcm63xx/dts/evg2000.dts | 103 +++++++++++++++++++++ > target/linux/brcm63xx/image/Makefile | 2 + > .../brcm63xx/patches-4.1/575-board_EVG2000.patch | 62 +++++++++++++ > ...-m25p80-use-parsers-if-provided-in-flash-.patch | 2 +- > ...CES-m25p80-add-support-for-limiting-reads.patch | 4 +- > .../414-MTD-m25p80-allow-passing-pp_data.patch | 2 +- > .../brcm63xx/patches-4.4/575-board_EVG2000.patch | 62 +++++++++++++ > target/linux/brcm63xx/profiles/netgear.mk | 10 ++ > 14 files changed, 259 insertions(+), 5 deletions(-) > create mode 100644 target/linux/brcm63xx/dts/evg2000.dts > create mode 100644 target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch > create mode 100644 target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch > > diff --git a/target/linux/brcm63xx/base-files/etc/board.d/01_leds b/target/linux/brcm63xx/base-files/etc/board.d/01_leds > index 8339254..4163214 100755 > --- a/target/linux/brcm63xx/base-files/etc/board.d/01_leds > +++ b/target/linux/brcm63xx/base-files/etc/board.d/01_leds > @@ -24,6 +24,13 @@ 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" > ;; > +evg2000) > + ucidef_set_led_netdev "lan" "LAN" "EVG2000:green:lan" "eth0" > + ucidef_set_led_netdev "wan" "WAN" "EVG2000:green:wan" "eth1" > + ucidef_set_led_netdev "wlan0" "WIFI" "EVG2000:green:wireless" "wlan0" > + ucidef_set_led_usbdev "usb1" "USB1" "EVG2000:green:voip1" "1-1" > + ucidef_set_led_usbdev "usb2" "USB2" "EVG2000:green:voip2" "1-2" > + ;; > fast2704n) > ucidef_set_led_netdev "wan" "WAN" "F@ST2704N:green:inet" "eth0.2" > ;; > diff --git a/target/linux/brcm63xx/base-files/etc/board.d/02_network b/target/linux/brcm63xx/base-files/etc/board.d/02_network > index f96da08..83367c1 100755 > --- a/target/linux/brcm63xx/base-files/etc/board.d/02_network > +++ b/target/linux/brcm63xx/base-files/etc/board.d/02_network > @@ -11,6 +11,7 @@ board_config_update > case "$(brcm63xx_board_name)" in > > cvg834g |\ > +evg2000 |\ > rta770bw |\ > rta770w |\ > spw303v |\ > diff --git a/target/linux/brcm63xx/base-files/etc/diag.sh b/target/linux/brcm63xx/base-files/etc/diag.sh > index b864964..6ac2459 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() { > dgnd3700v1_dgnd3800b) > status_led="DGND3700v1_3800B:green:power" > ;; > + evg2000) > + status_led="EVG2000:green:power" > + ;; > fast2504n) > status_led="fast2504n:green:ok" > ;; > diff --git a/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc b/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc > index 70dbe2a..1201168 100644 > --- a/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc > +++ b/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc > @@ -21,6 +21,7 @@ case "$(brcm63xx_board_name)" in > cpva642 |\ > ct-6373 |\ > dsl-274xb-f |\ > + evg2000 |\ > hg622 |\ > magic |\ > p870hw-51a_v2 |\ > @@ -37,4 +38,3 @@ case "$(brcm63xx_board_name)" in > do_fixcrc > ;; > esac > - > diff --git a/target/linux/brcm63xx/base-files/lib/brcm63xx.sh b/target/linux/brcm63xx/base-files/lib/brcm63xx.sh > index a2d6519..9cc0b2b 100755 > --- a/target/linux/brcm63xx/base-files/lib/brcm63xx.sh > +++ b/target/linux/brcm63xx/base-files/lib/brcm63xx.sh > @@ -183,6 +183,9 @@ brcm63xx_dt_detect() { > "Netgear DGND3700v1/DGND3800B") > board_name="dgnd3700v1_dgnd3800b" > ;; > + "Netgear EVG2000") > + board_name="evg2000" > + ;; > "NuCom R5010UN v2") > board_name="r5010un_v2" > ;; > diff --git a/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx b/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx > index 7e4dfcb..1e3fc14 100644 > --- a/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx > +++ b/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx > @@ -18,6 +18,7 @@ set_preinit_iface() { > dsl-274xb-c |\ > dsl-274xb-f |\ > dsl-275xb-d |\ > + evg2000 |\ > fast2504n |\ > fast2704v2 |\ > hg553 |\ > diff --git a/target/linux/brcm63xx/dts/evg2000.dts b/target/linux/brcm63xx/dts/evg2000.dts > new file mode 100644 > index 0000000..04f7b84 > --- /dev/null > +++ b/target/linux/brcm63xx/dts/evg2000.dts > @@ -0,0 +1,103 @@ > +/dts-v1/; > + > +#include "bcm6368.dtsi" > + > +#include <dt-bindings/input/input.h> > + > +/ { > + model = "Netgear EVG2000"; > + compatible = "netgear,evg2000", "brcm,bcm6368"; > + > + gpio-keys-polled { > + compatible = "gpio-keys-polled"; > + #address-cells = <1>; > + #size-cells = <0>; > + poll-interval = <20>; > + debounce-interval = <60>; > + > + reset { > + label = "reset"; > + gpios = <&gpio0 25 1>; > + linux,code = <KEY_RESTART>; > + }; > + wps { > + label = "wps"; > + gpios = <&gpio0 26 1>; > + linux,code = <KEY_WPS_BUTTON>; > + }; > + }; > + > + gpio-leds { > + compatible = "gpio-leds"; > + > + voip1_green { > + label = "EVG2000:green:voip1"; > + gpios = <&gpio0 14 1>; > + }; > + voip2_green { > + label = "EVG2000:green:voip2"; > + gpios = <&gpio0 2 1>; > + }; > + inet_red { > + label = "EVG2000:red:inet"; > + gpios = <&gpio0 4 1>; > + }; > + inet_green { > + label = "EVG2000:green:inet"; > + gpios = <&gpio0 5 1>; > + }; > + usb_green { > + label = "EVG2000:green:usb"; > + gpios = <&gpio0 15 1>; > + }; > + power_green { > + label = "EVG2000:green:power"; > + gpios = <&gpio0 22 1>; > + default-state = "on"; > + }; > + power_red { > + label = "EVG2000:red:power"; > + gpios = <&gpio0 23 1>; > + }; > + lan_green { > + label = "EVG2000:green:lan"; > + gpios = <&gpio0 24 1>; > + }; > + wireless_green { > + label = "EVG2000:green:wireless"; > + gpios = <&gpio0 26 1>; > + }; > + wan_green { > + label = "EVG2000:green:wan"; > + gpios = <&gpio0 27 1>; > + }; > + }; > +}; > + > +&pflash { > + status = "ok"; > + > + linux,part-probe = "bcm63xxpart"; > + > + cfe@0 { > + label = "CFE"; > + reg = <0x00000000 0x00020000>; > + read-only; > + }; > + > + linux@20000 { > + label = "linux"; > + reg = <0x00020000 0x00f40000>; > + }; > + > + board_data@f60000 { > + label = "board_data"; > + reg = <0x00f60000 0x00080000>; > + read-only; > + }; > + > + nvram@fe0000 { > + label = "nvram"; > + reg = <0x00fe0000 0x00020000>; > + }; > +}; > diff --git a/target/linux/brcm63xx/image/Makefile b/target/linux/brcm63xx/image/Makefile > index e00b6fb..f1fb86b 100644 > --- a/target/linux/brcm63xx/image/Makefile > +++ b/target/linux/brcm63xx/image/Makefile > @@ -593,6 +593,8 @@ $(eval $(call bcm63xxCfeRamdisk,DG834GV4,DG834GTv4,dg834g_v4,96348W3,6348)) > $(eval $(call bcm63xxCfeNetgear,DGND3700v1_3800B,DGND3700v1,dgnd3700v1,96368MVWG,6368,--image-offset 0x20000 --block-size 0x20000,U12L144T01_NETGEAR_NEWLED,1)) > # Netgear DGND3800B > $(eval $(call bcm63xxCfeNetgear,DGND3700v1_3800B,DGND3800B,dgnd3700v1,96368MVWG,6368,--image-offset 0x20000 --block-size 0x20000,U12L144T11_NETGEAR_NEWLED,1)) > +# Netgear EVG2000 > +$(eval $(call bcm63xxCfeNetgear,EVG2000,EVG2000,evg2000,96369PVG,6369,--image-offset 0x20000 --block-size 0x20000,U12H154T90_NETGEAR,1)) > # NuCom R5010UNv2 > $(eval $(call bcm63xxCfe,R5010UNV2,R5010UNv2,r5010unv2,96328ang,6328,--pad 8)) > # Pirelli Alice Gate VoIP 2 Plus Wi-Fi AGPF-S0 > diff --git a/target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch b/target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch > new file mode 100644 > index 0000000..9339085 > --- /dev/null > +++ b/target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch > @@ -0,0 +1,62 @@ > +--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c > ++++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c > +@@ -2010,6 +2010,43 @@ static struct board_info __initdata boar > + .num_spis = ARRAY_SIZE(DGND3700v1_3800B_spi_devices), > + }; > + > ++static struct sprom_fixup __initdata EVG2000_fixups[] = { > ++ { .offset = 219, .value = 0xec08 }, > ++}; > ++ > ++static struct board_info __initdata board_EVG2000 = { > ++ .name = "96369PVG", > ++ .expected_cpu_id = 0x6368, > ++ > ++ .has_uart0 = 1, > ++ .has_pci = 1, > ++ .has_ohci0 = 1, > ++ .has_ehci0 = 1, > ++ .num_usbh_ports = 2, > ++ > ++ .has_enetsw = 1, > ++ .enetsw = { > ++ .used_ports = { > ++ [5] = { > ++ .used = 1, > ++ .phy_id = 0xff, > ++ .bypass_link = 1, > ++ .force_speed = 1000, > ++ .force_duplex_full = 1, > ++ .name = "RGMII", > ++ }, > ++ }, > ++ }, > ++ .use_fallback_sprom = 1, > ++ .fallback_sprom = { > ++ .type = SPROM_BCM4322, > ++ .pci_bus = 0, > ++ .pci_dev = 1, > ++ .board_fixups = EVG2000_fixups, > ++ .num_board_fixups = ARRAY_SIZE(EVG2000_fixups), > ++ }, > ++}; > ++ > + static struct board_info __initdata board_HG655b = { > + .name = "HW65x", > + .expected_cpu_id = 0x6368, > +@@ -2610,6 +2647,7 @@ static const struct board_info __initcon > + &board_96368mvwg, > + &board_96368mvngr, > + &board_DGND3700v1_3800B, > ++ &board_EVG2000, > + &board_HG622, > + &board_HG655b, > + &board_P870HW51A_V2, > +@@ -2722,6 +2760,7 @@ static struct of_device_id const bcm963x > + { .compatible = "huawei,hg622", .data = &board_HG622, }, > + { .compatible = "huawei,hg655b", .data = &board_HG655b, }, > + { .compatible = "netgear,dgnd3700v1", .data = &board_DGND3700v1_3800B, }, > ++ { .compatible = "netgear,evg2000", .data = &board_EVG2000, }, > + { .compatible = "zyxel,p870hw-51a-v2", .data = &board_P870HW51A_V2, }, > + #endif > + #ifdef CONFIG_BCM63XX_CPU_63268 > diff --git a/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch b/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch > index be62e67..4793836 100644 > --- a/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch > +++ b/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch > @@ -11,7 +11,7 @@ Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> > > --- a/drivers/mtd/devices/m25p80.c > +++ b/drivers/mtd/devices/m25p80.c > -@@ -229,7 +229,8 @@ static int m25p_probe(struct spi_device > +@@ -251,7 +251,8 @@ static int m25p_probe(struct spi_device > > ppdata.of_node = spi->dev.of_node; > > diff --git a/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch b/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch > index 3877442..75a874d 100644 > --- a/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch > +++ b/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch > @@ -28,7 +28,7 @@ Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> > size_t *retlen, u_char *buf) > { > struct m25p *flash = nor->priv; > -@@ -152,6 +153,29 @@ static int m25p80_read(struct spi_nor *n > +@@ -174,6 +175,29 @@ static int m25p80_read(struct spi_nor *n > return 0; > } > > @@ -58,7 +58,7 @@ Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> > static int m25p80_erase(struct spi_nor *nor, loff_t offset) > { > struct m25p *flash = nor->priv; > -@@ -223,6 +247,9 @@ static int m25p_probe(struct spi_device > +@@ -245,6 +269,9 @@ static int m25p_probe(struct spi_device > else > flash_name = spi->modalias; > > diff --git a/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch b/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch > index e421e9a..bbb565e 100644 > --- a/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch > +++ b/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch > @@ -10,7 +10,7 @@ Subject: [PATCH 64/79] MTD: m25p80: allow passing pp_data > > --- a/drivers/mtd/devices/m25p80.c > +++ b/drivers/mtd/devices/m25p80.c > -@@ -250,6 +250,9 @@ static int m25p_probe(struct spi_device > +@@ -272,6 +272,9 @@ static int m25p_probe(struct spi_device > if (data) > flash->max_transfer_len = data->max_transfer_len; > > diff --git a/target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch b/target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch > new file mode 100644 > index 0000000..fc7afc7 > --- /dev/null > +++ b/target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch > @@ -0,0 +1,62 @@ > +--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c > ++++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c > +@@ -2011,6 +2011,43 @@ static struct board_info __initdata boar > + .num_spis = ARRAY_SIZE(DGND3700v1_3800B_spi_devices), > + }; > + > ++static struct sprom_fixup __initdata EVG2000_fixups[] = { > ++ { .offset = 219, .value = 0xec08 }, > ++}; > ++ > ++static struct board_info __initdata board_EVG2000 = { > ++ .name = "96369PVG", > ++ .expected_cpu_id = 0x6368, > ++ > ++ .has_uart0 = 1, > ++ .has_pci = 1, > ++ .has_ohci0 = 1, > ++ .has_ehci0 = 1, > ++ .num_usbh_ports = 2, > ++ > ++ .has_enetsw = 1, > ++ .enetsw = { > ++ .used_ports = { > ++ [5] = { > ++ .used = 1, > ++ .phy_id = 0xff, > ++ .bypass_link = 1, > ++ .force_speed = 1000, > ++ .force_duplex_full = 1, > ++ .name = "RGMII", > ++ }, > ++ }, > ++ }, > ++ .use_fallback_sprom = 1, > ++ .fallback_sprom = { > ++ .type = SPROM_BCM4322, > ++ .pci_bus = 0, > ++ .pci_dev = 1, > ++ .board_fixups = EVG2000_fixups, > ++ .num_board_fixups = ARRAY_SIZE(EVG2000_fixups), > ++ }, > ++}; > ++ > + static struct board_info __initdata board_HG655b = { > + .name = "HW65x", > + .expected_cpu_id = 0x6368, > +@@ -2611,6 +2648,7 @@ static const struct board_info __initcon > + &board_96368mvwg, > + &board_96368mvngr, > + &board_DGND3700v1_3800B, > ++ &board_EVG2000, > + &board_HG622, > + &board_HG655b, > + &board_P870HW51A_V2, > +@@ -2723,6 +2761,7 @@ static struct of_device_id const bcm963x > + { .compatible = "huawei,hg622", .data = &board_HG622, }, > + { .compatible = "huawei,hg655b", .data = &board_HG655b, }, > + { .compatible = "netgear,dgnd3700v1", .data = &board_DGND3700v1_3800B, }, > ++ { .compatible = "netgear,evg2000", .data = &board_EVG2000, }, > + { .compatible = "zyxel,p870hw-51a-v2", .data = &board_P870HW51A_V2, }, > + #endif > + #ifdef CONFIG_BCM63XX_CPU_63268 > diff --git a/target/linux/brcm63xx/profiles/netgear.mk b/target/linux/brcm63xx/profiles/netgear.mk > index bc345bb..e3bc34a 100644 > --- a/target/linux/brcm63xx/profiles/netgear.mk > +++ b/target/linux/brcm63xx/profiles/netgear.mk > @@ -41,3 +41,13 @@ define Profile/DGND3700v1_3800B/Description > Package set optimized for DGND3700 v1 / DGND3800B. > endef > $(eval $(call Profile,DGND3700v1_3800B)) > + > +define Profile/EVG2000 > + NAME:=Netgear EVG2000 > + PACKAGES:=kmod-b43 wpad-mini \ > + kmod-usb2 kmod-usb-ohci kmod-ledtrig-usbdev > +endef > +define Profile/EVG2000/Description > + Package set optimized for EVG2000. > +endef > +$(eval $(call Profile,EVG2000))
Hi and thanks. On 3 June 2016 at 12:07, Álvaro Fernández Rojas <noltari@gmail.com> wrote: > Hello Graham, > > Pulled into my staging tree with some changes (whitespace fixes, cleanups...): > https://git.lede-project.org/?p=lede/noltari/staging.git;a=shortlog;h=refs/heads/brcm63xx-next > > Regards, > Álvaro. > > El 23/5/16 a las 0:56, Xotic750 escribió: >> From: Graham Fairweather <xotic750@gmail.com> >> >> This patch adds support for the Netgear EVG2000 VoIP Gateway to the >> bcm63xx targets. >> Ran 'make target/linux/refresh V=s' after update to kernel 4.4.10 from >> 4.4.8 where the initial patch was added. >> This device was not sold to the general public, but rather is/was >> provided by telcos to customers in Sweden, Australia, Singapore and >> other parts of asia. >> System-On-Chip: Broadcom BCM6369 (2 * BMIPS4350 v3.1 / 400 MHz) >> Flash size: 16 MiB >> RAM size: 64 MiB >> Wireless: BCM4322 802.11b/g/n (onboard) >> Ethernet: Broadcom BCM53115 >> USB: 2 x USB 2.0 >> Known issues: >> - Unable to detect 53115 switch. This appear to be a problem with >> probing for the PHY using MDIO and results in error 5. Doesn't seem to >> be a problem with the configuration, and could use someone with >> experience to have a look at it. >> - Uses the b43 driver as using the OpenWRT/LEDE broadcom-wl driver >> fails to load the firmware for the 4322, so 802.11n is not supported. >> The factory build uses a newer broadcom-wl driver. >> - No support for the 2 VoIP ports (not attempted) >> More info on the device and the research can be found at: >> https://wiki.openwrt.org/toh/netgear/evg2000 >> https://wikidevi.com/wiki/Netgear_EVG2000 >> https://github.com/Xotic750/mirror-lede/tree/evg2000 >> https://forum.openwrt.org/viewtopic.php?id=63950 >> Signed-off-by: Graham Fairweather <xotic750@gmail.com> >> --- >> .../linux/brcm63xx/base-files/etc/board.d/01_leds | 7 ++ >> .../brcm63xx/base-files/etc/board.d/02_network | 1 + >> target/linux/brcm63xx/base-files/etc/diag.sh | 3 + >> .../base-files/etc/uci-defaults/09_fix_crc | 2 +- >> target/linux/brcm63xx/base-files/lib/brcm63xx.sh | 3 + >> .../lib/preinit/05_init_interfaces_brcm63xx | 1 + >> target/linux/brcm63xx/dts/evg2000.dts | 103 +++++++++++++++++++++ >> target/linux/brcm63xx/image/Makefile | 2 + >> .../brcm63xx/patches-4.1/575-board_EVG2000.patch | 62 +++++++++++++ >> ...-m25p80-use-parsers-if-provided-in-flash-.patch | 2 +- >> ...CES-m25p80-add-support-for-limiting-reads.patch | 4 +- >> .../414-MTD-m25p80-allow-passing-pp_data.patch | 2 +- >> .../brcm63xx/patches-4.4/575-board_EVG2000.patch | 62 +++++++++++++ >> target/linux/brcm63xx/profiles/netgear.mk | 10 ++ >> 14 files changed, 259 insertions(+), 5 deletions(-) >> create mode 100644 target/linux/brcm63xx/dts/evg2000.dts >> create mode 100644 target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch >> create mode 100644 target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch >> >> diff --git a/target/linux/brcm63xx/base-files/etc/board.d/01_leds b/target/linux/brcm63xx/base-files/etc/board.d/01_leds >> index 8339254..4163214 100755 >> --- a/target/linux/brcm63xx/base-files/etc/board.d/01_leds >> +++ b/target/linux/brcm63xx/base-files/etc/board.d/01_leds >> @@ -24,6 +24,13 @@ 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" >> ;; >> +evg2000) >> + ucidef_set_led_netdev "lan" "LAN" "EVG2000:green:lan" "eth0" >> + ucidef_set_led_netdev "wan" "WAN" "EVG2000:green:wan" "eth1" >> + ucidef_set_led_netdev "wlan0" "WIFI" "EVG2000:green:wireless" "wlan0" >> + ucidef_set_led_usbdev "usb1" "USB1" "EVG2000:green:voip1" "1-1" >> + ucidef_set_led_usbdev "usb2" "USB2" "EVG2000:green:voip2" "1-2" >> + ;; >> fast2704n) >> ucidef_set_led_netdev "wan" "WAN" "F@ST2704N:green:inet" "eth0.2" >> ;; >> diff --git a/target/linux/brcm63xx/base-files/etc/board.d/02_network b/target/linux/brcm63xx/base-files/etc/board.d/02_network >> index f96da08..83367c1 100755 >> --- a/target/linux/brcm63xx/base-files/etc/board.d/02_network >> +++ b/target/linux/brcm63xx/base-files/etc/board.d/02_network >> @@ -11,6 +11,7 @@ board_config_update >> case "$(brcm63xx_board_name)" in >> >> cvg834g |\ >> +evg2000 |\ >> rta770bw |\ >> rta770w |\ >> spw303v |\ >> diff --git a/target/linux/brcm63xx/base-files/etc/diag.sh b/target/linux/brcm63xx/base-files/etc/diag.sh >> index b864964..6ac2459 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() { >> dgnd3700v1_dgnd3800b) >> status_led="DGND3700v1_3800B:green:power" >> ;; >> + evg2000) >> + status_led="EVG2000:green:power" >> + ;; >> fast2504n) >> status_led="fast2504n:green:ok" >> ;; >> diff --git a/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc b/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc >> index 70dbe2a..1201168 100644 >> --- a/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc >> +++ b/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc >> @@ -21,6 +21,7 @@ case "$(brcm63xx_board_name)" in >> cpva642 |\ >> ct-6373 |\ >> dsl-274xb-f |\ >> + evg2000 |\ >> hg622 |\ >> magic |\ >> p870hw-51a_v2 |\ >> @@ -37,4 +38,3 @@ case "$(brcm63xx_board_name)" in >> do_fixcrc >> ;; >> esac >> - >> diff --git a/target/linux/brcm63xx/base-files/lib/brcm63xx.sh b/target/linux/brcm63xx/base-files/lib/brcm63xx.sh >> index a2d6519..9cc0b2b 100755 >> --- a/target/linux/brcm63xx/base-files/lib/brcm63xx.sh >> +++ b/target/linux/brcm63xx/base-files/lib/brcm63xx.sh >> @@ -183,6 +183,9 @@ brcm63xx_dt_detect() { >> "Netgear DGND3700v1/DGND3800B") >> board_name="dgnd3700v1_dgnd3800b" >> ;; >> + "Netgear EVG2000") >> + board_name="evg2000" >> + ;; >> "NuCom R5010UN v2") >> board_name="r5010un_v2" >> ;; >> diff --git a/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx b/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx >> index 7e4dfcb..1e3fc14 100644 >> --- a/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx >> +++ b/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx >> @@ -18,6 +18,7 @@ set_preinit_iface() { >> dsl-274xb-c |\ >> dsl-274xb-f |\ >> dsl-275xb-d |\ >> + evg2000 |\ >> fast2504n |\ >> fast2704v2 |\ >> hg553 |\ >> diff --git a/target/linux/brcm63xx/dts/evg2000.dts b/target/linux/brcm63xx/dts/evg2000.dts >> new file mode 100644 >> index 0000000..04f7b84 >> --- /dev/null >> +++ b/target/linux/brcm63xx/dts/evg2000.dts >> @@ -0,0 +1,103 @@ >> +/dts-v1/; >> + >> +#include "bcm6368.dtsi" >> + >> +#include <dt-bindings/input/input.h> >> + >> +/ { >> + model = "Netgear EVG2000"; >> + compatible = "netgear,evg2000", "brcm,bcm6368"; >> + >> + gpio-keys-polled { >> + compatible = "gpio-keys-polled"; >> + #address-cells = <1>; >> + #size-cells = <0>; >> + poll-interval = <20>; >> + debounce-interval = <60>; >> + >> + reset { >> + label = "reset"; >> + gpios = <&gpio0 25 1>; >> + linux,code = <KEY_RESTART>; >> + }; >> + wps { >> + label = "wps"; >> + gpios = <&gpio0 26 1>; >> + linux,code = <KEY_WPS_BUTTON>; >> + }; >> + }; >> + >> + gpio-leds { >> + compatible = "gpio-leds"; >> + >> + voip1_green { >> + label = "EVG2000:green:voip1"; >> + gpios = <&gpio0 14 1>; >> + }; >> + voip2_green { >> + label = "EVG2000:green:voip2"; >> + gpios = <&gpio0 2 1>; >> + }; >> + inet_red { >> + label = "EVG2000:red:inet"; >> + gpios = <&gpio0 4 1>; >> + }; >> + inet_green { >> + label = "EVG2000:green:inet"; >> + gpios = <&gpio0 5 1>; >> + }; >> + usb_green { >> + label = "EVG2000:green:usb"; >> + gpios = <&gpio0 15 1>; >> + }; >> + power_green { >> + label = "EVG2000:green:power"; >> + gpios = <&gpio0 22 1>; >> + default-state = "on"; >> + }; >> + power_red { >> + label = "EVG2000:red:power"; >> + gpios = <&gpio0 23 1>; >> + }; >> + lan_green { >> + label = "EVG2000:green:lan"; >> + gpios = <&gpio0 24 1>; >> + }; >> + wireless_green { >> + label = "EVG2000:green:wireless"; >> + gpios = <&gpio0 26 1>; >> + }; >> + wan_green { >> + label = "EVG2000:green:wan"; >> + gpios = <&gpio0 27 1>; >> + }; >> + }; >> +}; >> + >> +&pflash { >> + status = "ok"; >> + >> + linux,part-probe = "bcm63xxpart"; >> + >> + cfe@0 { >> + label = "CFE"; >> + reg = <0x00000000 0x00020000>; >> + read-only; >> + }; >> + >> + linux@20000 { >> + label = "linux"; >> + reg = <0x00020000 0x00f40000>; >> + }; >> + >> + board_data@f60000 { >> + label = "board_data"; >> + reg = <0x00f60000 0x00080000>; >> + read-only; >> + }; >> + >> + nvram@fe0000 { >> + label = "nvram"; >> + reg = <0x00fe0000 0x00020000>; >> + }; >> +}; >> diff --git a/target/linux/brcm63xx/image/Makefile b/target/linux/brcm63xx/image/Makefile >> index e00b6fb..f1fb86b 100644 >> --- a/target/linux/brcm63xx/image/Makefile >> +++ b/target/linux/brcm63xx/image/Makefile >> @@ -593,6 +593,8 @@ $(eval $(call bcm63xxCfeRamdisk,DG834GV4,DG834GTv4,dg834g_v4,96348W3,6348)) >> $(eval $(call bcm63xxCfeNetgear,DGND3700v1_3800B,DGND3700v1,dgnd3700v1,96368MVWG,6368,--image-offset 0x20000 --block-size 0x20000,U12L144T01_NETGEAR_NEWLED,1)) >> # Netgear DGND3800B >> $(eval $(call bcm63xxCfeNetgear,DGND3700v1_3800B,DGND3800B,dgnd3700v1,96368MVWG,6368,--image-offset 0x20000 --block-size 0x20000,U12L144T11_NETGEAR_NEWLED,1)) >> +# Netgear EVG2000 >> +$(eval $(call bcm63xxCfeNetgear,EVG2000,EVG2000,evg2000,96369PVG,6369,--image-offset 0x20000 --block-size 0x20000,U12H154T90_NETGEAR,1)) >> # NuCom R5010UNv2 >> $(eval $(call bcm63xxCfe,R5010UNV2,R5010UNv2,r5010unv2,96328ang,6328,--pad 8)) >> # Pirelli Alice Gate VoIP 2 Plus Wi-Fi AGPF-S0 >> diff --git a/target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch b/target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch >> new file mode 100644 >> index 0000000..9339085 >> --- /dev/null >> +++ b/target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch >> @@ -0,0 +1,62 @@ >> +--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c >> ++++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c >> +@@ -2010,6 +2010,43 @@ static struct board_info __initdata boar >> + .num_spis = ARRAY_SIZE(DGND3700v1_3800B_spi_devices), >> + }; >> + >> ++static struct sprom_fixup __initdata EVG2000_fixups[] = { >> ++ { .offset = 219, .value = 0xec08 }, >> ++}; >> ++ >> ++static struct board_info __initdata board_EVG2000 = { >> ++ .name = "96369PVG", >> ++ .expected_cpu_id = 0x6368, >> ++ >> ++ .has_uart0 = 1, >> ++ .has_pci = 1, >> ++ .has_ohci0 = 1, >> ++ .has_ehci0 = 1, >> ++ .num_usbh_ports = 2, >> ++ >> ++ .has_enetsw = 1, >> ++ .enetsw = { >> ++ .used_ports = { >> ++ [5] = { >> ++ .used = 1, >> ++ .phy_id = 0xff, >> ++ .bypass_link = 1, >> ++ .force_speed = 1000, >> ++ .force_duplex_full = 1, >> ++ .name = "RGMII", >> ++ }, >> ++ }, >> ++ }, >> ++ .use_fallback_sprom = 1, >> ++ .fallback_sprom = { >> ++ .type = SPROM_BCM4322, >> ++ .pci_bus = 0, >> ++ .pci_dev = 1, >> ++ .board_fixups = EVG2000_fixups, >> ++ .num_board_fixups = ARRAY_SIZE(EVG2000_fixups), >> ++ }, >> ++}; >> ++ >> + static struct board_info __initdata board_HG655b = { >> + .name = "HW65x", >> + .expected_cpu_id = 0x6368, >> +@@ -2610,6 +2647,7 @@ static const struct board_info __initcon >> + &board_96368mvwg, >> + &board_96368mvngr, >> + &board_DGND3700v1_3800B, >> ++ &board_EVG2000, >> + &board_HG622, >> + &board_HG655b, >> + &board_P870HW51A_V2, >> +@@ -2722,6 +2760,7 @@ static struct of_device_id const bcm963x >> + { .compatible = "huawei,hg622", .data = &board_HG622, }, >> + { .compatible = "huawei,hg655b", .data = &board_HG655b, }, >> + { .compatible = "netgear,dgnd3700v1", .data = &board_DGND3700v1_3800B, }, >> ++ { .compatible = "netgear,evg2000", .data = &board_EVG2000, }, >> + { .compatible = "zyxel,p870hw-51a-v2", .data = &board_P870HW51A_V2, }, >> + #endif >> + #ifdef CONFIG_BCM63XX_CPU_63268 >> diff --git a/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch b/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch >> index be62e67..4793836 100644 >> --- a/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch >> +++ b/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch >> @@ -11,7 +11,7 @@ Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> >> >> --- a/drivers/mtd/devices/m25p80.c >> +++ b/drivers/mtd/devices/m25p80.c >> -@@ -229,7 +229,8 @@ static int m25p_probe(struct spi_device >> +@@ -251,7 +251,8 @@ static int m25p_probe(struct spi_device >> >> ppdata.of_node = spi->dev.of_node; >> >> diff --git a/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch b/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch >> index 3877442..75a874d 100644 >> --- a/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch >> +++ b/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch >> @@ -28,7 +28,7 @@ Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> >> size_t *retlen, u_char *buf) >> { >> struct m25p *flash = nor->priv; >> -@@ -152,6 +153,29 @@ static int m25p80_read(struct spi_nor *n >> +@@ -174,6 +175,29 @@ static int m25p80_read(struct spi_nor *n >> return 0; >> } >> >> @@ -58,7 +58,7 @@ Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> >> static int m25p80_erase(struct spi_nor *nor, loff_t offset) >> { >> struct m25p *flash = nor->priv; >> -@@ -223,6 +247,9 @@ static int m25p_probe(struct spi_device >> +@@ -245,6 +269,9 @@ static int m25p_probe(struct spi_device >> else >> flash_name = spi->modalias; >> >> diff --git a/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch b/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch >> index e421e9a..bbb565e 100644 >> --- a/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch >> +++ b/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch >> @@ -10,7 +10,7 @@ Subject: [PATCH 64/79] MTD: m25p80: allow passing pp_data >> >> --- a/drivers/mtd/devices/m25p80.c >> +++ b/drivers/mtd/devices/m25p80.c >> -@@ -250,6 +250,9 @@ static int m25p_probe(struct spi_device >> +@@ -272,6 +272,9 @@ static int m25p_probe(struct spi_device >> if (data) >> flash->max_transfer_len = data->max_transfer_len; >> >> diff --git a/target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch b/target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch >> new file mode 100644 >> index 0000000..fc7afc7 >> --- /dev/null >> +++ b/target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch >> @@ -0,0 +1,62 @@ >> +--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c >> ++++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c >> +@@ -2011,6 +2011,43 @@ static struct board_info __initdata boar >> + .num_spis = ARRAY_SIZE(DGND3700v1_3800B_spi_devices), >> + }; >> + >> ++static struct sprom_fixup __initdata EVG2000_fixups[] = { >> ++ { .offset = 219, .value = 0xec08 }, >> ++}; >> ++ >> ++static struct board_info __initdata board_EVG2000 = { >> ++ .name = "96369PVG", >> ++ .expected_cpu_id = 0x6368, >> ++ >> ++ .has_uart0 = 1, >> ++ .has_pci = 1, >> ++ .has_ohci0 = 1, >> ++ .has_ehci0 = 1, >> ++ .num_usbh_ports = 2, >> ++ >> ++ .has_enetsw = 1, >> ++ .enetsw = { >> ++ .used_ports = { >> ++ [5] = { >> ++ .used = 1, >> ++ .phy_id = 0xff, >> ++ .bypass_link = 1, >> ++ .force_speed = 1000, >> ++ .force_duplex_full = 1, >> ++ .name = "RGMII", >> ++ }, >> ++ }, >> ++ }, >> ++ .use_fallback_sprom = 1, >> ++ .fallback_sprom = { >> ++ .type = SPROM_BCM4322, >> ++ .pci_bus = 0, >> ++ .pci_dev = 1, >> ++ .board_fixups = EVG2000_fixups, >> ++ .num_board_fixups = ARRAY_SIZE(EVG2000_fixups), >> ++ }, >> ++}; >> ++ >> + static struct board_info __initdata board_HG655b = { >> + .name = "HW65x", >> + .expected_cpu_id = 0x6368, >> +@@ -2611,6 +2648,7 @@ static const struct board_info __initcon >> + &board_96368mvwg, >> + &board_96368mvngr, >> + &board_DGND3700v1_3800B, >> ++ &board_EVG2000, >> + &board_HG622, >> + &board_HG655b, >> + &board_P870HW51A_V2, >> +@@ -2723,6 +2761,7 @@ static struct of_device_id const bcm963x >> + { .compatible = "huawei,hg622", .data = &board_HG622, }, >> + { .compatible = "huawei,hg655b", .data = &board_HG655b, }, >> + { .compatible = "netgear,dgnd3700v1", .data = &board_DGND3700v1_3800B, }, >> ++ { .compatible = "netgear,evg2000", .data = &board_EVG2000, }, >> + { .compatible = "zyxel,p870hw-51a-v2", .data = &board_P870HW51A_V2, }, >> + #endif >> + #ifdef CONFIG_BCM63XX_CPU_63268 >> diff --git a/target/linux/brcm63xx/profiles/netgear.mk b/target/linux/brcm63xx/profiles/netgear.mk >> index bc345bb..e3bc34a 100644 >> --- a/target/linux/brcm63xx/profiles/netgear.mk >> +++ b/target/linux/brcm63xx/profiles/netgear.mk >> @@ -41,3 +41,13 @@ define Profile/DGND3700v1_3800B/Description >> Package set optimized for DGND3700 v1 / DGND3800B. >> endef >> $(eval $(call Profile,DGND3700v1_3800B)) >> + >> +define Profile/EVG2000 >> + NAME:=Netgear EVG2000 >> + PACKAGES:=kmod-b43 wpad-mini \ >> + kmod-usb2 kmod-usb-ohci kmod-ledtrig-usbdev >> +endef >> +define Profile/EVG2000/Description >> + Package set optimized for EVG2000. >> +endef >> +$(eval $(call Profile,EVG2000)) >
It would great if someone with the knowledge could take at look and see if they know why the 53115 switch is not detected so that this is a fully working device. On 3 June 2016 at 12:45, Graham Fairweather <xotic750@gmail.com> wrote: > Hi and thanks. > > On 3 June 2016 at 12:07, Álvaro Fernández Rojas <noltari@gmail.com> wrote: >> Hello Graham, >> >> Pulled into my staging tree with some changes (whitespace fixes, cleanups...): >> https://git.lede-project.org/?p=lede/noltari/staging.git;a=shortlog;h=refs/heads/brcm63xx-next >> >> Regards, >> Álvaro. >> >> El 23/5/16 a las 0:56, Xotic750 escribió: >>> From: Graham Fairweather <xotic750@gmail.com> >>> >>> This patch adds support for the Netgear EVG2000 VoIP Gateway to the >>> bcm63xx targets. >>> Ran 'make target/linux/refresh V=s' after update to kernel 4.4.10 from >>> 4.4.8 where the initial patch was added. >>> This device was not sold to the general public, but rather is/was >>> provided by telcos to customers in Sweden, Australia, Singapore and >>> other parts of asia. >>> System-On-Chip: Broadcom BCM6369 (2 * BMIPS4350 v3.1 / 400 MHz) >>> Flash size: 16 MiB >>> RAM size: 64 MiB >>> Wireless: BCM4322 802.11b/g/n (onboard) >>> Ethernet: Broadcom BCM53115 >>> USB: 2 x USB 2.0 >>> Known issues: >>> - Unable to detect 53115 switch. This appear to be a problem with >>> probing for the PHY using MDIO and results in error 5. Doesn't seem to >>> be a problem with the configuration, and could use someone with >>> experience to have a look at it. >>> - Uses the b43 driver as using the OpenWRT/LEDE broadcom-wl driver >>> fails to load the firmware for the 4322, so 802.11n is not supported. >>> The factory build uses a newer broadcom-wl driver. >>> - No support for the 2 VoIP ports (not attempted) >>> More info on the device and the research can be found at: >>> https://wiki.openwrt.org/toh/netgear/evg2000 >>> https://wikidevi.com/wiki/Netgear_EVG2000 >>> https://github.com/Xotic750/mirror-lede/tree/evg2000 >>> https://forum.openwrt.org/viewtopic.php?id=63950 >>> Signed-off-by: Graham Fairweather <xotic750@gmail.com> >>> --- >>> .../linux/brcm63xx/base-files/etc/board.d/01_leds | 7 ++ >>> .../brcm63xx/base-files/etc/board.d/02_network | 1 + >>> target/linux/brcm63xx/base-files/etc/diag.sh | 3 + >>> .../base-files/etc/uci-defaults/09_fix_crc | 2 +- >>> target/linux/brcm63xx/base-files/lib/brcm63xx.sh | 3 + >>> .../lib/preinit/05_init_interfaces_brcm63xx | 1 + >>> target/linux/brcm63xx/dts/evg2000.dts | 103 +++++++++++++++++++++ >>> target/linux/brcm63xx/image/Makefile | 2 + >>> .../brcm63xx/patches-4.1/575-board_EVG2000.patch | 62 +++++++++++++ >>> ...-m25p80-use-parsers-if-provided-in-flash-.patch | 2 +- >>> ...CES-m25p80-add-support-for-limiting-reads.patch | 4 +- >>> .../414-MTD-m25p80-allow-passing-pp_data.patch | 2 +- >>> .../brcm63xx/patches-4.4/575-board_EVG2000.patch | 62 +++++++++++++ >>> target/linux/brcm63xx/profiles/netgear.mk | 10 ++ >>> 14 files changed, 259 insertions(+), 5 deletions(-) >>> create mode 100644 target/linux/brcm63xx/dts/evg2000.dts >>> create mode 100644 target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch >>> create mode 100644 target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch >>> >>> diff --git a/target/linux/brcm63xx/base-files/etc/board.d/01_leds b/target/linux/brcm63xx/base-files/etc/board.d/01_leds >>> index 8339254..4163214 100755 >>> --- a/target/linux/brcm63xx/base-files/etc/board.d/01_leds >>> +++ b/target/linux/brcm63xx/base-files/etc/board.d/01_leds >>> @@ -24,6 +24,13 @@ 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" >>> ;; >>> +evg2000) >>> + ucidef_set_led_netdev "lan" "LAN" "EVG2000:green:lan" "eth0" >>> + ucidef_set_led_netdev "wan" "WAN" "EVG2000:green:wan" "eth1" >>> + ucidef_set_led_netdev "wlan0" "WIFI" "EVG2000:green:wireless" "wlan0" >>> + ucidef_set_led_usbdev "usb1" "USB1" "EVG2000:green:voip1" "1-1" >>> + ucidef_set_led_usbdev "usb2" "USB2" "EVG2000:green:voip2" "1-2" >>> + ;; >>> fast2704n) >>> ucidef_set_led_netdev "wan" "WAN" "F@ST2704N:green:inet" "eth0.2" >>> ;; >>> diff --git a/target/linux/brcm63xx/base-files/etc/board.d/02_network b/target/linux/brcm63xx/base-files/etc/board.d/02_network >>> index f96da08..83367c1 100755 >>> --- a/target/linux/brcm63xx/base-files/etc/board.d/02_network >>> +++ b/target/linux/brcm63xx/base-files/etc/board.d/02_network >>> @@ -11,6 +11,7 @@ board_config_update >>> case "$(brcm63xx_board_name)" in >>> >>> cvg834g |\ >>> +evg2000 |\ >>> rta770bw |\ >>> rta770w |\ >>> spw303v |\ >>> diff --git a/target/linux/brcm63xx/base-files/etc/diag.sh b/target/linux/brcm63xx/base-files/etc/diag.sh >>> index b864964..6ac2459 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() { >>> dgnd3700v1_dgnd3800b) >>> status_led="DGND3700v1_3800B:green:power" >>> ;; >>> + evg2000) >>> + status_led="EVG2000:green:power" >>> + ;; >>> fast2504n) >>> status_led="fast2504n:green:ok" >>> ;; >>> diff --git a/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc b/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc >>> index 70dbe2a..1201168 100644 >>> --- a/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc >>> +++ b/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc >>> @@ -21,6 +21,7 @@ case "$(brcm63xx_board_name)" in >>> cpva642 |\ >>> ct-6373 |\ >>> dsl-274xb-f |\ >>> + evg2000 |\ >>> hg622 |\ >>> magic |\ >>> p870hw-51a_v2 |\ >>> @@ -37,4 +38,3 @@ case "$(brcm63xx_board_name)" in >>> do_fixcrc >>> ;; >>> esac >>> - >>> diff --git a/target/linux/brcm63xx/base-files/lib/brcm63xx.sh b/target/linux/brcm63xx/base-files/lib/brcm63xx.sh >>> index a2d6519..9cc0b2b 100755 >>> --- a/target/linux/brcm63xx/base-files/lib/brcm63xx.sh >>> +++ b/target/linux/brcm63xx/base-files/lib/brcm63xx.sh >>> @@ -183,6 +183,9 @@ brcm63xx_dt_detect() { >>> "Netgear DGND3700v1/DGND3800B") >>> board_name="dgnd3700v1_dgnd3800b" >>> ;; >>> + "Netgear EVG2000") >>> + board_name="evg2000" >>> + ;; >>> "NuCom R5010UN v2") >>> board_name="r5010un_v2" >>> ;; >>> diff --git a/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx b/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx >>> index 7e4dfcb..1e3fc14 100644 >>> --- a/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx >>> +++ b/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx >>> @@ -18,6 +18,7 @@ set_preinit_iface() { >>> dsl-274xb-c |\ >>> dsl-274xb-f |\ >>> dsl-275xb-d |\ >>> + evg2000 |\ >>> fast2504n |\ >>> fast2704v2 |\ >>> hg553 |\ >>> diff --git a/target/linux/brcm63xx/dts/evg2000.dts b/target/linux/brcm63xx/dts/evg2000.dts >>> new file mode 100644 >>> index 0000000..04f7b84 >>> --- /dev/null >>> +++ b/target/linux/brcm63xx/dts/evg2000.dts >>> @@ -0,0 +1,103 @@ >>> +/dts-v1/; >>> + >>> +#include "bcm6368.dtsi" >>> + >>> +#include <dt-bindings/input/input.h> >>> + >>> +/ { >>> + model = "Netgear EVG2000"; >>> + compatible = "netgear,evg2000", "brcm,bcm6368"; >>> + >>> + gpio-keys-polled { >>> + compatible = "gpio-keys-polled"; >>> + #address-cells = <1>; >>> + #size-cells = <0>; >>> + poll-interval = <20>; >>> + debounce-interval = <60>; >>> + >>> + reset { >>> + label = "reset"; >>> + gpios = <&gpio0 25 1>; >>> + linux,code = <KEY_RESTART>; >>> + }; >>> + wps { >>> + label = "wps"; >>> + gpios = <&gpio0 26 1>; >>> + linux,code = <KEY_WPS_BUTTON>; >>> + }; >>> + }; >>> + >>> + gpio-leds { >>> + compatible = "gpio-leds"; >>> + >>> + voip1_green { >>> + label = "EVG2000:green:voip1"; >>> + gpios = <&gpio0 14 1>; >>> + }; >>> + voip2_green { >>> + label = "EVG2000:green:voip2"; >>> + gpios = <&gpio0 2 1>; >>> + }; >>> + inet_red { >>> + label = "EVG2000:red:inet"; >>> + gpios = <&gpio0 4 1>; >>> + }; >>> + inet_green { >>> + label = "EVG2000:green:inet"; >>> + gpios = <&gpio0 5 1>; >>> + }; >>> + usb_green { >>> + label = "EVG2000:green:usb"; >>> + gpios = <&gpio0 15 1>; >>> + }; >>> + power_green { >>> + label = "EVG2000:green:power"; >>> + gpios = <&gpio0 22 1>; >>> + default-state = "on"; >>> + }; >>> + power_red { >>> + label = "EVG2000:red:power"; >>> + gpios = <&gpio0 23 1>; >>> + }; >>> + lan_green { >>> + label = "EVG2000:green:lan"; >>> + gpios = <&gpio0 24 1>; >>> + }; >>> + wireless_green { >>> + label = "EVG2000:green:wireless"; >>> + gpios = <&gpio0 26 1>; >>> + }; >>> + wan_green { >>> + label = "EVG2000:green:wan"; >>> + gpios = <&gpio0 27 1>; >>> + }; >>> + }; >>> +}; >>> + >>> +&pflash { >>> + status = "ok"; >>> + >>> + linux,part-probe = "bcm63xxpart"; >>> + >>> + cfe@0 { >>> + label = "CFE"; >>> + reg = <0x00000000 0x00020000>; >>> + read-only; >>> + }; >>> + >>> + linux@20000 { >>> + label = "linux"; >>> + reg = <0x00020000 0x00f40000>; >>> + }; >>> + >>> + board_data@f60000 { >>> + label = "board_data"; >>> + reg = <0x00f60000 0x00080000>; >>> + read-only; >>> + }; >>> + >>> + nvram@fe0000 { >>> + label = "nvram"; >>> + reg = <0x00fe0000 0x00020000>; >>> + }; >>> +}; >>> diff --git a/target/linux/brcm63xx/image/Makefile b/target/linux/brcm63xx/image/Makefile >>> index e00b6fb..f1fb86b 100644 >>> --- a/target/linux/brcm63xx/image/Makefile >>> +++ b/target/linux/brcm63xx/image/Makefile >>> @@ -593,6 +593,8 @@ $(eval $(call bcm63xxCfeRamdisk,DG834GV4,DG834GTv4,dg834g_v4,96348W3,6348)) >>> $(eval $(call bcm63xxCfeNetgear,DGND3700v1_3800B,DGND3700v1,dgnd3700v1,96368MVWG,6368,--image-offset 0x20000 --block-size 0x20000,U12L144T01_NETGEAR_NEWLED,1)) >>> # Netgear DGND3800B >>> $(eval $(call bcm63xxCfeNetgear,DGND3700v1_3800B,DGND3800B,dgnd3700v1,96368MVWG,6368,--image-offset 0x20000 --block-size 0x20000,U12L144T11_NETGEAR_NEWLED,1)) >>> +# Netgear EVG2000 >>> +$(eval $(call bcm63xxCfeNetgear,EVG2000,EVG2000,evg2000,96369PVG,6369,--image-offset 0x20000 --block-size 0x20000,U12H154T90_NETGEAR,1)) >>> # NuCom R5010UNv2 >>> $(eval $(call bcm63xxCfe,R5010UNV2,R5010UNv2,r5010unv2,96328ang,6328,--pad 8)) >>> # Pirelli Alice Gate VoIP 2 Plus Wi-Fi AGPF-S0 >>> diff --git a/target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch b/target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch >>> new file mode 100644 >>> index 0000000..9339085 >>> --- /dev/null >>> +++ b/target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch >>> @@ -0,0 +1,62 @@ >>> +--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c >>> ++++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c >>> +@@ -2010,6 +2010,43 @@ static struct board_info __initdata boar >>> + .num_spis = ARRAY_SIZE(DGND3700v1_3800B_spi_devices), >>> + }; >>> + >>> ++static struct sprom_fixup __initdata EVG2000_fixups[] = { >>> ++ { .offset = 219, .value = 0xec08 }, >>> ++}; >>> ++ >>> ++static struct board_info __initdata board_EVG2000 = { >>> ++ .name = "96369PVG", >>> ++ .expected_cpu_id = 0x6368, >>> ++ >>> ++ .has_uart0 = 1, >>> ++ .has_pci = 1, >>> ++ .has_ohci0 = 1, >>> ++ .has_ehci0 = 1, >>> ++ .num_usbh_ports = 2, >>> ++ >>> ++ .has_enetsw = 1, >>> ++ .enetsw = { >>> ++ .used_ports = { >>> ++ [5] = { >>> ++ .used = 1, >>> ++ .phy_id = 0xff, >>> ++ .bypass_link = 1, >>> ++ .force_speed = 1000, >>> ++ .force_duplex_full = 1, >>> ++ .name = "RGMII", >>> ++ }, >>> ++ }, >>> ++ }, >>> ++ .use_fallback_sprom = 1, >>> ++ .fallback_sprom = { >>> ++ .type = SPROM_BCM4322, >>> ++ .pci_bus = 0, >>> ++ .pci_dev = 1, >>> ++ .board_fixups = EVG2000_fixups, >>> ++ .num_board_fixups = ARRAY_SIZE(EVG2000_fixups), >>> ++ }, >>> ++}; >>> ++ >>> + static struct board_info __initdata board_HG655b = { >>> + .name = "HW65x", >>> + .expected_cpu_id = 0x6368, >>> +@@ -2610,6 +2647,7 @@ static const struct board_info __initcon >>> + &board_96368mvwg, >>> + &board_96368mvngr, >>> + &board_DGND3700v1_3800B, >>> ++ &board_EVG2000, >>> + &board_HG622, >>> + &board_HG655b, >>> + &board_P870HW51A_V2, >>> +@@ -2722,6 +2760,7 @@ static struct of_device_id const bcm963x >>> + { .compatible = "huawei,hg622", .data = &board_HG622, }, >>> + { .compatible = "huawei,hg655b", .data = &board_HG655b, }, >>> + { .compatible = "netgear,dgnd3700v1", .data = &board_DGND3700v1_3800B, }, >>> ++ { .compatible = "netgear,evg2000", .data = &board_EVG2000, }, >>> + { .compatible = "zyxel,p870hw-51a-v2", .data = &board_P870HW51A_V2, }, >>> + #endif >>> + #ifdef CONFIG_BCM63XX_CPU_63268 >>> diff --git a/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch b/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch >>> index be62e67..4793836 100644 >>> --- a/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch >>> +++ b/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch >>> @@ -11,7 +11,7 @@ Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> >>> >>> --- a/drivers/mtd/devices/m25p80.c >>> +++ b/drivers/mtd/devices/m25p80.c >>> -@@ -229,7 +229,8 @@ static int m25p_probe(struct spi_device >>> +@@ -251,7 +251,8 @@ static int m25p_probe(struct spi_device >>> >>> ppdata.of_node = spi->dev.of_node; >>> >>> diff --git a/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch b/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch >>> index 3877442..75a874d 100644 >>> --- a/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch >>> +++ b/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch >>> @@ -28,7 +28,7 @@ Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> >>> size_t *retlen, u_char *buf) >>> { >>> struct m25p *flash = nor->priv; >>> -@@ -152,6 +153,29 @@ static int m25p80_read(struct spi_nor *n >>> +@@ -174,6 +175,29 @@ static int m25p80_read(struct spi_nor *n >>> return 0; >>> } >>> >>> @@ -58,7 +58,7 @@ Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> >>> static int m25p80_erase(struct spi_nor *nor, loff_t offset) >>> { >>> struct m25p *flash = nor->priv; >>> -@@ -223,6 +247,9 @@ static int m25p_probe(struct spi_device >>> +@@ -245,6 +269,9 @@ static int m25p_probe(struct spi_device >>> else >>> flash_name = spi->modalias; >>> >>> diff --git a/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch b/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch >>> index e421e9a..bbb565e 100644 >>> --- a/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch >>> +++ b/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch >>> @@ -10,7 +10,7 @@ Subject: [PATCH 64/79] MTD: m25p80: allow passing pp_data >>> >>> --- a/drivers/mtd/devices/m25p80.c >>> +++ b/drivers/mtd/devices/m25p80.c >>> -@@ -250,6 +250,9 @@ static int m25p_probe(struct spi_device >>> +@@ -272,6 +272,9 @@ static int m25p_probe(struct spi_device >>> if (data) >>> flash->max_transfer_len = data->max_transfer_len; >>> >>> diff --git a/target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch b/target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch >>> new file mode 100644 >>> index 0000000..fc7afc7 >>> --- /dev/null >>> +++ b/target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch >>> @@ -0,0 +1,62 @@ >>> +--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c >>> ++++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c >>> +@@ -2011,6 +2011,43 @@ static struct board_info __initdata boar >>> + .num_spis = ARRAY_SIZE(DGND3700v1_3800B_spi_devices), >>> + }; >>> + >>> ++static struct sprom_fixup __initdata EVG2000_fixups[] = { >>> ++ { .offset = 219, .value = 0xec08 }, >>> ++}; >>> ++ >>> ++static struct board_info __initdata board_EVG2000 = { >>> ++ .name = "96369PVG", >>> ++ .expected_cpu_id = 0x6368, >>> ++ >>> ++ .has_uart0 = 1, >>> ++ .has_pci = 1, >>> ++ .has_ohci0 = 1, >>> ++ .has_ehci0 = 1, >>> ++ .num_usbh_ports = 2, >>> ++ >>> ++ .has_enetsw = 1, >>> ++ .enetsw = { >>> ++ .used_ports = { >>> ++ [5] = { >>> ++ .used = 1, >>> ++ .phy_id = 0xff, >>> ++ .bypass_link = 1, >>> ++ .force_speed = 1000, >>> ++ .force_duplex_full = 1, >>> ++ .name = "RGMII", >>> ++ }, >>> ++ }, >>> ++ }, >>> ++ .use_fallback_sprom = 1, >>> ++ .fallback_sprom = { >>> ++ .type = SPROM_BCM4322, >>> ++ .pci_bus = 0, >>> ++ .pci_dev = 1, >>> ++ .board_fixups = EVG2000_fixups, >>> ++ .num_board_fixups = ARRAY_SIZE(EVG2000_fixups), >>> ++ }, >>> ++}; >>> ++ >>> + static struct board_info __initdata board_HG655b = { >>> + .name = "HW65x", >>> + .expected_cpu_id = 0x6368, >>> +@@ -2611,6 +2648,7 @@ static const struct board_info __initcon >>> + &board_96368mvwg, >>> + &board_96368mvngr, >>> + &board_DGND3700v1_3800B, >>> ++ &board_EVG2000, >>> + &board_HG622, >>> + &board_HG655b, >>> + &board_P870HW51A_V2, >>> +@@ -2723,6 +2761,7 @@ static struct of_device_id const bcm963x >>> + { .compatible = "huawei,hg622", .data = &board_HG622, }, >>> + { .compatible = "huawei,hg655b", .data = &board_HG655b, }, >>> + { .compatible = "netgear,dgnd3700v1", .data = &board_DGND3700v1_3800B, }, >>> ++ { .compatible = "netgear,evg2000", .data = &board_EVG2000, }, >>> + { .compatible = "zyxel,p870hw-51a-v2", .data = &board_P870HW51A_V2, }, >>> + #endif >>> + #ifdef CONFIG_BCM63XX_CPU_63268 >>> diff --git a/target/linux/brcm63xx/profiles/netgear.mk b/target/linux/brcm63xx/profiles/netgear.mk >>> index bc345bb..e3bc34a 100644 >>> --- a/target/linux/brcm63xx/profiles/netgear.mk >>> +++ b/target/linux/brcm63xx/profiles/netgear.mk >>> @@ -41,3 +41,13 @@ define Profile/DGND3700v1_3800B/Description >>> Package set optimized for DGND3700 v1 / DGND3800B. >>> endef >>> $(eval $(call Profile,DGND3700v1_3800B)) >>> + >>> +define Profile/EVG2000 >>> + NAME:=Netgear EVG2000 >>> + PACKAGES:=kmod-b43 wpad-mini \ >>> + kmod-usb2 kmod-usb-ohci kmod-ledtrig-usbdev >>> +endef >>> +define Profile/EVG2000/Description >>> + Package set optimized for EVG2000. >>> +endef >>> +$(eval $(call Profile,EVG2000)) >>
Hi, On 5 June 2016 at 15:13, Graham Fairweather <xotic750@gmail.com> wrote: > It would great if someone with the knowledge could take at look and > see if they know why the 53115 switch is not detected so that this is > a fully working device. MDIO connected switches aren't currently supported for bcm6368 and newer, only SPI connected ones (it's a driver limitation). Assuming it is MDIO connected. Jonas
Aha. It is MDIO as far as I am aware. Is this something new/changed, because whoever tested it originally (when 'roboswitch' was in the build) was able to detect it? https://wiki.openwrt.org/toh/netgear/evg2000#openwrt_test_bootlog_bcm6368_cpu_id_6369 On 5 June 2016 at 15:37, Jonas Gorski <jonas.gorski@gmail.com> wrote: > Hi, > > On 5 June 2016 at 15:13, Graham Fairweather <xotic750@gmail.com> wrote: >> It would great if someone with the knowledge could take at look and >> see if they know why the 53115 switch is not detected so that this is >> a fully working device. > > MDIO connected switches aren't currently supported for bcm6368 and > newer, only SPI connected ones (it's a driver limitation). Assuming it > is MDIO connected. > > > Jonas
diff --git a/target/linux/brcm63xx/base-files/etc/board.d/01_leds b/target/linux/brcm63xx/base-files/etc/board.d/01_leds index 8339254..4163214 100755 --- a/target/linux/brcm63xx/base-files/etc/board.d/01_leds +++ b/target/linux/brcm63xx/base-files/etc/board.d/01_leds @@ -24,6 +24,13 @@ 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" ;; +evg2000) + ucidef_set_led_netdev "lan" "LAN" "EVG2000:green:lan" "eth0" + ucidef_set_led_netdev "wan" "WAN" "EVG2000:green:wan" "eth1" + ucidef_set_led_netdev "wlan0" "WIFI" "EVG2000:green:wireless" "wlan0" + ucidef_set_led_usbdev "usb1" "USB1" "EVG2000:green:voip1" "1-1" + ucidef_set_led_usbdev "usb2" "USB2" "EVG2000:green:voip2" "1-2" + ;; fast2704n) ucidef_set_led_netdev "wan" "WAN" "F@ST2704N:green:inet" "eth0.2" ;; diff --git a/target/linux/brcm63xx/base-files/etc/board.d/02_network b/target/linux/brcm63xx/base-files/etc/board.d/02_network index f96da08..83367c1 100755 --- a/target/linux/brcm63xx/base-files/etc/board.d/02_network +++ b/target/linux/brcm63xx/base-files/etc/board.d/02_network @@ -11,6 +11,7 @@ board_config_update case "$(brcm63xx_board_name)" in cvg834g |\ +evg2000 |\ rta770bw |\ rta770w |\ spw303v |\ diff --git a/target/linux/brcm63xx/base-files/etc/diag.sh b/target/linux/brcm63xx/base-files/etc/diag.sh index b864964..6ac2459 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() { dgnd3700v1_dgnd3800b) status_led="DGND3700v1_3800B:green:power" ;; + evg2000) + status_led="EVG2000:green:power" + ;; fast2504n) status_led="fast2504n:green:ok" ;; diff --git a/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc b/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc index 70dbe2a..1201168 100644 --- a/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc +++ b/target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc @@ -21,6 +21,7 @@ case "$(brcm63xx_board_name)" in cpva642 |\ ct-6373 |\ dsl-274xb-f |\ + evg2000 |\ hg622 |\ magic |\ p870hw-51a_v2 |\ @@ -37,4 +38,3 @@ case "$(brcm63xx_board_name)" in do_fixcrc ;; esac - diff --git a/target/linux/brcm63xx/base-files/lib/brcm63xx.sh b/target/linux/brcm63xx/base-files/lib/brcm63xx.sh index a2d6519..9cc0b2b 100755 --- a/target/linux/brcm63xx/base-files/lib/brcm63xx.sh +++ b/target/linux/brcm63xx/base-files/lib/brcm63xx.sh @@ -183,6 +183,9 @@ brcm63xx_dt_detect() { "Netgear DGND3700v1/DGND3800B") board_name="dgnd3700v1_dgnd3800b" ;; + "Netgear EVG2000") + board_name="evg2000" + ;; "NuCom R5010UN v2") board_name="r5010un_v2" ;; diff --git a/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx b/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx index 7e4dfcb..1e3fc14 100644 --- a/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx +++ b/target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx @@ -18,6 +18,7 @@ set_preinit_iface() { dsl-274xb-c |\ dsl-274xb-f |\ dsl-275xb-d |\ + evg2000 |\ fast2504n |\ fast2704v2 |\ hg553 |\ diff --git a/target/linux/brcm63xx/dts/evg2000.dts b/target/linux/brcm63xx/dts/evg2000.dts new file mode 100644 index 0000000..04f7b84 --- /dev/null +++ b/target/linux/brcm63xx/dts/evg2000.dts @@ -0,0 +1,103 @@ +/dts-v1/; + +#include "bcm6368.dtsi" + +#include <dt-bindings/input/input.h> + +/ { + model = "Netgear EVG2000"; + compatible = "netgear,evg2000", "brcm,bcm6368"; + + gpio-keys-polled { + compatible = "gpio-keys-polled"; + #address-cells = <1>; + #size-cells = <0>; + poll-interval = <20>; + debounce-interval = <60>; + + reset { + label = "reset"; + gpios = <&gpio0 25 1>; + linux,code = <KEY_RESTART>; + }; + wps { + label = "wps"; + gpios = <&gpio0 26 1>; + linux,code = <KEY_WPS_BUTTON>; + }; + }; + + gpio-leds { + compatible = "gpio-leds"; + + voip1_green { + label = "EVG2000:green:voip1"; + gpios = <&gpio0 14 1>; + }; + voip2_green { + label = "EVG2000:green:voip2"; + gpios = <&gpio0 2 1>; + }; + inet_red { + label = "EVG2000:red:inet"; + gpios = <&gpio0 4 1>; + }; + inet_green { + label = "EVG2000:green:inet"; + gpios = <&gpio0 5 1>; + }; + usb_green { + label = "EVG2000:green:usb"; + gpios = <&gpio0 15 1>; + }; + power_green { + label = "EVG2000:green:power"; + gpios = <&gpio0 22 1>; + default-state = "on"; + }; + power_red { + label = "EVG2000:red:power"; + gpios = <&gpio0 23 1>; + }; + lan_green { + label = "EVG2000:green:lan"; + gpios = <&gpio0 24 1>; + }; + wireless_green { + label = "EVG2000:green:wireless"; + gpios = <&gpio0 26 1>; + }; + wan_green { + label = "EVG2000:green:wan"; + gpios = <&gpio0 27 1>; + }; + }; +}; + +&pflash { + status = "ok"; + + linux,part-probe = "bcm63xxpart"; + + cfe@0 { + label = "CFE"; + reg = <0x00000000 0x00020000>; + read-only; + }; + + linux@20000 { + label = "linux"; + reg = <0x00020000 0x00f40000>; + }; + + board_data@f60000 { + label = "board_data"; + reg = <0x00f60000 0x00080000>; + read-only; + }; + + nvram@fe0000 { + label = "nvram"; + reg = <0x00fe0000 0x00020000>; + }; +}; diff --git a/target/linux/brcm63xx/image/Makefile b/target/linux/brcm63xx/image/Makefile index e00b6fb..f1fb86b 100644 --- a/target/linux/brcm63xx/image/Makefile +++ b/target/linux/brcm63xx/image/Makefile @@ -593,6 +593,8 @@ $(eval $(call bcm63xxCfeRamdisk,DG834GV4,DG834GTv4,dg834g_v4,96348W3,6348)) $(eval $(call bcm63xxCfeNetgear,DGND3700v1_3800B,DGND3700v1,dgnd3700v1,96368MVWG,6368,--image-offset 0x20000 --block-size 0x20000,U12L144T01_NETGEAR_NEWLED,1)) # Netgear DGND3800B $(eval $(call bcm63xxCfeNetgear,DGND3700v1_3800B,DGND3800B,dgnd3700v1,96368MVWG,6368,--image-offset 0x20000 --block-size 0x20000,U12L144T11_NETGEAR_NEWLED,1)) +# Netgear EVG2000 +$(eval $(call bcm63xxCfeNetgear,EVG2000,EVG2000,evg2000,96369PVG,6369,--image-offset 0x20000 --block-size 0x20000,U12H154T90_NETGEAR,1)) # NuCom R5010UNv2 $(eval $(call bcm63xxCfe,R5010UNV2,R5010UNv2,r5010unv2,96328ang,6328,--pad 8)) # Pirelli Alice Gate VoIP 2 Plus Wi-Fi AGPF-S0 diff --git a/target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch b/target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch new file mode 100644 index 0000000..9339085 --- /dev/null +++ b/target/linux/brcm63xx/patches-4.1/575-board_EVG2000.patch @@ -0,0 +1,62 @@ +--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c ++++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c +@@ -2010,6 +2010,43 @@ static struct board_info __initdata boar + .num_spis = ARRAY_SIZE(DGND3700v1_3800B_spi_devices), + }; + ++static struct sprom_fixup __initdata EVG2000_fixups[] = { ++ { .offset = 219, .value = 0xec08 }, ++}; ++ ++static struct board_info __initdata board_EVG2000 = { ++ .name = "96369PVG", ++ .expected_cpu_id = 0x6368, ++ ++ .has_uart0 = 1, ++ .has_pci = 1, ++ .has_ohci0 = 1, ++ .has_ehci0 = 1, ++ .num_usbh_ports = 2, ++ ++ .has_enetsw = 1, ++ .enetsw = { ++ .used_ports = { ++ [5] = { ++ .used = 1, ++ .phy_id = 0xff, ++ .bypass_link = 1, ++ .force_speed = 1000, ++ .force_duplex_full = 1, ++ .name = "RGMII", ++ }, ++ }, ++ }, ++ .use_fallback_sprom = 1, ++ .fallback_sprom = { ++ .type = SPROM_BCM4322, ++ .pci_bus = 0, ++ .pci_dev = 1, ++ .board_fixups = EVG2000_fixups, ++ .num_board_fixups = ARRAY_SIZE(EVG2000_fixups), ++ }, ++}; ++ + static struct board_info __initdata board_HG655b = { + .name = "HW65x", + .expected_cpu_id = 0x6368, +@@ -2610,6 +2647,7 @@ static const struct board_info __initcon + &board_96368mvwg, + &board_96368mvngr, + &board_DGND3700v1_3800B, ++ &board_EVG2000, + &board_HG622, + &board_HG655b, + &board_P870HW51A_V2, +@@ -2722,6 +2760,7 @@ static struct of_device_id const bcm963x + { .compatible = "huawei,hg622", .data = &board_HG622, }, + { .compatible = "huawei,hg655b", .data = &board_HG655b, }, + { .compatible = "netgear,dgnd3700v1", .data = &board_DGND3700v1_3800B, }, ++ { .compatible = "netgear,evg2000", .data = &board_EVG2000, }, + { .compatible = "zyxel,p870hw-51a-v2", .data = &board_P870HW51A_V2, }, + #endif + #ifdef CONFIG_BCM63XX_CPU_63268 diff --git a/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch b/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch index be62e67..4793836 100644 --- a/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch +++ b/target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch @@ -11,7 +11,7 @@ Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> --- a/drivers/mtd/devices/m25p80.c +++ b/drivers/mtd/devices/m25p80.c -@@ -229,7 +229,8 @@ static int m25p_probe(struct spi_device +@@ -251,7 +251,8 @@ static int m25p_probe(struct spi_device ppdata.of_node = spi->dev.of_node; diff --git a/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch b/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch index 3877442..75a874d 100644 --- a/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch +++ b/target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch @@ -28,7 +28,7 @@ Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> size_t *retlen, u_char *buf) { struct m25p *flash = nor->priv; -@@ -152,6 +153,29 @@ static int m25p80_read(struct spi_nor *n +@@ -174,6 +175,29 @@ static int m25p80_read(struct spi_nor *n return 0; } @@ -58,7 +58,7 @@ Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com> static int m25p80_erase(struct spi_nor *nor, loff_t offset) { struct m25p *flash = nor->priv; -@@ -223,6 +247,9 @@ static int m25p_probe(struct spi_device +@@ -245,6 +269,9 @@ static int m25p_probe(struct spi_device else flash_name = spi->modalias; diff --git a/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch b/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch index e421e9a..bbb565e 100644 --- a/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch +++ b/target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch @@ -10,7 +10,7 @@ Subject: [PATCH 64/79] MTD: m25p80: allow passing pp_data --- a/drivers/mtd/devices/m25p80.c +++ b/drivers/mtd/devices/m25p80.c -@@ -250,6 +250,9 @@ static int m25p_probe(struct spi_device +@@ -272,6 +272,9 @@ static int m25p_probe(struct spi_device if (data) flash->max_transfer_len = data->max_transfer_len; diff --git a/target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch b/target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch new file mode 100644 index 0000000..fc7afc7 --- /dev/null +++ b/target/linux/brcm63xx/patches-4.4/575-board_EVG2000.patch @@ -0,0 +1,62 @@ +--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c ++++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c +@@ -2011,6 +2011,43 @@ static struct board_info __initdata boar + .num_spis = ARRAY_SIZE(DGND3700v1_3800B_spi_devices), + }; + ++static struct sprom_fixup __initdata EVG2000_fixups[] = { ++ { .offset = 219, .value = 0xec08 }, ++}; ++ ++static struct board_info __initdata board_EVG2000 = { ++ .name = "96369PVG", ++ .expected_cpu_id = 0x6368, ++ ++ .has_uart0 = 1, ++ .has_pci = 1, ++ .has_ohci0 = 1, ++ .has_ehci0 = 1, ++ .num_usbh_ports = 2, ++ ++ .has_enetsw = 1, ++ .enetsw = { ++ .used_ports = { ++ [5] = { ++ .used = 1, ++ .phy_id = 0xff, ++ .bypass_link = 1, ++ .force_speed = 1000, ++ .force_duplex_full = 1, ++ .name = "RGMII", ++ }, ++ }, ++ }, ++ .use_fallback_sprom = 1, ++ .fallback_sprom = { ++ .type = SPROM_BCM4322, ++ .pci_bus = 0, ++ .pci_dev = 1, ++ .board_fixups = EVG2000_fixups, ++ .num_board_fixups = ARRAY_SIZE(EVG2000_fixups), ++ }, ++}; ++ + static struct board_info __initdata board_HG655b = { + .name = "HW65x", + .expected_cpu_id = 0x6368, +@@ -2611,6 +2648,7 @@ static const struct board_info __initcon + &board_96368mvwg, + &board_96368mvngr, + &board_DGND3700v1_3800B, ++ &board_EVG2000, + &board_HG622, + &board_HG655b, + &board_P870HW51A_V2, +@@ -2723,6 +2761,7 @@ static struct of_device_id const bcm963x + { .compatible = "huawei,hg622", .data = &board_HG622, }, + { .compatible = "huawei,hg655b", .data = &board_HG655b, }, + { .compatible = "netgear,dgnd3700v1", .data = &board_DGND3700v1_3800B, }, ++ { .compatible = "netgear,evg2000", .data = &board_EVG2000, }, + { .compatible = "zyxel,p870hw-51a-v2", .data = &board_P870HW51A_V2, }, + #endif + #ifdef CONFIG_BCM63XX_CPU_63268 diff --git a/target/linux/brcm63xx/profiles/netgear.mk b/target/linux/brcm63xx/profiles/netgear.mk index bc345bb..e3bc34a 100644 --- a/target/linux/brcm63xx/profiles/netgear.mk +++ b/target/linux/brcm63xx/profiles/netgear.mk @@ -41,3 +41,13 @@ define Profile/DGND3700v1_3800B/Description Package set optimized for DGND3700 v1 / DGND3800B. endef $(eval $(call Profile,DGND3700v1_3800B)) + +define Profile/EVG2000 + NAME:=Netgear EVG2000 + PACKAGES:=kmod-b43 wpad-mini \ + kmod-usb2 kmod-usb-ohci kmod-ledtrig-usbdev +endef +define Profile/EVG2000/Description + Package set optimized for EVG2000. +endef +$(eval $(call Profile,EVG2000))