diff mbox

[LEDE-DEV,1/1,brcm63xx] Add support for the NetGear EVG2000

Message ID CAD2Yd_YBT5xtQBfzSqEXkyanZeBgrahOaUTN+KZ5rve3=-B4ow@mail.gmail.com
State Superseded, archived
Headers show

Commit Message

Graham Fairweather May 13, 2016, 6:57 p.m. UTC
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>
---
 target/linux/brcm63xx/base-files/etc/board.d/01_leds
                           |   7 +++++
 target/linux/brcm63xx/base-files/etc/board.d/02_network
                           |   1 +
 target/linux/brcm63xx/base-files/etc/diag.sh
                           |   3 +++
 target/linux/brcm63xx/base-files/etc/uci-defaults/09_fix_crc
                           |   2 +-
 target/linux/brcm63xx/base-files/lib/brcm63xx.sh
                           |   3 +++
 target/linux/brcm63xx/base-files/lib/preinit/05_init_interfaces_brcm63xx
                        |   1 +
 target/linux/brcm63xx/dts/evg2000.dts
                           | 103
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 target/linux/brcm63xx/image/Makefile
                           |   2 ++
 target/linux/brcm63xx/patches-4.1/805-board_EVG2000.patch
                           |  62
+++++++++++++++++++++++++++++++++++++++++++
 target/linux/brcm63xx/patches-4.4/202-MTD-DEVICES-m25p80-use-parsers-if-provided-in-flash-.patch
|   2 +-
 target/linux/brcm63xx/patches-4.4/203-MTD-DEVICES-m25p80-add-support-for-limiting-reads.patch
   |   4 +--
 target/linux/brcm63xx/patches-4.4/414-MTD-m25p80-allow-passing-pp_data.patch
                    |   2 +-
 target/linux/brcm63xx/patches-4.4/805-board_EVG2000.patch
                           |  62
+++++++++++++++++++++++++++++++++++++++++++
 target/linux/brcm63xx/profiles/netgear.mk
                           |  10 +++++++
 target/linux/generic/patches-4.4/032-fq_codel-add-batch-ability-to-fq_codel_drop.patch
          |   4 +--
 target/linux/generic/patches-4.4/330-MIPS-kexec-Accept-command-line-parameters-from-users.patch
 |  10 +++----
 target/linux/generic/patches-4.4/531-debloat_lzma.patch
                           |  33 ++++++++++++-----------
 target/linux/generic/patches-4.4/645-bridge_multicast_to_unicast.patch
                          |   5 ++--
 target/linux/generic/patches-4.4/834-ledtrig-libata.patch
                           |   4 +--
 19 files changed, 289 insertions(+), 31 deletions(-)

Comments

