]> git.baikalelectronics.ru Git - kernel.git/commit
netfilter: nf_tables: fix chain dependency validation
authorPablo Neira Ayuso <pablo@netfilter.org>
Wed, 30 May 2018 18:18:57 +0000 (20:18 +0200)
committerPablo Neira Ayuso <pablo@netfilter.org>
Fri, 1 Jun 2018 07:46:22 +0000 (09:46 +0200)
commitbcaff1410594f516e68ce8b6bd54b74ec35104a7
tree539186f5a542d2b1dceaf7a824270721c2ba4305
parentc7bc9c9e27945558f506b100864b8b3c1914d13a
netfilter: nf_tables: fix chain dependency validation

The following ruleset:

 add table ip filter
 add chain ip filter input { type filter hook input priority 4; }
 add chain ip filter ap
 add rule ip filter input jump ap
 add rule ip filter ap masquerade

results in a panic, because the masquerade extension should be rejected
from the filter chain. The existing validation is missing a chain
dependency check when the rule is added to the non-base chain.

This patch fixes the problem by walking down the rules from the
basechains, searching for either immediate or lookup expressions, then
jumping to non-base chains and again walking down the rules to perform
the expression validation, so we make sure the full ruleset graph is
validated. This is done only once from the commit phase, in case of
problem, we abort the transaction and perform fine grain validation for
error reporting. This patch requires 097977b1d1c9 ("netfilter:
nfnetlink: allow commit to fail") to achieve this behaviour.

This patch also adds a cleanup callback to nfnl batch interface to reset
the validate state from the exit path.

As a result of this patch, nf_tables_check_loops() doesn't use
->validate to check for loops, instead it just checks for immediate
expressions.

Reported-by: Taehee Yoo <ap420073@gmail.com>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
include/linux/netfilter/nfnetlink.h
include/net/netfilter/nf_tables.h
include/net/netfilter/nf_tables_core.h
include/net/netns/nftables.h
net/netfilter/nf_tables_api.c
net/netfilter/nfnetlink.c
net/netfilter/nft_immediate.c
net/netfilter/nft_lookup.c