mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-13 16:31:09 +00:00
c4ab1b7dd9
At the moment, bcm63xx creates one patch for each board to add to board_bcm963xx.c. While this is not really helpful to get an overview in the first place, it is particularly painful if you want to change something for an early file and have to refresh all the later patches accordingly. Since it does not look like these board patches are upstreamed either, this commit consolidates all board additions into one patch per "board". By this, both adding and editing boards should become much simpler, and we drop about 1300 lines of "code" from patches as well. Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
522 lines
10 KiB
Diff
522 lines
10 KiB
Diff
--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
|
|
+++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
|
|
@@ -348,6 +348,482 @@ static struct board_info __initdata boar
|
|
},
|
|
},
|
|
};
|
|
+
|
|
+static struct board_info __initdata board_963281TAN = {
|
|
+ .name = "963281TAN",
|
|
+ .expected_cpu_id = 0x6328,
|
|
+
|
|
+ .has_pci = 1,
|
|
+
|
|
+ .has_enetsw = 1,
|
|
+ .enetsw = {
|
|
+ .used_ports = {
|
|
+ [0] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 1,
|
|
+ .name = "Port 1",
|
|
+ },
|
|
+ [1] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 2,
|
|
+ .name = "Port 2",
|
|
+ },
|
|
+ [2] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 3,
|
|
+ .name = "Port 3",
|
|
+ },
|
|
+ [3] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 4,
|
|
+ .name = "Port 4",
|
|
+ },
|
|
+ },
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct board_info __initdata board_A4001N = {
|
|
+ .name = "96328dg2x2",
|
|
+ .expected_cpu_id = 0x6328,
|
|
+
|
|
+ .has_pci = 1,
|
|
+ .has_ohci0 = 1,
|
|
+ .has_ehci0 = 1,
|
|
+ .num_usbh_ports = 1,
|
|
+
|
|
+ .has_enetsw = 1,
|
|
+ .enetsw = {
|
|
+ .used_ports = {
|
|
+ [0] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 1,
|
|
+ .name = "Port 1",
|
|
+ },
|
|
+ [1] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 2,
|
|
+ .name = "Port 2",
|
|
+ },
|
|
+ [2] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 3,
|
|
+ .name = "Port 3",
|
|
+ },
|
|
+ [3] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 4,
|
|
+ .name = "Port 4",
|
|
+ },
|
|
+ },
|
|
+ },
|
|
+
|
|
+ .use_fallback_sprom = 1,
|
|
+ .fallback_sprom = {
|
|
+ .type = SPROM_BCM43225,
|
|
+ .pci_bus = 1,
|
|
+ .pci_dev = 0,
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct board_info __initdata board_A4001N1 = {
|
|
+ .name = "963281T_TEF",
|
|
+ .expected_cpu_id = 0x6328,
|
|
+
|
|
+ .has_pci = 1,
|
|
+ .has_ohci0 = 1,
|
|
+ .has_ehci0 = 1,
|
|
+ .num_usbh_ports = 1,
|
|
+
|
|
+ .has_enetsw = 1,
|
|
+ .enetsw = {
|
|
+ .used_ports = {
|
|
+ [0] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 1,
|
|
+ .name = "Port 1",
|
|
+ },
|
|
+ [1] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 2,
|
|
+ .name = "Port 2",
|
|
+ },
|
|
+ [2] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 3,
|
|
+ .name = "Port 3",
|
|
+ },
|
|
+ [3] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 4,
|
|
+ .name = "Port 4",
|
|
+ },
|
|
+ },
|
|
+ },
|
|
+
|
|
+ .use_fallback_sprom = 1,
|
|
+ .fallback_sprom = {
|
|
+ .type = SPROM_BCM43225,
|
|
+ .pci_bus = 1,
|
|
+ .pci_dev = 0,
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct sprom_fixup __initdata ad1018_fixups[] = {
|
|
+ { .offset = 6, .value = 0x1c00 },
|
|
+ { .offset = 65, .value = 0x1256 },
|
|
+ { .offset = 96, .value = 0x2046 },
|
|
+ { .offset = 97, .value = 0xfe69 },
|
|
+ { .offset = 98, .value = 0x1726 },
|
|
+ { .offset = 99, .value = 0xfa5c },
|
|
+ { .offset = 112, .value = 0x2046 },
|
|
+ { .offset = 113, .value = 0xfea8 },
|
|
+ { .offset = 114, .value = 0x1978 },
|
|
+ { .offset = 115, .value = 0xfa26 },
|
|
+ { .offset = 161, .value = 0x2222 },
|
|
+ { .offset = 169, .value = 0x2222 },
|
|
+ { .offset = 171, .value = 0x2222 },
|
|
+ { .offset = 173, .value = 0x2222 },
|
|
+ { .offset = 174, .value = 0x4444 },
|
|
+ { .offset = 175, .value = 0x2222 },
|
|
+ { .offset = 176, .value = 0x4444 },
|
|
+};
|
|
+
|
|
+static struct board_info __initdata board_AD1018 = {
|
|
+ .name = "96328avngr",
|
|
+ .expected_cpu_id = 0x6328,
|
|
+
|
|
+ .has_pci = 1,
|
|
+ .has_ohci0 = 1,
|
|
+ .has_ehci0 = 1,
|
|
+ .num_usbh_ports = 1,
|
|
+
|
|
+ .has_enetsw = 1,
|
|
+ .enetsw = {
|
|
+ .used_ports = {
|
|
+ [0] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 1,
|
|
+ .name = "FIBRE",
|
|
+ },
|
|
+ [1] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 2,
|
|
+ .name = "LAN3",
|
|
+ },
|
|
+ [2] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 3,
|
|
+ .name = "LAN2",
|
|
+ },
|
|
+ [3] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 4,
|
|
+ .name = "LAN1",
|
|
+ },
|
|
+ },
|
|
+ },
|
|
+
|
|
+ .use_fallback_sprom = 1,
|
|
+ .fallback_sprom = {
|
|
+ .type = SPROM_BCM43217,
|
|
+ .pci_bus = 1,
|
|
+ .pci_dev = 0,
|
|
+ .board_fixups = ad1018_fixups,
|
|
+ .num_board_fixups = ARRAY_SIZE(ad1018_fixups),
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct sprom_fixup __initdata ar5381u_fixups[] = {
|
|
+ { .offset = 97, .value = 0xfee5 },
|
|
+ { .offset = 98, .value = 0x157c },
|
|
+ { .offset = 99, .value = 0xfae7 },
|
|
+ { .offset = 113, .value = 0xfefa },
|
|
+ { .offset = 114, .value = 0x15d6 },
|
|
+ { .offset = 115, .value = 0xfaf8 },
|
|
+};
|
|
+
|
|
+static struct board_info __initdata board_AR5381u = {
|
|
+ .name = "96328A-1241N",
|
|
+ .expected_cpu_id = 0x6328,
|
|
+
|
|
+ .has_pci = 1,
|
|
+ .has_ohci0 = 1,
|
|
+ .has_ehci0 = 1,
|
|
+ .num_usbh_ports = 1,
|
|
+
|
|
+ .has_enetsw = 1,
|
|
+ .enetsw = {
|
|
+ .used_ports = {
|
|
+ [0] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 1,
|
|
+ .name = "Port 1",
|
|
+ },
|
|
+ [1] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 2,
|
|
+ .name = "Port 2",
|
|
+ },
|
|
+ [2] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 3,
|
|
+ .name = "Port 3",
|
|
+ },
|
|
+ [3] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 4,
|
|
+ .name = "Port 4",
|
|
+ },
|
|
+ },
|
|
+ },
|
|
+
|
|
+ .use_fallback_sprom = 1,
|
|
+ .fallback_sprom = {
|
|
+ .type = SPROM_BCM43225,
|
|
+ .pci_bus = 1,
|
|
+ .pci_dev = 0,
|
|
+ .board_fixups = ar5381u_fixups,
|
|
+ .num_board_fixups = ARRAY_SIZE(ar5381u_fixups),
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct sprom_fixup __initdata ar5387un_fixups[] = {
|
|
+ { .offset = 2, .value = 0x05bb },
|
|
+ { .offset = 65, .value = 0x1204 },
|
|
+ { .offset = 78, .value = 0x0303 },
|
|
+ { .offset = 79, .value = 0x0202 },
|
|
+ { .offset = 80, .value = 0xff02 },
|
|
+ { .offset = 87, .value = 0x0315 },
|
|
+ { .offset = 88, .value = 0x0315 },
|
|
+ { .offset = 96, .value = 0x2048 },
|
|
+ { .offset = 97, .value = 0xff11 },
|
|
+ { .offset = 98, .value = 0x1567 },
|
|
+ { .offset = 99, .value = 0xfb24 },
|
|
+ { .offset = 100, .value = 0x3e3c },
|
|
+ { .offset = 101, .value = 0x4038 },
|
|
+ { .offset = 102, .value = 0xfe7f },
|
|
+ { .offset = 103, .value = 0x1279 },
|
|
+ { .offset = 112, .value = 0x2048 },
|
|
+ { .offset = 113, .value = 0xff03 },
|
|
+ { .offset = 114, .value = 0x154c },
|
|
+ { .offset = 115, .value = 0xfb27 },
|
|
+ { .offset = 116, .value = 0x3e3c },
|
|
+ { .offset = 117, .value = 0x4038 },
|
|
+ { .offset = 118, .value = 0xfe87 },
|
|
+ { .offset = 119, .value = 0x1233 },
|
|
+ { .offset = 203, .value = 0x2226 },
|
|
+};
|
|
+
|
|
+static struct board_info __initdata board_AR5387un = {
|
|
+ .name = "96328A-1441N1",
|
|
+ .expected_cpu_id = 0x6328,
|
|
+
|
|
+ .has_pci = 1,
|
|
+ .has_ohci0 = 1,
|
|
+ .has_ehci0 = 1,
|
|
+ .num_usbh_ports = 1,
|
|
+
|
|
+ .has_enetsw = 1,
|
|
+ .enetsw = {
|
|
+ .used_ports = {
|
|
+ [0] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 1,
|
|
+ .name = "Port 1",
|
|
+ },
|
|
+ [1] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 2,
|
|
+ .name = "Port 2",
|
|
+ },
|
|
+ [2] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 3,
|
|
+ .name = "Port 3",
|
|
+ },
|
|
+ [3] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 4,
|
|
+ .name = "Port 4",
|
|
+ },
|
|
+ },
|
|
+ },
|
|
+
|
|
+ .use_fallback_sprom = 1,
|
|
+ .fallback_sprom = {
|
|
+ .type = SPROM_BCM43225,
|
|
+ .pci_bus = 1,
|
|
+ .pci_dev = 0,
|
|
+ .board_fixups = ar5387un_fixups,
|
|
+ .num_board_fixups = ARRAY_SIZE(ar5387un_fixups),
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct board_info __initdata board_dsl_274xb_f1 = {
|
|
+ .name = "AW4339U",
|
|
+ .expected_cpu_id = 0x6328,
|
|
+
|
|
+ .has_pci = 1,
|
|
+
|
|
+ .has_caldata = 1,
|
|
+ .caldata = {
|
|
+ {
|
|
+ .vendor = PCI_VENDOR_ID_ATHEROS,
|
|
+ .caldata_offset = 0x7d1000,
|
|
+ .slot = 0,
|
|
+ .led_pin = -1,
|
|
+ .led_active_high = 1,
|
|
+ },
|
|
+ },
|
|
+
|
|
+ .has_enetsw = 1,
|
|
+ .enetsw = {
|
|
+ .used_ports = {
|
|
+ [0] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 1,
|
|
+ .name = "Port 4",
|
|
+ },
|
|
+ [1] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 2,
|
|
+ .name = "Port 3",
|
|
+ },
|
|
+ [2] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 3,
|
|
+ .name = "Port 2",
|
|
+ },
|
|
+ [3] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 4,
|
|
+ .name = "Port 1",
|
|
+ },
|
|
+ },
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct board_info __initdata board_FAST2704V2 = {
|
|
+ .name = "F@ST2704V2",
|
|
+ .expected_cpu_id = 0x6328,
|
|
+
|
|
+ .has_pci = 1,
|
|
+ .has_ohci0 = 1,
|
|
+ .has_ehci0 = 1,
|
|
+ .has_usbd = 1,
|
|
+
|
|
+ .has_enetsw = 1,
|
|
+ .enetsw = {
|
|
+ .used_ports = {
|
|
+ [0] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 1,
|
|
+ .name = "Port 1",
|
|
+ },
|
|
+ [1] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 2,
|
|
+ .name = "Port 2",
|
|
+ },
|
|
+ [2] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 3,
|
|
+ .name = "Port 3",
|
|
+ },
|
|
+ [3] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 4,
|
|
+ .name = "Port 4",
|
|
+ },
|
|
+ },
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct board_info __initdata board_PDG_A4001N_A_000_1A1_AX = {
|
|
+ .name = "96328avng",
|
|
+ .expected_cpu_id = 0x6328,
|
|
+
|
|
+ .has_pci = 1,
|
|
+ .has_ohci0 = 1,
|
|
+ .has_ehci0 = 1,
|
|
+ .num_usbh_ports = 1,
|
|
+
|
|
+ .has_enetsw = 1,
|
|
+ .enetsw = {
|
|
+ .used_ports = {
|
|
+ [0] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 1,
|
|
+ .name = "Port 1",
|
|
+ },
|
|
+ [1] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 2,
|
|
+ .name = "Port 2",
|
|
+ },
|
|
+ [2] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 3,
|
|
+ .name = "Port 3",
|
|
+ },
|
|
+ [3] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 4,
|
|
+ .name = "Port 4",
|
|
+ },
|
|
+ },
|
|
+ },
|
|
+
|
|
+ .use_fallback_sprom = 1,
|
|
+ .fallback_sprom = {
|
|
+ .type = SPROM_BCM43225,
|
|
+ .pci_bus = 1,
|
|
+ .pci_dev = 0,
|
|
+ },
|
|
+};
|
|
+
|
|
+static struct board_info __initdata board_R5010UNV2 = {
|
|
+ .name = "96328ang",
|
|
+ .expected_cpu_id = 0x6328,
|
|
+
|
|
+ .has_pci = 1,
|
|
+ .has_ohci0 = 1,
|
|
+ .has_ehci0 = 1,
|
|
+ .num_usbh_ports = 1,
|
|
+
|
|
+ .has_enetsw = 1,
|
|
+ .enetsw = {
|
|
+ .used_ports = {
|
|
+ [0] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 1,
|
|
+ .name = "Port 1",
|
|
+ },
|
|
+ [1] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 2,
|
|
+ .name = "Port 2",
|
|
+ },
|
|
+ [2] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 3,
|
|
+ .name = "Port 3",
|
|
+ },
|
|
+ [3] = {
|
|
+ .used = 1,
|
|
+ .phy_id = 4,
|
|
+ .name = "Port 4",
|
|
+ },
|
|
+ },
|
|
+ },
|
|
+
|
|
+ .use_fallback_sprom = 1,
|
|
+ .fallback_sprom = {
|
|
+ .type = SPROM_BCM43217,
|
|
+ .pci_bus = 1,
|
|
+ .pci_dev = 0,
|
|
+ },
|
|
+};
|
|
#endif /* CONFIG_BCM63XX_CPU_6328 */
|
|
|
|
/*
|
|
@@ -703,6 +1179,16 @@ static const struct board_info __initcon
|
|
#endif /* CONFIG_BCM63XX_CPU_6318 */
|
|
#ifdef CONFIG_BCM63XX_CPU_6328
|
|
&board_96328avng,
|
|
+ &board_963281TAN,
|
|
+ &board_A4001N,
|
|
+ &board_A4001N1,
|
|
+ &board_AD1018,
|
|
+ &board_AR5381u,
|
|
+ &board_AR5387un,
|
|
+ &board_dsl_274xb_f1,
|
|
+ &board_FAST2704V2,
|
|
+ &board_PDG_A4001N_A_000_1A1_AX,
|
|
+ &board_R5010UNV2,
|
|
#endif /* CONFIG_BCM63XX_CPU_6328 */
|
|
#ifdef CONFIG_BCM63XX_CPU_6338
|
|
&board_96338gw,
|
|
@@ -742,7 +1228,18 @@ static struct of_device_id const bcm963x
|
|
{ .compatible = "sagem,fast-2704n", .data = &board_FAST2704N, },
|
|
#endif /* CONFIG_BCM63XX_CPU_6318 */
|
|
#ifdef CONFIG_BCM63XX_CPU_6328
|
|
+ { .compatible = "adb,a4001n", .data = &board_A4001N, },
|
|
+ { .compatible = "adb,a4001n1", .data = &board_A4001N1, },
|
|
+ { .compatible = "adb,pdg-a4001n-a-000-1a1-ax", .data = &board_PDG_A4001N_A_000_1A1_AX, },
|
|
{ .compatible = "brcm,bcm96328avng", .data = &board_96328avng, },
|
|
+ { .compatible = "brcm,bcm963281tan", .data = &board_963281TAN, },
|
|
+ { .compatible = "comtrend,ar-5381u", .data = &board_AR5381u, },
|
|
+ { .compatible = "comtrend,ar-5387un", .data = &board_AR5387un, },
|
|
+ { .compatible = "d-link,dsl-274xb-f1", .data = &board_dsl_274xb_f1, },
|
|
+ { .compatible = "nucom,r5010un-v2", .data = &board_R5010UNV2, },
|
|
+ { .compatible = "sagem,fast-2704-v2", .data = &board_FAST2704V2, },
|
|
+ { .compatible = "sercomm,ad1018", .data = &board_AD1018, },
|
|
+ { .compatible = "sercomm,ad1018-nor", .data = &board_AD1018, },
|
|
#endif /* CONFIG_BCM63XX_CPU_6328 */
|
|
#ifdef CONFIG_BCM63XX_CPU_6338
|
|
{ .compatible = "brcm,bcm96338gw", .data = &board_96338gw, },
|