aboutsummaryrefslogtreecommitdiffstats
path: root/net/netfilter
diff options
context:
space:
mode:
authorFlorian Westphal <fw@strlen.de>2018-07-11 07:45:11 -0400
committerPablo Neira Ayuso <pablo@netfilter.org>2018-07-18 05:26:45 -0400
commitca2f18be792fddd0db2bbf6cbe1ec12d1bb32dd7 (patch)
tree706fd92db3b395541a5c2d8d6b4c8aa7db846723 /net/netfilter
parent452238e8d5ffd8b77f92387519513839d4ca7379 (diff)
netfilter: nf_tables: make valid_genid callback mandatory
always call this function, followup patch can use this to aquire a per-netns transaction log to guard the entire batch instead of using the nfnl susbsys mutex (which is shared among all namespaces). Signed-off-by: Florian Westphal <fw@strlen.de> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'net/netfilter')
-rw-r--r--net/netfilter/nf_tables_api.c2
-rw-r--r--net/netfilter/nfnetlink.c4
2 files changed, 3 insertions, 3 deletions
diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c
index 5e95e92e547b..594b395442d6 100644
--- a/net/netfilter/nf_tables_api.c
+++ b/net/netfilter/nf_tables_api.c
@@ -6591,7 +6591,7 @@ static int nf_tables_abort(struct net *net, struct sk_buff *skb)
6591 6591
6592static bool nf_tables_valid_genid(struct net *net, u32 genid) 6592static bool nf_tables_valid_genid(struct net *net, u32 genid)
6593{ 6593{
6594 return net->nft.base_seq == genid; 6594 return genid == 0 || net->nft.base_seq == genid;
6595} 6595}
6596 6596
6597static const struct nfnetlink_subsystem nf_tables_subsys = { 6597static const struct nfnetlink_subsystem nf_tables_subsys = {
diff --git a/net/netfilter/nfnetlink.c b/net/netfilter/nfnetlink.c
index e1b6be29848d..94f9bcaa0799 100644
--- a/net/netfilter/nfnetlink.c
+++ b/net/netfilter/nfnetlink.c
@@ -331,13 +331,13 @@ replay:
331 } 331 }
332 } 332 }
333 333
334 if (!ss->commit || !ss->abort) { 334 if (!ss->valid_genid || !ss->commit || !ss->abort) {
335 nfnl_unlock(subsys_id); 335 nfnl_unlock(subsys_id);
336 netlink_ack(oskb, nlh, -EOPNOTSUPP, NULL); 336 netlink_ack(oskb, nlh, -EOPNOTSUPP, NULL);
337 return kfree_skb(skb); 337 return kfree_skb(skb);
338 } 338 }
339 339
340 if (genid && ss->valid_genid && !ss->valid_genid(net, genid)) { 340 if (!ss->valid_genid(net, genid)) {
341 nfnl_unlock(subsys_id); 341 nfnl_unlock(subsys_id);
342 netlink_ack(oskb, nlh, -ERESTART, NULL); 342 netlink_ack(oskb, nlh, -ERESTART, NULL);
343 return kfree_skb(skb); 343 return kfree_skb(skb);