netfilter: nf_tables: do not leave chain stats enabled on error
[ Upstream commit 43eb8949cfdffa764b92bc6c54b87cbe5b0003fe ]
Error might occur later in the nf_tables_addchain() codepath, enable
static key only after transaction has been created.
Fixes: 9f08ea8481
("netfilter: nf_tables: keep chain counters away from hot path")
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
ea358cfc8e
commit
c907dfe4ea
@@ -1999,9 +1999,9 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,
|
|||||||
u8 policy, u32 flags)
|
u8 policy, u32 flags)
|
||||||
{
|
{
|
||||||
const struct nlattr * const *nla = ctx->nla;
|
const struct nlattr * const *nla = ctx->nla;
|
||||||
|
struct nft_stats __percpu *stats = NULL;
|
||||||
struct nft_table *table = ctx->table;
|
struct nft_table *table = ctx->table;
|
||||||
struct nft_base_chain *basechain;
|
struct nft_base_chain *basechain;
|
||||||
struct nft_stats __percpu *stats;
|
|
||||||
struct net *net = ctx->net;
|
struct net *net = ctx->net;
|
||||||
char name[NFT_NAME_MAXLEN];
|
char name[NFT_NAME_MAXLEN];
|
||||||
struct nft_trans *trans;
|
struct nft_trans *trans;
|
||||||
@@ -2037,7 +2037,6 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,
|
|||||||
return PTR_ERR(stats);
|
return PTR_ERR(stats);
|
||||||
}
|
}
|
||||||
rcu_assign_pointer(basechain->stats, stats);
|
rcu_assign_pointer(basechain->stats, stats);
|
||||||
static_branch_inc(&nft_counters_enabled);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
err = nft_basechain_init(basechain, family, &hook, flags);
|
err = nft_basechain_init(basechain, family, &hook, flags);
|
||||||
@@ -2120,6 +2119,9 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,
|
|||||||
goto err_unregister_hook;
|
goto err_unregister_hook;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (stats)
|
||||||
|
static_branch_inc(&nft_counters_enabled);
|
||||||
|
|
||||||
table->use++;
|
table->use++;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
Reference in New Issue
Block a user