Commit a4b58f97 authored by Eric Dumazet's avatar Eric Dumazet Committed by Ben Hutchings

dummy: fix rcu_sched self-detected stalls

[ Upstream commit 16b0dc29 ]

Trying to "modprobe dummy numdummies=30000" triggers :

INFO: rcu_sched self-detected stall on CPU { 8} (t=60000 jiffies)

After this splat, RTNL is locked and reboot is needed.

We must call cond_resched() to avoid this, even holding RTNL.
Signed-off-by: default avatarEric Dumazet <edumazet@google.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent 14be9250
...@@ -37,6 +37,7 @@ ...@@ -37,6 +37,7 @@
#include <linux/rtnetlink.h> #include <linux/rtnetlink.h>
#include <net/rtnetlink.h> #include <net/rtnetlink.h>
#include <linux/u64_stats_sync.h> #include <linux/u64_stats_sync.h>
#include <linux/sched.h>
static int numdummies = 1; static int numdummies = 1;
...@@ -186,8 +187,10 @@ static int __init dummy_init_module(void) ...@@ -186,8 +187,10 @@ static int __init dummy_init_module(void)
rtnl_lock(); rtnl_lock();
err = __rtnl_link_register(&dummy_link_ops); err = __rtnl_link_register(&dummy_link_ops);
for (i = 0; i < numdummies && !err; i++) for (i = 0; i < numdummies && !err; i++) {
err = dummy_init_one(); err = dummy_init_one();
cond_resched();
}
if (err < 0) if (err < 0)
__rtnl_link_unregister(&dummy_link_ops); __rtnl_link_unregister(&dummy_link_ops);
rtnl_unlock(); rtnl_unlock();
......
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