Blame SOURCES/CVE-2021-3715.patch

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