aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/brcm63xx/patches-4.4/505-board_spw500v.patch
blob: c6bc4ec2de18b51d382e16400f4f748e70b8f284 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
+++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
@@ -340,6 +340,44 @@ static struct board_info __initdata boar
 		.force_duplex_full	= 1,
 	},
 };
+
+static struct sprom_fixup __initdata spw500v_fixups[] = {
+	{ .offset = 46, .value = 0x3046 },
+	{ .offset = 47, .value = 0x15a7 },
+	{ .offset = 48, .value = 0xfa89 },
+	{ .offset = 49, .value = 0xfe79 },
+	{ .offset = 57, .value = 0x6a49 },
+};
+
+static struct board_info __initdata board_spw500v = {
+	.name				= "SPW500V",
+	.expected_cpu_id		= 0x6348,
+
+	.has_enet0			= 1,
+	.has_pci			= 1,
+	.use_fallback_sprom		= 1,
+
+	.enet0 = {
+		.has_phy		= 1,
+		.use_internal_phy	= 1,
+	},
+
+	.has_dsp			= 1,
+	.dsp = {
+		.gpio_rst		= 6,
+		.gpio_int		= 34,
+		.ext_irq		= 2,
+		.cs			= 2,
+	},
+
+	.fallback_sprom = {
+		.type			= SPROM_BCM4318,
+		.pci_bus		= 0,
+		.pci_dev		= 1,
+		.board_fixups		= spw500v_fixups,
+		.num_board_fixups	= ARRAY_SIZE(spw500v_fixups),
+	},
+};
 #endif /* CONFIG_BCM63XX_CPU_6348 */
 
 /*
@@ -567,6 +605,7 @@ static const struct board_info __initcon
 	&board_96348gw_a,
 	&board_rta1025w_16,
 	&board_96348_D4PW,
+	&board_spw500v,
 #endif
 
 #ifdef CONFIG_BCM63XX_CPU_6358
@@ -608,6 +647,7 @@ static struct of_device_id const bcm963x
 	{ .compatible = "dynalink,rta1025w", .data = &board_rta1025w_16, },
 	{ .compatible = "netgear,dg834gtpn", .data = &board_96348gw_10, },
 	{ .compatible = "sagem,f@st2404", .data = &board_FAST2404, },
+	{ .compatible = "t-com,spw500v", .data = &board_spw500v, },
 	{ .compatible = "tp-link,td-w8900gb", .data = &board_96348gw_11, },
 	{ .compatible = "usr,9108", .data = &board_96348gw_a, },
 #endif