1 --- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
2 +++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
4 #if 0 /* FIXME: 3.14 removed non-DT support */
5 #include <linux/spi/74x164.h>
7 +#include <linux/rtl8367.h>
8 #include <asm/addrspace.h>
9 #include <bcm63xx_board.h>
10 #include <bcm63xx_cpu.h>
12 #define NB4_SPI_GPIO_MOSI 7
13 #define NB4_SPI_GPIO_CLK 6
14 #define NB4_74HC64_GPIO(X) (NB4_74X164_GPIO_BASE + (X))
15 +#define NB6_GPIO_RTL8367_SDA 18
16 +#define NB6_GPIO_RTL8367_SCK 20
18 #define CT6373_PID_OFFSET 0xff80
19 #define CT6373_74X164_GPIO_BASE 64
20 @@ -2387,6 +2390,105 @@ static struct board_info __initdata boar
22 #endif /* CONFIG_BCM63XX_CPU_6358 */
24 +#ifdef CONFIG_BCM63XX_CPU_6362
25 +static struct rtl8367_extif_config nb6_rtl8367_extif0_cfg = {
26 + .mode = RTL8367_EXTIF_MODE_RGMII,
35 + .speed = RTL8367_PORT_SPEED_1000,
39 +static struct rtl8367_platform_data nb6_rtl8367_data = {
40 + .gpio_sda = NB6_GPIO_RTL8367_SDA,
41 + .gpio_sck = NB6_GPIO_RTL8367_SCK,
42 + .extif0_cfg = &nb6_rtl8367_extif0_cfg,
45 +static struct platform_device nb6_rtl8367_device = {
46 + .name = RTL8367_DRIVER_NAME,
49 + .platform_data = &nb6_rtl8367_data,
53 +static struct platform_device * __initdata nb6_devices[] = {
54 + &nb6_rtl8367_device,
57 +static struct board_info __initdata board_nb6 = {
59 + .of_board_id = "sfr,nb6-ser-r0",
60 + .expected_cpu_id = 0x6362,
66 + .num_usbh_ports = 2,
76 + .force_speed = 1000,
77 + .force_duplex_full = 1,
88 + .code = KEY_RESTART,
89 + .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
96 + .code = KEY_WPS_BUTTON,
97 + .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
105 + .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
113 + .debounce_interval = BCM963XX_KEYS_DEBOUNCE_INTERVAL,
118 + .devs = nb6_devices,
119 + .num_devs = ARRAY_SIZE(nb6_devices),
121 +#endif /* CONFIG_BCM63XX_CPU_6362 */
126 @@ -2590,6 +2692,10 @@ static const struct board_info __initcon
130 +#ifdef CONFIG_BCM63XX_CPU_6362
134 #ifdef CONFIG_BCM63XX_CPU_6368