Received: by 2002:a05:6358:4e97:b0:b3:742d:4702 with SMTP id ce23csp2924676rwb; Mon, 15 Aug 2022 14:09:40 -0700 (PDT) X-Google-Smtp-Source: AA6agR6JzVCAxBXapB9XwKHAiVzXhoTHWqZQJb5A+7tcF0R9EBZqHsB0l8exP02GW4esu6eVXOUV X-Received: by 2002:a17:906:9c82:b0:6df:c5f0:d456 with SMTP id fj2-20020a1709069c8200b006dfc5f0d456mr11942910ejc.287.1660597779718; Mon, 15 Aug 2022 14:09:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1660597779; cv=none; d=google.com; s=arc-20160816; b=Qgsal7Ygrmv9PeLwG6UZ+eC5LsyuNxcSgjRl+pTbIyUSJZDugg5bvdd71xnBdEDi8E +ZjB74zRX4vHomvg/u8tny7zQIHYdz3yaZtmbYC1ul5XCCf6GlP3v0OrqMMpfs4GJGyd XAqoiGmJVVYvJkNwwiDlwmVuA3go4QKb3ZkWsKSagKg15+WV+uu6dACaMWil840Rgmnt VWGP4v1FbsZD7BOYX3CzPhUr/9ZYFup5G3ky8jhyrtNUMcd1Vd3Oey7ijo64y4zh3Y9f UcCMRZ6MgU+TPooHIP6tm6TYmYqyakrPfxQoeQQnAHswcCll0/H90vEj0KoQ+J8Ac8ps 8TVA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=33LqYscJNNhsKOTPDztFrK2ECgfyszAK7y52XNgLw7w=; b=mw9+4NVKfXdy6P2P5MnLXD7LgG/t9WtBHsjsZmQe6nf4zBU7Cvg5QMuRp5YusDcCKT SwRdOqXxqBRTfgBOY49c15na8Id95453GOS5emeezXxZYcAZH1WSxVMzxp0WLTtF7bmi rx7XsiFFh2BaAVQMIPt49wlbWXbcFjULYlCINjI7NKMIeKb/ioyJ6vkJZJTxr9SFn6Gn lu8Bjdx8hWvEamYanlKwbYtLmNlAvm6sN1bqj2jn/SsEvh5Vn4m35ZJv+gKjC5IHFB9j M3vulAwF2g0NJI52nHbITzqzvoLLcohTL1mkdypDFBMusaZHrAuD2CWb7BVhJ5dKrYYs DjUw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=h3VGVVMw; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id ga14-20020a1709070c0e00b007317e0f2b71si9481950ejc.256.2022.08.15.14.09.14; Mon, 15 Aug 2022 14:09:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=h3VGVVMw; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344437AbiHOU3h (ORCPT + 99 others); Mon, 15 Aug 2022 16:29:37 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49442 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1347309AbiHOUWP (ORCPT ); Mon, 15 Aug 2022 16:22:15 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2181333A3B; Mon, 15 Aug 2022 12:02:19 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id B1B8461281; Mon, 15 Aug 2022 19:02:18 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 9C88DC433D6; Mon, 15 Aug 2022 19:02:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1660590138; bh=KXsiz/clbAFn5tBxvwlcvQAnIlwUuukB5cDniMj0fBY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=h3VGVVMwGUaW8RuWvSZu+uCfTIG+ghJKjTUlyLhp1CNN/68vX+8OeLwhW2TOnFUgD a3KP1cjKBieGsmmHGga4OKkPAMOQqAYS6MUaHSrF6BXQBz++3kpHPDCt/k/254p3LP YBDPH6HzvSLcb5J5ngGAcdYCzDJBz6Qlai/bgaX0= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Thadeu Lima de Souza Cascardo , Pablo Neira Ayuso Subject: [PATCH 5.18 0131/1095] netfilter: nf_tables: do not allow CHAIN_ID to refer to another table Date: Mon, 15 Aug 2022 19:52:10 +0200 Message-Id: <20220815180434.997918368@linuxfoundation.org> X-Mailer: git-send-email 2.37.2 In-Reply-To: <20220815180429.240518113@linuxfoundation.org> References: <20220815180429.240518113@linuxfoundation.org> User-Agent: quilt/0.67 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Thadeu Lima de Souza Cascardo commit 95f466d22364a33d183509629d0879885b4f547e upstream. When doing lookups for chains on the same batch by using its ID, a chain from a different table can be used. If a rule is added to a table but refers to a chain in a different table, it will be linked to the chain in table2, but would have expressions referring to objects in table1. Then, when table1 is removed, the rule will not be removed as its linked to a chain in table2. When expressions in the rule are processed or removed, that will lead to a use-after-free. When looking for chains by ID, use the table that was used for the lookup by name, and only return chains belonging to that same table. Fixes: 837830a4b439 ("netfilter: nf_tables: add NFTA_RULE_CHAIN_ID attribute") Signed-off-by: Thadeu Lima de Souza Cascardo Cc: Signed-off-by: Pablo Neira Ayuso Signed-off-by: Greg Kroah-Hartman --- net/netfilter/nf_tables_api.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) --- a/net/netfilter/nf_tables_api.c +++ b/net/netfilter/nf_tables_api.c @@ -2472,6 +2472,7 @@ err: } static struct nft_chain *nft_chain_lookup_byid(const struct net *net, + const struct nft_table *table, const struct nlattr *nla) { struct nftables_pernet *nft_net = nft_pernet(net); @@ -2482,6 +2483,7 @@ static struct nft_chain *nft_chain_looku struct nft_chain *chain = trans->ctx.chain; if (trans->msg_type == NFT_MSG_NEWCHAIN && + chain->table == table && id == nft_trans_chain_id(trans)) return chain; } @@ -3415,7 +3417,7 @@ static int nf_tables_newrule(struct sk_b return -EOPNOTSUPP; } else if (nla[NFTA_RULE_CHAIN_ID]) { - chain = nft_chain_lookup_byid(net, nla[NFTA_RULE_CHAIN_ID]); + chain = nft_chain_lookup_byid(net, table, nla[NFTA_RULE_CHAIN_ID]); if (IS_ERR(chain)) { NL_SET_BAD_ATTR(extack, nla[NFTA_RULE_CHAIN_ID]); return PTR_ERR(chain); @@ -9597,7 +9599,7 @@ static int nft_verdict_init(const struct tb[NFTA_VERDICT_CHAIN], genmask); } else if (tb[NFTA_VERDICT_CHAIN_ID]) { - chain = nft_chain_lookup_byid(ctx->net, + chain = nft_chain_lookup_byid(ctx->net, ctx->table, tb[NFTA_VERDICT_CHAIN_ID]); if (IS_ERR(chain)) return PTR_ERR(chain);