|
Jiri Wiesner |
c50ecf |
From 70f87de9fa0d454c5c176876fe5d5f6a7bb1fe9d Mon Sep 17 00:00:00 2001
|
|
Jiri Wiesner |
c50ecf |
From: Eric Dumazet <edumazet@google.com>
|
|
Jiri Wiesner |
c50ecf |
Date: Fri, 13 May 2022 11:55:47 -0700
|
|
Jiri Wiesner |
c50ecf |
Subject: [PATCH] net_sched: em_meta: add READ_ONCE() in var_sk_bound_if()
|
|
Jiri Wiesner |
c50ecf |
Git-commit: 70f87de9fa0d454c5c176876fe5d5f6a7bb1fe9d
|
|
Jiri Wiesner |
c50ecf |
Patch-mainline: v5.19-rc1
|
|
Jiri Wiesner |
c50ecf |
References: bsc#1207361
|
|
Jiri Wiesner |
c50ecf |
|
|
Jiri Wiesner |
c50ecf |
sk->sk_bound_dev_if can change under us, use READ_ONCE() annotation.
|
|
Jiri Wiesner |
c50ecf |
|
|
Jiri Wiesner |
c50ecf |
Signed-off-by: Eric Dumazet <edumazet@google.com>
|
|
Jiri Wiesner |
c50ecf |
Signed-off-by: David S. Miller <davem@davemloft.net>
|
|
Jiri Wiesner |
c50ecf |
Signed-off-by: Jiri Wiesner <jwiesner@suse.de>
|
|
Jiri Wiesner |
c50ecf |
---
|
|
Jiri Wiesner |
c50ecf |
net/sched/em_meta.c | 7 +++++--
|
|
Jiri Wiesner |
c50ecf |
1 file changed, 5 insertions(+), 2 deletions(-)
|
|
Jiri Wiesner |
c50ecf |
|
|
Jiri Wiesner |
c50ecf |
diff --git a/net/sched/em_meta.c b/net/sched/em_meta.c
|
|
Jiri Wiesner |
c50ecf |
index 0a04468b7314..49bae3d5006b 100644
|
|
Jiri Wiesner |
c50ecf |
--- a/net/sched/em_meta.c
|
|
Jiri Wiesner |
c50ecf |
+++ b/net/sched/em_meta.c
|
|
Jiri Wiesner |
c50ecf |
@@ -311,12 +311,15 @@ META_COLLECTOR(int_sk_bound_if)
|
|
Jiri Wiesner |
c50ecf |
|
|
Jiri Wiesner |
c50ecf |
META_COLLECTOR(var_sk_bound_if)
|
|
Jiri Wiesner |
c50ecf |
{
|
|
Jiri Wiesner |
c50ecf |
+ int bound_dev_if;
|
|
Jiri Wiesner |
c50ecf |
+
|
|
Jiri Wiesner |
c50ecf |
if (skip_nonlocal(skb)) {
|
|
Jiri Wiesner |
c50ecf |
*err = -1;
|
|
Jiri Wiesner |
c50ecf |
return;
|
|
Jiri Wiesner |
c50ecf |
}
|
|
Jiri Wiesner |
c50ecf |
|
|
Jiri Wiesner |
c50ecf |
- if (skb->sk->sk_bound_dev_if == 0) {
|
|
Jiri Wiesner |
c50ecf |
+ bound_dev_if = READ_ONCE(skb->sk->sk_bound_dev_if);
|
|
Jiri Wiesner |
c50ecf |
+ if (bound_dev_if == 0) {
|
|
Jiri Wiesner |
c50ecf |
dst->value = (unsigned long) "any";
|
|
Jiri Wiesner |
c50ecf |
dst->len = 3;
|
|
Jiri Wiesner |
c50ecf |
} else {
|
|
Jiri Wiesner |
c50ecf |
@@ -324,7 +327,7 @@ META_COLLECTOR(var_sk_bound_if)
|
|
Jiri Wiesner |
c50ecf |
|
|
Jiri Wiesner |
c50ecf |
rcu_read_lock();
|
|
Jiri Wiesner |
c50ecf |
dev = dev_get_by_index_rcu(sock_net(skb->sk),
|
|
Jiri Wiesner |
c50ecf |
- skb->sk->sk_bound_dev_if);
|
|
Jiri Wiesner |
c50ecf |
+ bound_dev_if);
|
|
Jiri Wiesner |
c50ecf |
*err = var_dev(dev, dst);
|
|
Jiri Wiesner |
c50ecf |
rcu_read_unlock();
|
|
Jiri Wiesner |
c50ecf |
}
|
|
Jiri Wiesner |
c50ecf |
--
|
|
Jiri Wiesner |
c50ecf |
2.35.3
|
|
Jiri Wiesner |
c50ecf |
|