Received: by 2002:a05:6358:4e97:b0:b3:742d:4702 with SMTP id ce23csp1865522rwb; Fri, 19 Aug 2022 10:40:36 -0700 (PDT) X-Google-Smtp-Source: AA6agR45F1qkgy8/cMLrg0zlf8LqvV4m9HzKxqJfxzWJiIVxmziR6M2ApTzPD29KfWagEkcWwO96 X-Received: by 2002:a17:907:2ccb:b0:730:aaca:fc10 with SMTP id hg11-20020a1709072ccb00b00730aacafc10mr5594731ejc.153.1660930835769; Fri, 19 Aug 2022 10:40:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1660930835; cv=none; d=google.com; s=arc-20160816; b=EYWRR8EYtHAdHW/cw+Nh1c6BrAQ7zIbOZzuPkmSDhXlLz0EXY0o3y+CbG5ONecf9ih Olvl/fVp350V0pMPq4hLnYlCzdpsJ+6MVBrC7dYg+tp1LUhDjt4t3zqOyMZcRljI9mAB Mn4s+StnToD22kjG867x3nA+EzRL9us6mRqAgVKl9Q1fEGDimdoA/gwFTczjFGjajuPj 6s/RYKW73hPfXV+/D5xpq/szsS6/EhCM00gEzHoDJY87NBE8dWe+wurzplNzv7+RyDDD DIESyOSzIA2dFBiGvSh/Mswg/0BQhKXXfO8QgFVd8+NKOm2Vd2OSzGF+PkC7XUlaKczG +OYg== 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=UDbe4GRjl5xp11xeGoZrkxoZNLlH1YPoTljK4GD9AH8=; b=W0h+3HgeVgSoFBl2V6SQmqURtY7bW6FwZvPharxMggIXKRex+OuOYiDY11f0aeIHlF 675wyt5/cg7d0monbbgU5/VVq+KO+UghtLDYL3VljkwxOhUgrECy1uhT7hpepX9Y2Y19 pdeqghWR+C3/nSxRi7BatuUv6L613Vfe2CBh84cldZGZPHqDoyJ+PdS3iaiww+ntaJIY SrwMe9Pqt10lepgVjNCCCdKSaauZnZhOxgi0CDojmjf7dXOOB4Y6bThhaTt7wv8sbza1 cO9PESKlxMcOJRDax3VHAGtNQ76Paxphv9w572KQusanEInYxMF2SPv4BKDpEEXj08Fa pR0Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=A1g6IFMv; 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 o14-20020a056402438e00b0043d476f96c1si4056071edc.86.2022.08.19.10.40.08; Fri, 19 Aug 2022 10:40:35 -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=A1g6IFMv; 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 S1350325AbiHSPyM (ORCPT + 99 others); Fri, 19 Aug 2022 11:54:12 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40980 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1350548AbiHSPx0 (ORCPT ); Fri, 19 Aug 2022 11:53:26 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 26889104B3A; Fri, 19 Aug 2022 08:49:14 -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 ams.source.kernel.org (Postfix) with ESMTPS id 877B4B8280F; Fri, 19 Aug 2022 15:49:13 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id C99D1C433C1; Fri, 19 Aug 2022 15:49:11 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1660924152; bh=1UqnW2Xqw0WuyU18/hUB7OjVcVCOS70Xm3MNH5+JMew=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=A1g6IFMv3qyhAasE3VZkkAQ82Z7yZXEe3bRyriKTv6sVuKeu7VIP+0SfzhHXp0C/Z DYVnQL8peWU41QyjvlliEgARF7HtxUNwHyKfPN9gqUSi1dLkJYeiF4hgO7WkqUDqqI lrgt3Ani8faiMDalUGvsC37GD8iUgwHU/OlUyV5A= 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.10 073/545] netfilter: nf_tables: do not allow CHAIN_ID to refer to another table Date: Fri, 19 Aug 2022 17:37:23 +0200 Message-Id: <20220819153832.533116527@linuxfoundation.org> X-Mailer: git-send-email 2.37.2 In-Reply-To: <20220819153829.135562864@linuxfoundation.org> References: <20220819153829.135562864@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 @@ -2265,6 +2265,7 @@ err: } static struct nft_chain *nft_chain_lookup_byid(const struct net *net, + const struct nft_table *table, const struct nlattr *nla) { u32 id = ntohl(nla_get_be32(nla)); @@ -2274,6 +2275,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; } @@ -3199,7 +3201,7 @@ static int nf_tables_newrule(struct net 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); @@ -8671,7 +8673,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);