From: Pablo Neira Ayuso Date: Wed, 14 Jun 2023 21:20:18 +0000 (+0200) Subject: netfilter: nf_tables: drop module reference after updating chain X-Git-Tag: dma-mapping-6.6-2023-08-29~398^2^2~2 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=043d2acf57227db1fdaaa620b2a420acfaa56d6e;p=users%2Fhch%2Fdma-mapping.git netfilter: nf_tables: drop module reference after updating chain Otherwise the module reference counter is leaked. Fixes b9703ed44ffb ("netfilter: nf_tables: support for adding new devices to an existing netdev chain") Signed-off-by: Pablo Neira Ayuso --- diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c index 0d293eab310b..c1db2f4b2aa4 100644 --- a/net/netfilter/nf_tables_api.c +++ b/net/netfilter/nf_tables_api.c @@ -2667,6 +2667,8 @@ static int nf_tables_updchain(struct nft_ctx *ctx, u8 genmask, u8 policy, nft_trans_basechain(trans) = basechain; INIT_LIST_HEAD(&nft_trans_chain_hooks(trans)); list_splice(&hook.list, &nft_trans_chain_hooks(trans)); + if (nla[NFTA_CHAIN_HOOK]) + module_put(hook.type->owner); nft_trans_commit_list_add_tail(ctx->net, trans);