diff options
author | Eric Dumazet <eric.dumazet@gmail.com> | 2010-09-23 21:46:03 +0000 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-09-26 19:04:07 -0700 |
commit | 83180af0b0ea166adf8249f4513beb7355f9b4c9 (patch) | |
tree | 4e2606d19e0e5be3e1fc1851a0294f163bfa8780 /net | |
parent | 1b4bf461f05d56ced6d6b8f3b4831adc7076f565 (diff) | |
download | talos-op-linux-83180af0b0ea166adf8249f4513beb7355f9b4c9.tar.gz talos-op-linux-83180af0b0ea166adf8249f4513beb7355f9b4c9.zip |
net: fix rcu use in ip_route_output_slow
__in_dev_get_rtnl(dev_out) is called while RTNL is not held, thus
triggers a lockdep fault.
At this point, we only perform a raw test of dev_out->ip_ptr being NULL,
we dont need to make sure ip_ptr cant changed right after.
We can use rcu_dereference_raw() for this.
Reported-by: Andrew Morton <akpm@linux-foundation.org>
Acked-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r-- | net/ipv4/route.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/ipv4/route.c b/net/ipv4/route.c index ae1d4a41f1c6..98beda47bc99 100644 --- a/net/ipv4/route.c +++ b/net/ipv4/route.c @@ -2579,7 +2579,7 @@ static int ip_route_output_slow(struct net *net, struct rtable **rp, goto out; /* RACE: Check return value of inet_select_addr instead. */ - if (__in_dev_get_rtnl(dev_out) == NULL) { + if (rcu_dereference_raw(dev_out->ip_ptr) == NULL) { dev_put(dev_out); goto out; /* Wrong error code */ } |