aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKai-Heng Feng <kai.heng.feng@canonical.com>2018-09-10 13:51:43 -0400
committerDavid S. Miller <davem@davemloft.net>2018-09-12 03:05:33 -0400
commit6ad569019999300afd8e614d296fdc356550b77f (patch)
treea7a6ec1248a66f265fd71ee64358c3ac171e4e09
parent51dc63e3911fbb1f0a7a32da2fe56253e2040ea4 (diff)
r8169: Clear RTL_FLAG_TASK_*_PENDING when clearing RTL_FLAG_TASK_ENABLED
After system suspend, sometimes the r8169 doesn't work when ethernet cable gets pluggued. This issue happens because rtl_reset_work() doesn't get called from rtl8169_runtime_resume(), after system suspend. In rtl_task(), RTL_FLAG_TASK_* only gets cleared if this condition is met: if (!netif_running(dev) || !test_bit(RTL_FLAG_TASK_ENABLED, tp->wk.flags)) ... If RTL_FLAG_TASK_ENABLED was cleared during system suspend while RTL_FLAG_TASK_RESET_PENDING was set, the next rtl_schedule_task() won't schedule task as the flag is still there. So in addition to clearing RTL_FLAG_TASK_ENABLED, also clears other flags. Cc: Heiner Kallweit <hkallweit1@gmail.com> Signed-off-by: Kai-Heng Feng <kai.heng.feng@canonical.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--drivers/net/ethernet/realtek/r8169.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/drivers/net/ethernet/realtek/r8169.c b/drivers/net/ethernet/realtek/r8169.c
index a1f37d58e2fe..1d8631303b53 100644
--- a/drivers/net/ethernet/realtek/r8169.c
+++ b/drivers/net/ethernet/realtek/r8169.c
@@ -631,7 +631,7 @@ struct rtl8169_tc_offsets {
631}; 631};
632 632
633enum rtl_flag { 633enum rtl_flag {
634 RTL_FLAG_TASK_ENABLED, 634 RTL_FLAG_TASK_ENABLED = 0,
635 RTL_FLAG_TASK_SLOW_PENDING, 635 RTL_FLAG_TASK_SLOW_PENDING,
636 RTL_FLAG_TASK_RESET_PENDING, 636 RTL_FLAG_TASK_RESET_PENDING,
637 RTL_FLAG_MAX 637 RTL_FLAG_MAX
@@ -6655,7 +6655,8 @@ static int rtl8169_close(struct net_device *dev)
6655 rtl8169_update_counters(tp); 6655 rtl8169_update_counters(tp);
6656 6656
6657 rtl_lock_work(tp); 6657 rtl_lock_work(tp);
6658 clear_bit(RTL_FLAG_TASK_ENABLED, tp->wk.flags); 6658 /* Clear all task flags */
6659 bitmap_zero(tp->wk.flags, RTL_FLAG_MAX);
6659 6660
6660 rtl8169_down(dev); 6661 rtl8169_down(dev);
6661 rtl_unlock_work(tp); 6662 rtl_unlock_work(tp);
@@ -6838,7 +6839,9 @@ static void rtl8169_net_suspend(struct net_device *dev)
6838 6839
6839 rtl_lock_work(tp); 6840 rtl_lock_work(tp);
6840 napi_disable(&tp->napi); 6841 napi_disable(&tp->napi);
6841 clear_bit(RTL_FLAG_TASK_ENABLED, tp->wk.flags); 6842 /* Clear all task flags */
6843 bitmap_zero(tp->wk.flags, RTL_FLAG_MAX);
6844
6842 rtl_unlock_work(tp); 6845 rtl_unlock_work(tp);
6843 6846
6844 rtl_pll_power_down(tp); 6847 rtl_pll_power_down(tp);