[LEDE-DEV] [PATCHv3 1/1] [brcm63xx] Add initial support for EVG2000
Graham Fairweather
xotic750 at gmail.com
Sun Jun 5 06:13:46 PDT 2016
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 at gmail.com> wrote:
> Hi and thanks.
>
> On 3 June 2016 at 12:07, Álvaro Fernández Rojas <noltari at 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 at 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 at 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 at 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 at 0 {
>>> + label = "CFE";
>>> + reg = <0x00000000 0x00020000>;
>>> + read-only;
>>> + };
>>> +
>>> + linux at 20000 {
>>> + label = "linux";
>>> + reg = <0x00020000 0x00f40000>;
>>> + };
>>> +
>>> + board_data at f60000 {
>>> + label = "board_data";
>>> + reg = <0x00f60000 0x00080000>;
>>> + read-only;
>>> + };
>>> +
>>> + nvram at 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 at 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 at 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 at 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))
>>
More information about the Lede-dev
mailing list