Skip to content

Commit d8ee8f7

Browse files
committed
netfilter: nf_tables: add nft_register_basechain() and nft_unregister_basechain()
This wrapper functions take care of hook registration for basechains. Signed-off-by: Pablo Neira Ayuso <[email protected]>
1 parent 2cbce13 commit d8ee8f7

File tree

1 file changed

+37
-15
lines changed

1 file changed

+37
-15
lines changed

net/netfilter/nf_tables_api.c

Lines changed: 37 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -127,13 +127,38 @@ static void nft_trans_destroy(struct nft_trans *trans)
127127
kfree(trans);
128128
}
129129

130+
static int nft_register_basechain(struct nft_base_chain *basechain,
131+
unsigned int hook_nops)
132+
{
133+
return nf_register_hooks(basechain->ops, hook_nops);
134+
}
135+
136+
static void nft_unregister_basechain(struct nft_base_chain *basechain,
137+
unsigned int hook_nops)
138+
{
139+
nf_unregister_hooks(basechain->ops, hook_nops);
140+
}
141+
142+
static int nf_tables_register_hooks(const struct nft_table *table,
143+
struct nft_chain *chain,
144+
unsigned int hook_nops)
145+
{
146+
if (table->flags & NFT_TABLE_F_DORMANT ||
147+
!(chain->flags & NFT_BASE_CHAIN))
148+
return 0;
149+
150+
return nft_register_basechain(nft_base_chain(chain), hook_nops);
151+
}
152+
130153
static void nf_tables_unregister_hooks(const struct nft_table *table,
131-
const struct nft_chain *chain,
154+
struct nft_chain *chain,
132155
unsigned int hook_nops)
133156
{
134-
if (!(table->flags & NFT_TABLE_F_DORMANT) &&
135-
chain->flags & NFT_BASE_CHAIN)
136-
nf_unregister_hooks(nft_base_chain(chain)->ops, hook_nops);
157+
if (table->flags & NFT_TABLE_F_DORMANT ||
158+
!(chain->flags & NFT_BASE_CHAIN))
159+
return;
160+
161+
nft_unregister_basechain(nft_base_chain(chain), hook_nops);
137162
}
138163

139164
/* Internal table flags */
@@ -560,7 +585,7 @@ static int nf_tables_table_enable(const struct nft_af_info *afi,
560585
if (!(chain->flags & NFT_BASE_CHAIN))
561586
continue;
562587

563-
err = nf_register_hooks(nft_base_chain(chain)->ops, afi->nops);
588+
err = nft_register_basechain(nft_base_chain(chain), afi->nops);
564589
if (err < 0)
565590
goto err;
566591

@@ -575,20 +600,20 @@ static int nf_tables_table_enable(const struct nft_af_info *afi,
575600
if (i-- <= 0)
576601
break;
577602

578-
nf_unregister_hooks(nft_base_chain(chain)->ops, afi->nops);
603+
nft_unregister_basechain(nft_base_chain(chain), afi->nops);
579604
}
580605
return err;
581606
}
582607

583608
static void nf_tables_table_disable(const struct nft_af_info *afi,
584-
struct nft_table *table)
609+
struct nft_table *table)
585610
{
586611
struct nft_chain *chain;
587612

588613
list_for_each_entry(chain, &table->chains, list) {
589614
if (chain->flags & NFT_BASE_CHAIN)
590-
nf_unregister_hooks(nft_base_chain(chain)->ops,
591-
afi->nops);
615+
nft_unregister_basechain(nft_base_chain(chain),
616+
afi->nops);
592617
}
593618
}
594619

@@ -1421,12 +1446,9 @@ static int nf_tables_newchain(struct sock *nlsk, struct sk_buff *skb,
14211446
chain->table = table;
14221447
nla_strlcpy(chain->name, name, NFT_CHAIN_MAXNAMELEN);
14231448

1424-
if (!(table->flags & NFT_TABLE_F_DORMANT) &&
1425-
chain->flags & NFT_BASE_CHAIN) {
1426-
err = nf_register_hooks(nft_base_chain(chain)->ops, afi->nops);
1427-
if (err < 0)
1428-
goto err1;
1429-
}
1449+
err = nf_tables_register_hooks(table, chain, afi->nops);
1450+
if (err < 0)
1451+
goto err1;
14301452

14311453
nft_ctx_init(&ctx, skb, nlh, afi, table, chain, nla);
14321454
err = nft_trans_chain_add(&ctx, NFT_MSG_NEWCHAIN);

0 commit comments

Comments
 (0)