diff options
author | Jonas Gorski <jonas.gorski@gmail.com> | 2017-02-07 17:15:36 +0100 |
---|---|---|
committer | Jonas Gorski <jonas.gorski@gmail.com> | 2017-02-09 14:30:44 +0100 |
commit | 0127c480bb709c38e6cd2b2c0deb6931606e709f (patch) | |
tree | 6681c4804d1094911bc4ee3d13a87a0b020a3d2f /target/linux/brcm63xx/patches-4.4/528-board_nb6.patch | |
parent | 8b741d5cd182be1ad830f43bbc0a412912ea84f8 (diff) | |
download | upstream-0127c480bb709c38e6cd2b2c0deb6931606e709f.tar.gz upstream-0127c480bb709c38e6cd2b2c0deb6931606e709f.tar.bz2 upstream-0127c480bb709c38e6cd2b2c0deb6931606e709f.zip |
brcm63xx: Neufbox 6: fix switch by probing through DT
Probe the switch through DT instead of a platform device. This fixes
probe, as GPIO offsets are now properly accounted for.
Fixes the following issue:
[ 0.802953] 8021q: 802.1Q VLAN Support v1.8
[ 0.810518] rtl8366_smi: gpio_request failed for 18, err=-517
Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com>
Diffstat (limited to 'target/linux/brcm63xx/patches-4.4/528-board_nb6.patch')
-rw-r--r-- | target/linux/brcm63xx/patches-4.4/528-board_nb6.patch | 60 |
1 files changed, 3 insertions, 57 deletions
diff --git a/target/linux/brcm63xx/patches-4.4/528-board_nb6.patch b/target/linux/brcm63xx/patches-4.4/528-board_nb6.patch index 0f235093c3..5f1d47a150 100644 --- a/target/linux/brcm63xx/patches-4.4/528-board_nb6.patch +++ b/target/linux/brcm63xx/patches-4.4/528-board_nb6.patch @@ -1,61 +1,10 @@ --- a/arch/mips/bcm63xx/boards/board_bcm963xx.c +++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c -@@ -12,6 +12,8 @@ - #include <linux/init.h> - #include <linux/kernel.h> - #include <linux/string.h> -+#include <linux/platform_device.h> -+#include <linux/rtl8367.h> - #include <asm/addrspace.h> - #include <bcm63xx_board.h> - #include <bcm63xx_cpu.h> -@@ -27,6 +29,9 @@ - - #define HCS_OFFSET_128K 0x20000 - -+#define NB6_GPIO_RTL8367_SDA 18 -+#define NB6_GPIO_RTL8367_SCK 20 -+ - /* - * known 3368 boards - */ -@@ -1315,6 +1320,69 @@ static struct board_info __initdata boar +@@ -1315,6 +1315,34 @@ static struct board_info __initdata boar }; #endif /* CONFIG_BCM63XX_CPU_6358 */ +#ifdef CONFIG_BCM63XX_CPU_6362 -+static struct rtl8367_extif_config nb6_rtl8367_extif0_cfg = { -+ .mode = RTL8367_EXTIF_MODE_RGMII, -+ .txdelay = 1, -+ .rxdelay = 5, -+ .ability = { -+ .force_mode = 1, -+ .txpause = 1, -+ .rxpause = 1, -+ .link = 1, -+ .duplex = 1, -+ .speed = RTL8367_PORT_SPEED_1000, -+ }, -+}; -+ -+static struct rtl8367_platform_data nb6_rtl8367_data = { -+ .gpio_sda = NB6_GPIO_RTL8367_SDA, -+ .gpio_sck = NB6_GPIO_RTL8367_SCK, -+ .extif0_cfg = &nb6_rtl8367_extif0_cfg, -+}; -+ -+static struct platform_device nb6_rtl8367_device = { -+ .name = RTL8367_DRIVER_NAME, -+ .id = -1, -+ .dev = { -+ .platform_data = &nb6_rtl8367_data, -+ } -+}; -+ -+static struct platform_device * __initdata nb6_devices[] = { -+ &nb6_rtl8367_device, -+}; -+ +static struct board_info __initdata board_nb6 = { + .name = "NB6", + .expected_cpu_id = 0x6362, @@ -80,16 +29,13 @@ + }, + }, + }, -+ -+ .devs = nb6_devices, -+ .num_devs = ARRAY_SIZE(nb6_devices), +}; +#endif /* CONFIG_BCM63XX_CPU_6362 */ + /* * known 6368 boards */ -@@ -1466,6 +1534,10 @@ static const struct board_info __initcon +@@ -1466,6 +1494,10 @@ static const struct board_info __initcon &board_DVAG3810BN, #endif @@ -100,7 +46,7 @@ #ifdef CONFIG_BCM63XX_CPU_6368 &board_96368mvwg, &board_96368mvngr, -@@ -1534,6 +1606,9 @@ static struct of_device_id const bcm963x +@@ -1534,6 +1566,9 @@ static struct of_device_id const bcm963x { .compatible = "t-com,spw303v", .data = &board_spw303v, }, { .compatible = "telsey,cpva642", .data = &board_CPVA642, }, #endif |