135 lines
3.2 KiB
Diff
135 lines
3.2 KiB
Diff
--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
|
|
+++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
|
|
@@ -164,6 +164,115 @@ static struct board_info __initdata boar
|
|
},
|
|
};
|
|
|
|
+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_uart0 = 1,
|
|
+ .has_pci = 1,
|
|
+ .use_fallback_sprom = 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",
|
|
+ },
|
|
+ },
|
|
+ },
|
|
+
|
|
+ .leds = {
|
|
+ {
|
|
+ .name = "AR-5387un:green:power",
|
|
+ .gpio = 8,
|
|
+ .default_trigger = "default-on",
|
|
+ },
|
|
+ {
|
|
+ .name = "AR-5387un:red:power",
|
|
+ .gpio = 4,
|
|
+ },
|
|
+ {
|
|
+ .name = "AR-5387un:green:inet",
|
|
+ .gpio = 7,
|
|
+ },
|
|
+ {
|
|
+ .name = "AR-5387un:red:inet",
|
|
+ .gpio = 1,
|
|
+ },
|
|
+ {
|
|
+ .name = "AR-5387un:green:dsl",
|
|
+ .gpio = 11,
|
|
+ .active_low = 1,
|
|
+ },
|
|
+ },
|
|
+
|
|
+ .buttons = {
|
|
+ {
|
|
+ .desc = "reset",
|
|
+ .gpio = 23,
|
|
+ .active_low = 1,
|
|
+ .type = EV_KEY,
|
|
+ .code = KEY_RESTART,
|
|
+ .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
|
|
+ },
|
|
+ },
|
|
+
|
|
+ .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_963281TAN = {
|
|
.name = "963281TAN",
|
|
.expected_cpu_id = 0x6328,
|
|
@@ -2803,6 +2912,7 @@ static const struct board_info __initcon
|
|
#endif
|
|
#ifdef CONFIG_BCM63XX_CPU_6328
|
|
&board_96328avng,
|
|
+ &board_AR5387un,
|
|
&board_963281TAN,
|
|
&board_A4001N1,
|
|
&board_dsl_274xb_f1,
|
|
@@ -2873,6 +2983,7 @@ static struct of_device_id const bcm963x
|
|
{ .compatible = "adb,a4001n1", .data = &board_A4001N1, },
|
|
{ .compatible = "brcm,bcm963281TAN", .data = &board_963281TAN, },
|
|
{ .compatible = "brcm,bcm96328avng", .data = &board_96328avng, },
|
|
+ { .compatible = "comtrend,ar-5387un", .data = &board_AR5387un, },
|
|
#endif
|
|
#ifdef CONFIG_BCM63XX_CPU_6338
|
|
{ .compatible = "brcm,bcm96338gw", .data = &board_96338gw, },
|