Received: by 2002:a17:90a:1609:0:0:0:0 with SMTP id n9csp856610pja; Wed, 1 Apr 2020 09:55:55 -0700 (PDT) X-Google-Smtp-Source: ADFU+vtnXqDimTW1jzBrlkQs0Vf1TTwr18YBCdQyhGaCZv4SbIUo0lpYML593Mh+6vIe9PjqqJ2E X-Received: by 2002:a05:6830:168f:: with SMTP id k15mr18204547otr.346.1585760154975; Wed, 01 Apr 2020 09:55:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585760154; cv=none; d=google.com; s=arc-20160816; b=ERlUlEHzGdsrnVK8EtMWIzBEe678HzNLaopTusG0H6XxgtgorTIixKKZzj7sS9ofXm CwIZ56wuuTNs4lU+pgjTqfYsfdp9sM2voX3Xy3fdZuD9f3YV6aAB/2eXnLildha7Ogh/ TALj3tUsnRuUHQEn3y6KwFbEdaES+MeZuySrLBeZTy0YH2mS/08unQNW4ukHPX8WCz9J GHFYPheWx/GS7rt6/tCkJ2F0ecp8Ykjkkpg4ELaQsNE/xBcHBN/bnXgyxxfVYhiFF7+0 ofUb5kKkOf9whqX2FPdLHGObQs6+jJEJN3RWNa2XhoBu+JweQrgkHlg03IR93FN1qSKs al0Q== 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=lSdk6BEWyJpN1hFpb7r/l9YCGFAJy5uf7O2NIxUTeqc=; b=WvuNrsCon9+9W3KIBbvuI3Y1UFcx0ua0skgOKKc2szPoOh44TCAiwu5UNSe/VPwrIC dK0lYK6VhxY9ctXi7Lf9ZSq0xQwMpsZUtxDP4YuHRF2Cvzu11kqK1HtEEMroIJs1IxmZ +0WysM8nOBwKzykjDwVX7L4/w92puz/EIOYWOjtssH76sDpCCHdd0FYrMhIeRbY6ScKD gq0nfdeMlvWXX70JF2XUCMw0HzFhcKxiSsgBlzAz9bRCRfCBtVSBMi49+WU0t8485Fbk IBPUqK/KwH3u5f5RWOZz+3WuaLi7x/0Lh07wdCqD1AyEFQB7RmrJVIEu4Nqnydx4WIQ8 xaTg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=wlHMcy7j; 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.55.41; Wed, 01 Apr 2020 09:55:54 -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=wlHMcy7j; 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 S2388080AbgDAQbB (ORCPT + 99 others); Wed, 1 Apr 2020 12:31:01 -0400 Received: from mail.kernel.org ([198.145.29.99]:56998 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387768AbgDAQa6 (ORCPT ); Wed, 1 Apr 2020 12:30:58 -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 73A7D2137B; Wed, 1 Apr 2020 16:30:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1585758657; bh=FOmBWtWn6+3QgLUu7/ZRMJz1EGVdTZYZfjvklXBdgdU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=wlHMcy7jzqagMmZugur1G9yJ6oEH34QIm6AVLXgXRDcR4EbDA9afhl+RLEQKeiQPP iOwoECiBh8Dzt+mVb31anrE8QR3JJbipCQJF2j2Mt2FZyip7PsbVaavuW7h9ag9QTl rtlxUi9C7ZAKmLfwUAPFTz7NIZWGvPjaPnADf2lY= 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.4 36/91] net_sched: cls_route: remove the right filter from hashtable Date: Wed, 1 Apr 2020 18:17:32 +0200 Message-Id: <20200401161526.901169434@linuxfoundation.org> X-Mailer: git-send-email 2.26.0 In-Reply-To: <20200401161512.917494101@linuxfoundation.org> References: <20200401161512.917494101@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 @@ -540,8 +540,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; } }