From: françois romieu Date: Fri, 2 Mar 2012 04:43:14 +0000 (+0000) Subject: r8169: corrupted IP fragments fix for large mtu. X-Git-Tag: v2.6.39-400.9.0~423^2~19^2~11^2~13 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=94ab75e3a5f376f93b211a198bd324f9eaeaff4a;p=users%2Fjedix%2Flinux-maple.git r8169: corrupted IP fragments fix for large mtu. Noticed with the 8168d (-vb-gr, aka RTL_GIGA_MAC_VER_26). ConfigX registers should only be written while the Config9346 lock is held. (cherry picked from commit 9c5028e9da1255dd2b99762d8627b88b29f68cce) Signed-off-by: Francois Romieu Reported-by: Nick Bowler Cc: Hayes Wang Signed-off-by: David S. Miller Signed-off-by: Joe Jin --- diff --git a/drivers/net/r8169.c b/drivers/net/r8169.c index e58f42b51fc1..e50e02e5e213 100644 --- a/drivers/net/r8169.c +++ b/drivers/net/r8169.c @@ -3831,12 +3831,20 @@ static void rtl8169_init_ring_indexes(struct rtl8169_private *tp) static void rtl_hw_jumbo_enable(struct rtl8169_private *tp) { + void __iomem *ioaddr = tp->mmio_addr; + + RTL_W8(Cfg9346, Cfg9346_Unlock); rtl_generic_op(tp, tp->jumbo_ops.enable); + RTL_W8(Cfg9346, Cfg9346_Lock); } static void rtl_hw_jumbo_disable(struct rtl8169_private *tp) { + void __iomem *ioaddr = tp->mmio_addr; + + RTL_W8(Cfg9346, Cfg9346_Unlock); rtl_generic_op(tp, tp->jumbo_ops.disable); + RTL_W8(Cfg9346, Cfg9346_Lock); } static void r8168c_hw_jumbo_enable(struct rtl8169_private *tp)