brcm63xx: DVA-G3810BN/TL: Fix the WAN ethernet port
[oweals/openwrt.git] / target / linux / brcm63xx / patches-4.14 / 567-board_dsl-2751b_e1.patch
1 --- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
2 +++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
3 @@ -142,6 +142,74 @@ static struct board_info __initdata boar
4                 },
5         },
6  };
7 +
8 +static struct sprom_fixup __initdata dsl2751b_e1_fixups[] = {
9 +       { .offset = 96, .value = 0x2046 },
10 +       { .offset = 97, .value = 0xfe9d },
11 +       { .offset = 98, .value = 0x1854 },
12 +       { .offset = 99, .value = 0xfa59 },
13 +       { .offset = 112, .value = 0x2046 },
14 +       { .offset = 113, .value = 0xfe79 },
15 +       { .offset = 114, .value = 0x17f5 },
16 +       { .offset = 115, .value = 0xfa47 },
17 +       { .offset = 161, .value = 0x2222 },
18 +       { .offset = 162, .value = 0x2222 },
19 +       { .offset = 169, .value = 0x2222 },
20 +       { .offset = 170, .value = 0x2222 },
21 +       { .offset = 171, .value = 0x5555 },
22 +       { .offset = 172, .value = 0x5555 },
23 +       { .offset = 173, .value = 0x4444 },
24 +       { .offset = 174, .value = 0x4444 },
25 +       { .offset = 175, .value = 0x5555 },
26 +       { .offset = 176, .value = 0x5555 },
27 +};
28 +
29 +static struct board_info __initdata board_dsl_2751b_d1 = {
30 +       .name                           = "AW5200B",
31 +       .expected_cpu_id                = 0x6318,
32 +
33 +       .has_pci                        = 1,
34 +       .use_fallback_sprom             = 1,
35 +
36 +       .has_enetsw                     = 1,
37 +
38 +       .has_ohci0                      = 1,
39 +       .has_ehci0                      = 1,
40 +       .num_usbh_ports                 = 1,
41 +
42 +       .enetsw = {
43 +               .used_ports = {
44 +                       [0] = {
45 +                               .used   = 1,
46 +                               .phy_id = 1,
47 +                               .name   = "Port 1",
48 +                       },
49 +                       [1] = {
50 +                               .used   = 1,
51 +                               .phy_id = 2,
52 +                               .name   = "Port 2",
53 +                       },
54 +                       [2] = {
55 +                               .used   = 1,
56 +                               .phy_id = 3,
57 +                               .name   = "Port 3",
58 +                       },
59 +                       [3] = {
60 +                               .used   = 1,
61 +                               .phy_id = 4,
62 +                               .name   = "Port 4",
63 +                       },
64 +               },
65 +       },
66 +
67 +       .fallback_sprom = {
68 +               .type                           = SPROM_BCM43217,
69 +               .pci_bus                        = 1,
70 +               .pci_dev                        = 0,
71 +               .board_fixups                   = dsl2751b_e1_fixups,
72 +               .num_board_fixups               = ARRAY_SIZE(dsl2751b_e1_fixups),
73 +       },
74 +};
75  #endif /* CONFIG_BCM63XX_CPU_6318 */
76  
77  /*
78 @@ -1989,6 +2057,7 @@ static const struct board_info __initcon
79  #ifdef CONFIG_BCM63XX_CPU_6318
80         &board_96318ref,
81         &board_96318ref_p300,
82 +       &board_dsl_2751b_d1,
83  #endif
84  #ifdef CONFIG_BCM63XX_CPU_6328
85         &board_96328avng,
86 @@ -2082,6 +2151,7 @@ static struct of_device_id const bcm963x
87  #ifdef CONFIG_BCM63XX_CPU_6318
88         { .compatible = "brcm,bcm96318ref", .data = &board_96318ref, },
89         { .compatible = "brcm,bcm96318ref_p300", .data = &board_96318ref_p300, },
90 +       { .compatible = "d-link,dsl-275xb-d", .data = &board_dsl_2751b_d1, },
91  #endif
92  #ifdef CONFIG_BCM63XX_CPU_6328
93         { .compatible = "adb,a4001n", .data = &board_A4001N, },