aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/brcm47xx/patches-3.18/791-tg3-no-pci-sleep.patch
diff options
context:
space:
mode:
authorRafał Miłecki <zajec5@gmail.com>2014-10-28 10:26:00 +0000
committerRafał Miłecki <zajec5@gmail.com>2014-10-28 10:26:00 +0000
commitf4295bb051f52ba4887fad78eb00d0abc8e774cd (patch)
tree182bafe0bf3fbf8893ea7643304b1868e8dc60ce /target/linux/brcm47xx/patches-3.18/791-tg3-no-pci-sleep.patch
parent43076c19c25e00cea9b2df5a25c49b85b4f27acc (diff)
downloadmaster-187ad058-f4295bb051f52ba4887fad78eb00d0abc8e774cd.tar.gz
master-187ad058-f4295bb051f52ba4887fad78eb00d0abc8e774cd.tar.bz2
master-187ad058-f4295bb051f52ba4887fad78eb00d0abc8e774cd.zip
brcm47xx: initial support for kernel 3.18
Signed-off-by: Rafał Miłecki <zajec5@gmail.com> git-svn-id: svn://svn.openwrt.org/openwrt/trunk@43100 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/brcm47xx/patches-3.18/791-tg3-no-pci-sleep.patch')
-rw-r--r--target/linux/brcm47xx/patches-3.18/791-tg3-no-pci-sleep.patch17
1 files changed, 17 insertions, 0 deletions
diff --git a/target/linux/brcm47xx/patches-3.18/791-tg3-no-pci-sleep.patch b/target/linux/brcm47xx/patches-3.18/791-tg3-no-pci-sleep.patch
new file mode 100644
index 0000000000..35a816d8c2
--- /dev/null
+++ b/target/linux/brcm47xx/patches-3.18/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
+@@ -4263,7 +4263,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)