Commit 3f315bef authored by Veaceslav Falico's avatar Veaceslav Falico Committed by David S. Miller

netconsole: don't call __netpoll_cleanup() while atomic

__netpoll_cleanup() is called in netconsole_netdev_event() while holding a
spinlock. Release/acquire the spinlock before/after it and restart the
loop. Also, disable the netconsole completely, because we won't have chance
after the restart of the loop, and might end up in a situation where
nt->enabled == 1 and nt->np.dev == NULL.
Signed-off-by: default avatarVeaceslav Falico <vfalico@redhat.com>
Acked-by: default avatarNeil Horman <nhorman@tuxdriver.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 3da889b6
...@@ -666,6 +666,7 @@ static int netconsole_netdev_event(struct notifier_block *this, ...@@ -666,6 +666,7 @@ static int netconsole_netdev_event(struct notifier_block *this,
goto done; goto done;
spin_lock_irqsave(&target_list_lock, flags); spin_lock_irqsave(&target_list_lock, flags);
restart:
list_for_each_entry(nt, &target_list, list) { list_for_each_entry(nt, &target_list, list) {
netconsole_target_get(nt); netconsole_target_get(nt);
if (nt->np.dev == dev) { if (nt->np.dev == dev) {
...@@ -678,15 +679,17 @@ static int netconsole_netdev_event(struct notifier_block *this, ...@@ -678,15 +679,17 @@ static int netconsole_netdev_event(struct notifier_block *this,
case NETDEV_UNREGISTER: case NETDEV_UNREGISTER:
/* /*
* rtnl_lock already held * rtnl_lock already held
* we might sleep in __netpoll_cleanup()
*/ */
if (nt->np.dev) { spin_unlock_irqrestore(&target_list_lock, flags);
__netpoll_cleanup(&nt->np); __netpoll_cleanup(&nt->np);
dev_put(nt->np.dev); spin_lock_irqsave(&target_list_lock, flags);
nt->np.dev = NULL; dev_put(nt->np.dev);
} nt->np.dev = NULL;
nt->enabled = 0; nt->enabled = 0;
stopped = true; stopped = true;
break; netconsole_target_put(nt);
goto restart;
} }
} }
netconsole_target_put(nt); netconsole_target_put(nt);
......
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