From: Eric Dumazet Date: Fri, 13 May 2022 18:55:47 +0000 (-0700) Subject: net_sched: em_meta: add READ_ONCE() in var_sk_bound_if() X-Git-Tag: v6.1-rc5~1274^2~107^2~3 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=70f87de9fa0d454c5c176876fe5d5f6a7bb1fe9d;p=platform%2Fkernel%2Flinux-starfive.git net_sched: em_meta: add READ_ONCE() in var_sk_bound_if() sk->sk_bound_dev_if can change under us, use READ_ONCE() annotation. Signed-off-by: Eric Dumazet Signed-off-by: David S. Miller --- diff --git a/net/sched/em_meta.c b/net/sched/em_meta.c index 0a04468..49bae3d 100644 --- a/net/sched/em_meta.c +++ b/net/sched/em_meta.c @@ -311,12 +311,15 @@ META_COLLECTOR(int_sk_bound_if) META_COLLECTOR(var_sk_bound_if) { + int bound_dev_if; + if (skip_nonlocal(skb)) { *err = -1; return; } - if (skb->sk->sk_bound_dev_if == 0) { + bound_dev_if = READ_ONCE(skb->sk->sk_bound_dev_if); + if (bound_dev_if == 0) { dst->value = (unsigned long) "any"; dst->len = 3; } else { @@ -324,7 +327,7 @@ META_COLLECTOR(var_sk_bound_if) rcu_read_lock(); dev = dev_get_by_index_rcu(sock_net(skb->sk), - skb->sk->sk_bound_dev_if); + bound_dev_if); *err = var_dev(dev, dst); rcu_read_unlock(); }