brcm63xx: CPVA502+: add SPROM wifi
[openwrt/openwrt.git] / target / linux / brcm63xx / patches-4.4 / 520-bcm63xx-add-support-for-96368MVWG-board.patch
1 From eeacc2529942051504bc957726aa178671344421 Mon Sep 17 00:00:00 2001
2 From: Maxime Bizon <mbizon@freebox.fr>
3 Date: Wed, 20 Jan 2010 16:21:30 +0100
4 Subject: [PATCH 32/63] bcm63xx: add support for 96368MVWG board.
5
6 ---
7 arch/mips/bcm63xx/boards/board_bcm963xx.c | 95 ++++++++++++++++++++
8 .../mips/include/asm/mach-bcm63xx/board_bcm963xx.h | 2 +
9 2 files changed, 97 insertions(+), 0 deletions(-)
10
11 --- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
12 +++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
13 @@ -1141,6 +1141,59 @@ static struct board_info __initdata boar
14 #endif /* CONFIG_BCM63XX_CPU_6358 */
15
16 /*
17 + * known 6368 boards
18 + */
19 +#ifdef CONFIG_BCM63XX_CPU_6368
20 +static struct board_info __initdata board_96368mvwg = {
21 + .name = "96368MVWG",
22 + .expected_cpu_id = 0x6368,
23 +
24 + .has_uart0 = 1,
25 + .has_pci = 1,
26 +
27 + .has_usbd = 1,
28 +
29 + .usbd = {
30 + .use_fullspeed = 0,
31 + .port_no = 0,
32 + },
33 +
34 + .has_enetsw = 1,
35 +
36 + .enetsw = {
37 + .used_ports = {
38 + [1] = {
39 + .used = 1,
40 + .phy_id = 2,
41 + .name = "port1",
42 + },
43 +
44 + [2] = {
45 + .used = 1,
46 + .phy_id = 3,
47 + .name = "port2",
48 + },
49 +
50 + [4] = {
51 + .used = 1,
52 + .phy_id = 0x12,
53 + .name = "port0",
54 + },
55 +
56 + [5] = {
57 + .used = 1,
58 + .phy_id = 0x11,
59 + .name = "port3",
60 + },
61 + },
62 + },
63 +
64 + .has_ohci0 = 1,
65 + .has_ehci0 = 1,
66 +};
67 +#endif /* CONFIG_BCM63XX_CPU_6368 */
68 +
69 +/*
70 * all boards
71 */
72 static const struct board_info __initconst *bcm963xx_boards[] = {
73 @@ -1192,6 +1245,10 @@ static const struct board_info __initcon
74 &board_HW553,
75 &board_spw303v,
76 #endif
77 +
78 +#ifdef CONFIG_BCM63XX_CPU_6368
79 + &board_96368mvwg,
80 +#endif
81 };
82
83 static struct of_device_id const bcm963xx_boards_dt[] = {
84 @@ -1252,6 +1309,7 @@ static struct of_device_id const bcm963x
85 { .compatible = "telsey,cpva642", .data = &board_CPVA642, },
86 #endif
87 #ifdef CONFIG_BCM63XX_CPU_6368
88 + { .compatible = "brcm,bcm96368mvwg", .data = &board_96368mvwg, },
89 #endif
90 #ifdef CONFIG_BCM63XX_CPU_63268
91 #endif
92 --- a/arch/mips/bcm63xx/boards/board_common.c
93 +++ b/arch/mips/bcm63xx/boards/board_common.c
94 @@ -86,12 +86,25 @@ void __init board_early_setup(const stru
95 bcm63xx_pci_enabled = 1;
96 if (BCMCPU_IS_6348())
97 val |= GPIO_MODE_6348_G2_PCI;
98 +
99 + if (BCMCPU_IS_6368())
100 + val |= GPIO_MODE_6368_PCI_REQ1 |
101 + GPIO_MODE_6368_PCI_GNT1 |
102 + GPIO_MODE_6368_PCI_INTB |
103 + GPIO_MODE_6368_PCI_REQ0 |
104 + GPIO_MODE_6368_PCI_GNT0;
105 }
106 #endif
107
108 if (board.has_pccard) {
109 if (BCMCPU_IS_6348())
110 val |= GPIO_MODE_6348_G1_MII_PCCARD;
111 +
112 + if (BCMCPU_IS_6368())
113 + val |= GPIO_MODE_6368_PCMCIA_CD1 |
114 + GPIO_MODE_6368_PCMCIA_CD2 |
115 + GPIO_MODE_6368_PCMCIA_VS1 |
116 + GPIO_MODE_6368_PCMCIA_VS2;
117 }
118
119 if (board.has_enet0 && !board.enet0.use_internal_phy) {