Conor O'Gorman May 16, 2016, 8:17 a.m. UTC | #1
You are still having line wrap issues with your patches, as Felix 
previously mentioned.
Graham Fairweather May 16, 2016, 9:06 a.m. UTC | #2
Ok, thanks for the feedback. I tried so hard to make sure that it was
correct. :(

On 16 May 2016 at 10:17, Conor O'Gorman <i@conorogorman.net> wrote:
> You are still having line wrap issues with your patches, as Felix previously
> mentioned.
John Crispin May 16, 2016, 9:08 a.m. UTC | #3
On 16/05/2016 11:06, Graham Fairweather wrote:
> Ok, thanks for the feedback. I tried so hard to make sure that it was
> correct. :(
> 


> On 16 May 2016 at 10:17, Conor O'Gorman <i@conorogorman.net> wrote:
>> You are still having line wrap issues with your patches, as Felix previously
>> mentioned.


you can use github to send a PR if you like. that way you dont have to
use a mail client.
Graham Fairweather May 16, 2016, 9:26 a.m. UTC | #4
How do I do that? I forked the LEDE repo
(http://git.lede-project.org/openwrt/source.git) to github, created a
branch for the work
(https://github.com/Xotic750/mirror-lede/tree/evg2000), the LEDE
document (https://www.lede-project.org/development.html) says that PRs
are accepted, but no detail of how to do it?

On 16 May 2016 at 11:08, John Crispin <john@phrozen.org> wrote:
>
>
> On 16/05/2016 11:06, Graham Fairweather wrote:
>> Ok, thanks for the feedback. I tried so hard to make sure that it was
>> correct. :(
>>
>
>
>> On 16 May 2016 at 10:17, Conor O'Gorman <i@conorogorman.net> wrote:
>>> You are still having line wrap issues with your patches, as Felix previously
>>> mentioned.
>
>
> you can use github to send a PR if you like. that way you dont have to
> use a mail client.
>
> _______________________________________________
> Lede-dev mailing list
> Lede-dev@lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/lede-dev
Conor O'Gorman May 16, 2016, 9:29 a.m. UTC | #5
On 16/05/16 10:26, Graham Fairweather wrote:
> How do I do that? I forked the LEDE repo
> (http://git.lede-project.org/openwrt/source.git) to github, created a
> branch for the work
> (https://github.com/Xotic750/mirror-lede/tree/evg2000), the LEDE
> document (https://www.lede-project.org/development.html) says that PRs
> are accepted, but no detail of how to do it?
>
https://help.github.com/articles/using-pull-requests/
Graham Fairweather May 16, 2016, 10:14 a.m. UTC | #6
Everything that I read talks about creating PRs when you have forked
from another github repo, and I have successfully create PRs in this
situation in the past. I have not seen any information about how to
create a PR when my repo was forked from a git repo that is hosted
outside of github. When I go to github and choose create PR, I can
only create it to branches within my fork, the upstream
(http://git.lede-project.org/openwrt/source.git) is not listed. Is
there a github repo that I should have forked from instead?

On 16 May 2016 at 11:29, Conor O'Gorman <i@conorogorman.net> wrote:
> On 16/05/16 10:26, Graham Fairweather wrote:
>>
>> How do I do that? I forked the LEDE repo
>> (http://git.lede-project.org/openwrt/source.git) to github, created a
>> branch for the work
>> (https://github.com/Xotic750/mirror-lede/tree/evg2000), the LEDE
>> document (https://www.lede-project.org/development.html) says that PRs
>> are accepted, but no detail of how to do it?
>>
> https://help.github.com/articles/using-pull-requests/
Conor O'Gorman May 16, 2016, 10:24 a.m. UTC | #7
On 16/05/16 11:14, Graham Fairweather wrote:
> Everything that I read talks about creating PRs when you have forked
> from another github repo, and I have successfully create PRs in this
> situation in the past. I have not seen any information about how to
> create a PR when my repo was forked from a git repo that is hosted
> outside of github. When I go to github and choose create PR, I can
> only create it to branches within my fork, the upstream
> (http://git.lede-project.org/openwrt/source.git) is not listed. Is
> there a github repo that I should have forked from instead?
>
If you have a publicly accessible git repository you can use "git 
request-pull"
https://git-scm.com/docs/git-request-pull

If you are using github you can fork from 
https://github.com/lede-project/source
diff mbox

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/805-board_EVG2000.patch
b/target/linux/brcm63xx/patches-4.1/805-board_EVG2000.patch
new file mode 100644
index 0000000..9339085
--- /dev/null
+++ b/target/linux/brcm63xx/patches-4.1/805-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/805-board_EVG2000.patch
b/target/linux/brcm63xx/patches-4.4/805-board_EVG2000.patch
new file mode 100644
index 0000000..fc7afc7
--- /dev/null
+++ b/target/linux/brcm63xx/patches-4.4/805-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))
diff --git a/target/linux/generic/patches-4.4/032-fq_codel-add-batch-ability-to-fq_codel_drop.patch
b/target/linux/generic/patches-4.4/032-fq_codel-add-batch-ability-to-fq_codel_drop.patch
index 94c9c7f..d139034 100644
--- a/target/linux/generic/patches-4.4/032-fq_codel-add-batch-ability-to-fq_codel_drop.patch
+++ b/target/linux/generic/patches-4.4/032-fq_codel-add-batch-ability-to-fq_codel_drop.patch
@@ -138,12 +138,12 @@  Signed-off-by: David S. Miller <davem@davemloft.net>
 -      if (fq_codel_drop(sch) == idx)
 -              return NET_XMIT_CN;
 +      ret = fq_codel_drop(sch, q->drop_batch_size);
++
++      q->drop_overlimit += prev_qlen - sch->q.qlen;

 -      /* As we dropped a packet, better let upper stack know this */
 -      qdisc_tree_reduce_backlog(sch, 1, prev_backlog - sch->qstats.backlog);
 -      return NET_XMIT_SUCCESS;
-+      q->drop_overlimit += prev_qlen - sch->q.qlen;
-+
 +      /* As we dropped packet(s), better let upper stack know this */
 +      qdisc_tree_reduce_backlog(sch, prev_qlen - sch->q.qlen,
 +                                prev_backlog - sch->qstats.backlog);
diff --git a/target/linux/generic/patches-4.4/330-MIPS-kexec-Accept-command-line-parameters-from-users.patch
b/target/linux/generic/patches-4.4/330-MIPS-kexec-Accept-command-line-parameters-from-users.patch
index 4a056c8..a69d197 100644
--- a/target/linux/generic/patches-4.4/330-MIPS-kexec-Accept-command-line-parameters-from-users.patch
+++ b/target/linux/generic/patches-4.4/330-MIPS-kexec-Accept-command-line-parameters-from-users.patch
@@ -284,15 +284,15 @@  Signed-off-by: Yousong Zhou <yszhou4tech@gmail.com>
 +      EXPORT(kexec_argv_buf)
 +      .skip           KEXEC_COMMAND_LINE_SIZE
 +      .size           kexec_argv_buf, KEXEC_COMMAND_LINE_SIZE
++
++kexec_argv:
++      EXPORT(kexec_argv)
++      .skip           KEXEC_ARGV_SIZE
++      .size           kexec_argv, KEXEC_ARGV_SIZE

 -relocate_new_kernel_size:
 -      EXPORT(relocate_new_kernel_size)
 -      PTR             relocate_new_kernel_end - relocate_new_kernel
 -      .size           relocate_new_kernel_size, PTRSIZE
-+kexec_argv:
-+      EXPORT(kexec_argv)
-+      .skip           KEXEC_ARGV_SIZE
-+      .size           kexec_argv, KEXEC_ARGV_SIZE
-+
 +kexec_relocate_new_kernel_end:
 +      EXPORT(kexec_relocate_new_kernel_end)
diff --git a/target/linux/generic/patches-4.4/531-debloat_lzma.patch
b/target/linux/generic/patches-4.4/531-debloat_lzma.patch
index bbf2b75..aa3c498 100644
--- a/target/linux/generic/patches-4.4/531-debloat_lzma.patch
+++ b/target/linux/generic/patches-4.4/531-debloat_lzma.patch
@@ -219,26 +219,26 @@ 
  {
    UInt32 dicSize;
    Byte d;
-@@ -935,33 +883,11 @@ static SRes LzmaDec_AllocateProbs2(CLzma
+@@ -935,7 +883,7 @@ static SRes LzmaDec_AllocateProbs2(CLzma
    return SZ_OK;
  }

 -SRes LzmaDec_AllocateProbs(CLzmaDec *p, const Byte *props, unsigned
propsSize, ISzAlloc *alloc)
--{
--  CLzmaProps propNew;
--  RINOK(LzmaProps_Decode(&propNew, props, propsSize));
--  RINOK(LzmaDec_AllocateProbs2(p, &propNew, alloc));
--  p->prop = propNew;
--  return SZ_OK;
--}
--
--SRes LzmaDec_Allocate(CLzmaDec *p, const Byte *props, unsigned
propsSize, ISzAlloc *alloc)
 +static SRes LzmaDec_AllocateProbs(CLzmaDec *p, const Byte *props,
unsigned propsSize, ISzAlloc *alloc)
  {
    CLzmaProps propNew;
--  SizeT dicBufSize;
    RINOK(LzmaProps_Decode(&propNew, props, propsSize));
-   RINOK(LzmaDec_AllocateProbs2(p, &propNew, alloc));
+@@ -943,28 +891,6 @@ SRes LzmaDec_AllocateProbs(CLzmaDec *p,
+   p->prop = propNew;
+   return SZ_OK;
+ }
+-
+-SRes LzmaDec_Allocate(CLzmaDec *p, const Byte *props, unsigned
propsSize, ISzAlloc *alloc)
+-{
+-  CLzmaProps propNew;
+-  SizeT dicBufSize;
+-  RINOK(LzmaProps_Decode(&propNew, props, propsSize));
+-  RINOK(LzmaDec_AllocateProbs2(p, &propNew, alloc));
 -  dicBufSize = propNew.dicSize;
 -  if (p->dic == 0 || dicBufSize != p->dicBufSize)
 -  {
@@ -251,9 +251,12 @@ 
 -    }
 -  }
 -  p->dicBufSize = dicBufSize;
-   p->prop = propNew;
-   return SZ_OK;
- }
+-  p->prop = propNew;
+-  return SZ_OK;
+-}
+
+ SRes LzmaDecode(Byte *dest, SizeT *destLen, const Byte *src, SizeT *srcLen,
+     const Byte *propData, unsigned propSize, ELzmaFinishMode finishMode,
 --- a/include/linux/lzma/LzmaEnc.h
 +++ b/include/linux/lzma/LzmaEnc.h
 @@ -31,9 +31,6 @@ typedef struct _CLzmaEncProps
diff --git a/target/linux/generic/patches-4.4/645-bridge_multicast_to_unicast.patch
b/target/linux/generic/patches-4.4/645-bridge_multicast_to_unicast.patch
index 7232b93..f729f38 100644
--- a/target/linux/generic/patches-4.4/645-bridge_multicast_to_unicast.patch
+++ b/target/linux/generic/patches-4.4/645-bridge_multicast_to_unicast.patch
@@ -382,6 +382,8 @@  Implement optinal multicast->unicast conversion
for igmp snooping

 -              port = (unsigned long)lport > (unsigned long)rport ?
 -                     lport : rport;
+-
+-              prev = maybe_deliver(prev, port, skb, __packet_hook);
 +              if ((unsigned long)lport > (unsigned long)rport) {
 +                      port = lport;
 +                      addr = p->unicast ? p->eth_addr : NULL;
@@ -389,8 +391,7 @@  Implement optinal multicast->unicast conversion
for igmp snooping
 +                      port = rport;
 +                      addr = NULL;
 +              }
-
--              prev = maybe_deliver(prev, port, skb, __packet_hook);
++
 +              if (addr)
 +                      prev = maybe_deliver_addr(prev, port, skb, addr,
 +                                                __packet_hook);
diff --git a/target/linux/generic/patches-4.4/834-ledtrig-libata.patch
b/target/linux/generic/patches-4.4/834-ledtrig-libata.patch
index 9a9203b..c60fc1a 100644
--- a/target/linux/generic/patches-4.4/834-ledtrig-libata.patch
+++ b/target/linux/generic/patches-4.4/834-ledtrig-libata.patch
@@ -110,11 +110,11 @@  Signed-off-by: Daniel Golle <daniel@makrotopia.org>
 +      for (i = 0; i < host->n_ports; i++) {
 +              if (unlikely(!host->ports[i]->ledtrig))
 +                      continue;
-+
+
 +              snprintf(host->ports[i]->ledtrig_name,
 +                      sizeof(host->ports[i]->ledtrig_name), "ata%u",
 +                      host->ports[i]->print_id);
-
++
 +              host->ports[i]->ledtrig->name = host->ports[i]->ledtrig_name;
 +
 +              if (led_trigger_register(host->ports[i]->ledtrig)) {