Received: by 2002:a17:90a:1609:0:0:0:0 with SMTP id n9csp841585pja; Wed, 1 Apr 2020 09:40:16 -0700 (PDT) X-Google-Smtp-Source: APiQypIlRU5UGN9DofA9v+LBlMdx4SgKRd0Mv918QcnmrpEKHeg/EeOW7HR5AcG9yM0BPir/NvqX X-Received: by 2002:a05:6808:485:: with SMTP id z5mr3393699oid.78.1585759216756; Wed, 01 Apr 2020 09:40:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585759216; cv=none; d=google.com; s=arc-20160816; b=oIAbVLqv+oFq5hQ+pRKn5w3eD2j4cEn/t00CSa70M+1T6dTRdFcsNSkBlPRg3UVj8c fUHTmmTOp773naXRWdgl2O4gNWMvIEeGtgyX4PHAzJtHlblH/JMCCBtsFjBiCKy+7ohC mZdbmlST073yex71V/EBQmCZ2mTN1sikJFViLFrTKvAXziQ22zIAX0DbIXz0Deuq7QDq uia90oFlsGer6FOfC7EBQbeYI7jNdomsk6o8Sd+sAjIllwdUOWfLt/ZRqIV8PMEmWcP1 +qu6gKET/8j5qryQFUFXuROfSZ2ebBr61ZO4EmWWNktn5Xmt8jglVIlPmp055gJ9Cr8y GmnQ== 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=ZRBhk/6MF0E1mhjJcI/4yOrkeEdqOi73KHWrdIHslZQ=; b=sgj20MAm7GcA7fBuBFckUkycCVUT8j6AY3lDxA7B5K9D6P1k+4HM2GQjbwayLuv8lx enzSvBTCaR11C73EmKInkD+nEUVVYJ8xbXGD1qIR0tWKuQS70m7BwMuibAzITwQxaINu xHmrSykoHRK2zs5HOB/CR9lsJKF80S96t0p0md93O7l+IWZDHZXtSYwTySIqj86U0LK1 43CRv+q7KdcvUBfzOMAXY2HPiTZuHrmSWtIVehZFIj/I4Jikgly6x0Fu0RcPEOjGVmp8 yEpuQub97mCcYCT+wLbO4qm/Tt0+QwBc6DhEXbX6obzWP98lnbmO8p3WBxeDR05/Mpwp gq/A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="WF/3PfwF"; 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 l9si1033849otf.51.2020.04.01.09.40.03; Wed, 01 Apr 2020 09:40:16 -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="WF/3PfwF"; 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 S2388115AbgDAQi3 (ORCPT + 99 others); Wed, 1 Apr 2020 12:38:29 -0400 Received: from mail.kernel.org ([198.145.29.99]:38170 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732169AbgDAQi1 (ORCPT ); Wed, 1 Apr 2020 12:38:27 -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 2F424212CC; Wed, 1 Apr 2020 16:38:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1585759106; bh=zRZCiOpv/kmMlJxQeyRwH+7szgYRurWO+1olXjkYMTU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=WF/3PfwFXtyRj3HIjx/p1YLDPRp/bfZREr4hTBdP/teyxweL46cTT9y9EP9OSywM2 m9qo9VQXBfQPU2Oh4LyLjJwLYiu3OOy6ShCtUsHpuO1HV6Vi/+V9QtgB2QrtaA6BZb ufWj82AKbFX03jUKsaG1WrSskPMyQYvtAbVIhPKA= 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 4.9 041/102] net_sched: cls_route: remove the right filter from hashtable Date: Wed, 1 Apr 2020 18:17:44 +0200 Message-Id: <20200401161540.504958837@linuxfoundation.org> X-Mailer: git-send-email 2.26.0 In-Reply-To: <20200401161530.451355388@linuxfoundation.org> References: <20200401161530.451355388@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 @@ -542,8 +542,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; } }