From 1f991bb365b1ee66846e0785dc36dd5914f83398 Mon Sep 17 00:00:00 2001 From: Hauke Mehrtens Date: Sun, 2 Jul 2017 14:12:45 +0200 Subject: brcm47xx: Add support for kernel 4.9 I tested this on a WRT54GS and a WRT610N V1. The WRT610N does not boot when the kernel is too big, so I deactivated KALLSYMS Signed-off-by: Hauke Mehrtens --- .../brcm47xx/patches-4.9/791-tg3-no-pci-sleep.patch | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) create mode 100644 target/linux/brcm47xx/patches-4.9/791-tg3-no-pci-sleep.patch (limited to 'target/linux/brcm47xx/patches-4.9/791-tg3-no-pci-sleep.patch') diff --git a/target/linux/brcm47xx/patches-4.9/791-tg3-no-pci-sleep.patch b/target/linux/brcm47xx/patches-4.9/791-tg3-no-pci-sleep.patch new file mode 100644 index 0000000000..584cb40702 --- /dev/null +++ b/target/linux/brcm47xx/patches-4.9/791-tg3-no-pci-sleep.patch @@ -0,0 +1,17 @@ +When the Ethernet controller is powered down and someone wants to +access the mdio bus like the witch driver (b53) the system crashed if +PCI_D3hot was set before. This patch deactivates this power sawing mode +when a switch driver is in use. + +--- a/drivers/net/ethernet/broadcom/tg3.c ++++ b/drivers/net/ethernet/broadcom/tg3.c +@@ -4261,7 +4261,8 @@ static int tg3_power_down_prepare(struct + static void tg3_power_down(struct tg3 *tp) + { + pci_wake_from_d3(tp->pdev, tg3_flag(tp, WOL_ENABLE)); +- pci_set_power_state(tp->pdev, PCI_D3hot); ++ if (!tg3_flag(tp, ROBOSWITCH)) ++ pci_set_power_state(tp->pdev, PCI_D3hot); + } + + static void tg3_aux_stat_to_speed_duplex(struct tg3 *tp, u32 val, u16 *speed, u8 *duplex) -- cgit v1.2.3