Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp3284847ybb; Tue, 31 Mar 2020 02:05:33 -0700 (PDT) X-Google-Smtp-Source: ADFU+vv+tAeoZipWmWiDJEzWNoqHSRXrbcmhYHU4wss9ECvS5unRJ99BDPFQtimcZ+mgl/mq/vj0 X-Received: by 2002:a4a:df05:: with SMTP id i5mr7634244oou.9.1585645533818; Tue, 31 Mar 2020 02:05:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585645533; cv=none; d=google.com; s=arc-20160816; b=VLJpOEvdNKw8oyjmGPq10+n/tG2KXSHC9qeGllfy8gx2jh7G2QzgCey7EN8CL0Fhl/ tpJW9i0Mkjlnx6mzm9hLAOKbY6kjfdvUz5LuQaMInWnPmlAxfLwnRO05p8VlzmUDRyeO HA1R2muioxJGGvA1TEpDaz/wh6VF4hKf3h/kSnXUSGGhEhoGuIQcBHM2Bol7ZNyjkuEx yo6Z5x2CzvQrTDcRL+1//j4f0ZeW+ft0C4Dwg/mNPf3XsDBlZ+T8sXHspY2pbeN6l9g9 Ad+JgtdEiOsFZTOiqgFBSx82IkkvhmwW39/EEQEXypVWcj8EE6eajkj6XCtYnkbYm0n5 0vHg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=4pmC0oDvHucolwbUHh9NpRzjIGumVo6jLqWUVyaSqKA=; b=J72fCchizxaeisHKx9Jwoi+yay4hpsgh4C+l0/2h+EWvNMjN0m6mZTWU3vBtSR07B6 uexmzzM3oR+TaAS8ve0ftgdSqtuxrevcJVbzKSenzZobvYNC9xaSNKhmb7myJnSyoLqx DNSw9BofZKctRvX/sMoxvbz0lAv3AaAubqSBhozEIttQ7PXjSsdgGeM0/a1ARPzEjH/x Qk6fzNsCHTciPrEMPPvhh/qojdbNy9CkNgNNnBjP4onrVzNaQRAWD3jx1MTCdKSjw2QJ FkHbFnqp1hIt7cVwCQHfuSSW/r6kfVYmnYbfZV3VXRO1r49y5Odcoz0rzW1Q/oo7QAL4 EJcg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="weBqK/1f"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 63si7538404otm.66.2020.03.31.02.05.21; Tue, 31 Mar 2020 02:05:33 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="weBqK/1f"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730920AbgCaJEK (ORCPT + 99 others); Tue, 31 Mar 2020 05:04:10 -0400 Received: from mail.kernel.org ([198.145.29.99]:43928 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730469AbgCaJEG (ORCPT ); Tue, 31 Mar 2020 05:04:06 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 8DEFF2137B; Tue, 31 Mar 2020 09:04:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1585645446; bh=S092gFVFtOYE7P8NHrfnFQpRTJsmjesAJzX7X3rp8K8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=weBqK/1fkHR8YVO8E24wCdqszMZhxC0iMyXRpoQPdaYp+gAAHBYjEaPPx5PBQ6XYs MALcvqCEMsKylB71RyNDv5P7U4LJpdR7q0eoXjb/UFiZ6ovAtFEZOhctyNbykWCwvk LNrDhm+xPot/2+sOTc8GjyEiOb33FfH48EUNtvIU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jamal Hadi Salim , Jiri Pirko , John Fastabend , Cong Wang , "David S. Miller" , syzbot+f9b32aaacd60305d9687@syzkaller.appspotmail.com, syzbot+2f8c233f131943d6056d@syzkaller.appspotmail.com, syzbot+9c2df9fd5e9445b74e01@syzkaller.appspotmail.com Subject: [PATCH 5.5 029/170] net_sched: cls_route: remove the right filter from hashtable Date: Tue, 31 Mar 2020 10:57:23 +0200 Message-Id: <20200331085427.181960701@linuxfoundation.org> X-Mailer: git-send-email 2.26.0 In-Reply-To: <20200331085423.990189598@linuxfoundation.org> References: <20200331085423.990189598@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Cong Wang [ Upstream commit ef299cc3fa1a9e1288665a9fdc8bff55629fd359 ] route4_change() allocates a new filter and copies values from the old one. After the new filter is inserted into the hash table, the old filter should be removed and freed, as the final step of the update. However, the current code mistakenly removes the new one. This looks apparently wrong to me, and it causes double "free" and use-after-free too, as reported by syzbot. Reported-and-tested-by: syzbot+f9b32aaacd60305d9687@syzkaller.appspotmail.com Reported-and-tested-by: syzbot+2f8c233f131943d6056d@syzkaller.appspotmail.com Reported-and-tested-by: syzbot+9c2df9fd5e9445b74e01@syzkaller.appspotmail.com Fixes: 1109c00547fc ("net: sched: RCU cls_route") Cc: Jamal Hadi Salim Cc: Jiri Pirko Cc: John Fastabend Signed-off-by: Cong Wang Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- net/sched/cls_route.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) --- a/net/sched/cls_route.c +++ b/net/sched/cls_route.c @@ -534,8 +534,8 @@ static int route4_change(struct net *net fp = &b->ht[h]; for (pfp = rtnl_dereference(*fp); pfp; fp = &pfp->next, pfp = rtnl_dereference(*fp)) { - if (pfp == f) { - *fp = f->next; + if (pfp == fold) { + rcu_assign_pointer(*fp, fold->next); break; } }