|
|
eaa7e1 |
From: Artem Savkov <asavkov@redhat.com>
|
|
|
eaa7e1 |
Subject: [RHEL-7.9 CVE-2021-3715 KPATCH] net_sched: cls_route: remove the right filter from hashtable
|
|
|
eaa7e1 |
Date: Mon, 30 Aug 2021 17:33:51 +0200
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
Kernels:
|
|
|
eaa7e1 |
3.10.0-1160.el7
|
|
|
eaa7e1 |
3.10.0-1160.2.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.2.2.el7
|
|
|
eaa7e1 |
3.10.0-1160.6.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.11.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.15.2.el7
|
|
|
eaa7e1 |
3.10.0-1160.21.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.24.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.25.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.31.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.36.2.el7
|
|
|
eaa7e1 |
3.10.0-1160.41.1.el7
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
Changes since last build:
|
|
|
eaa7e1 |
arches: x86_64 ppc64le
|
|
|
eaa7e1 |
cls_route.o: changed function: route4_change
|
|
|
eaa7e1 |
---------------------------
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
Kernels:
|
|
|
eaa7e1 |
3.10.0-1160.el7
|
|
|
eaa7e1 |
3.10.0-1160.2.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.2.2.el7
|
|
|
eaa7e1 |
3.10.0-1160.6.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.11.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.15.2.el7
|
|
|
eaa7e1 |
3.10.0-1160.21.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.24.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.25.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.31.1.el7
|
|
|
eaa7e1 |
3.10.0-1160.36.2.el7
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
Modifications: none
|
|
|
eaa7e1 |
Z-MR: https://gitlab.com/redhat/rhel/src/kernel/rhel-7/-/merge_requests/251
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
commit f4e1814eb56167451ddd819fccb951178f97660b
|
|
|
eaa7e1 |
Author: Ivan Vecera <ivecera@redhat.com>
|
|
|
eaa7e1 |
Date: Tue Aug 17 12:21:33 2021 +0200
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
net_sched: cls_route: remove the right filter from hashtable
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
Bugzilla: https://bugzilla.redhat.com/show_bug.cgi?id=1992926
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
commit ef299cc3fa1a9e1288665a9fdc8bff55629fd359
|
|
|
eaa7e1 |
Author: Cong Wang <xiyou.wangcong@gmail.com>
|
|
|
eaa7e1 |
Date: Fri Mar 13 22:29:54 2020 -0700
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
net_sched: cls_route: remove the right filter from hashtable
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
route4_change() allocates a new filter and copies values from
|
|
|
eaa7e1 |
the old one. After the new filter is inserted into the hash
|
|
|
eaa7e1 |
table, the old filter should be removed and freed, as the final
|
|
|
eaa7e1 |
step of the update.
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
However, the current code mistakenly removes the new one. This
|
|
|
eaa7e1 |
looks apparently wrong to me, and it causes double "free" and
|
|
|
eaa7e1 |
use-after-free too, as reported by syzbot.
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
Reported-and-tested-by: syzbot+f9b32aaacd60305d9687@syzkaller.appspotmail.com
|
|
|
eaa7e1 |
Reported-and-tested-by: syzbot+2f8c233f131943d6056d@syzkaller.appspotmail.com
|
|
|
eaa7e1 |
Reported-and-tested-by: syzbot+9c2df9fd5e9445b74e01@syzkaller.appspotmail.com
|
|
|
eaa7e1 |
Fixes: 1109c00547fc ("net: sched: RCU cls_route")
|
|
|
eaa7e1 |
Cc: Jamal Hadi Salim <jhs@mojatatu.com>
|
|
|
eaa7e1 |
Cc: Jiri Pirko <jiri@resnulli.us>
|
|
|
eaa7e1 |
Cc: John Fastabend <john.fastabend@gmail.com>
|
|
|
eaa7e1 |
Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com>
|
|
|
eaa7e1 |
Signed-off-by: David S. Miller <davem@davemloft.net>
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
Signed-off-by: Ivan Vecera <ivecera@redhat.com>
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
Signed-off-by: Artem Savkov <asavkov@redhat.com>
|
|
|
eaa7e1 |
Acked-by: Joe Lawrence <joe.lawrence@redhat.com>
|
|
|
eaa7e1 |
---
|
|
|
eaa7e1 |
net/sched/cls_route.c | 4 ++--
|
|
|
eaa7e1 |
1 file changed, 2 insertions(+), 2 deletions(-)
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
diff --git a/net/sched/cls_route.c b/net/sched/cls_route.c
|
|
|
eaa7e1 |
index 7bd464e8d084..2fed29fa504e 100644
|
|
|
eaa7e1 |
--- a/net/sched/cls_route.c
|
|
|
eaa7e1 |
+++ b/net/sched/cls_route.c
|
|
|
eaa7e1 |
@@ -534,8 +534,8 @@ static int route4_change(struct net *net, struct sk_buff *in_skb,
|
|
|
eaa7e1 |
fp = &b->ht[h];
|
|
|
eaa7e1 |
for (pfp = rtnl_dereference(*fp); pfp;
|
|
|
eaa7e1 |
fp = &pfp->next, pfp = rtnl_dereference(*fp)) {
|
|
|
eaa7e1 |
- if (pfp == f) {
|
|
|
eaa7e1 |
- *fp = f->next;
|
|
|
eaa7e1 |
+ if (pfp == fold) {
|
|
|
eaa7e1 |
+ rcu_assign_pointer(*fp, fold->next);
|
|
|
eaa7e1 |
break;
|
|
|
eaa7e1 |
}
|
|
|
eaa7e1 |
}
|
|
|
eaa7e1 |
--
|
|
|
eaa7e1 |
2.31.1
|
|
|
eaa7e1 |
|
|
|
eaa7e1 |
|