Commit 8b638160 authored by Taehee Yoo's avatar Taehee Yoo Committed by David S. Miller

ixgbe: fix possible deadlock in ixgbe_service_task()

ixgbe_service_task() calls unregister_netdev() under rtnl_lock().
But unregister_netdev() internally calls rtnl_lock().
So deadlock would occur.

Fixes: 59dd45d5 ("ixgbe: firmware recovery mode")
Signed-off-by: default avatarTaehee Yoo <ap420073@gmail.com>
Tested-by: default avatarAndrew Bowers <andrewx.bowers@intel.com>
Signed-off-by: default avatarJeff Kirsher <jeffrey.t.kirsher@intel.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 703acf62
...@@ -7897,11 +7897,8 @@ static void ixgbe_service_task(struct work_struct *work) ...@@ -7897,11 +7897,8 @@ static void ixgbe_service_task(struct work_struct *work)
return; return;
} }
if (ixgbe_check_fw_error(adapter)) { if (ixgbe_check_fw_error(adapter)) {
if (!test_bit(__IXGBE_DOWN, &adapter->state)) { if (!test_bit(__IXGBE_DOWN, &adapter->state))
rtnl_lock();
unregister_netdev(adapter->netdev); unregister_netdev(adapter->netdev);
rtnl_unlock();
}
ixgbe_service_event_complete(adapter); ixgbe_service_event_complete(adapter);
return; return;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment