]> git.ipfire.org Git - thirdparty/kernel/linux.git/commit
netfilter: xt_policy: fix strict mode inbound policy matching
authorJiexun Wang <wangjiexun2025@gmail.com>
Fri, 17 Apr 2026 12:25:06 +0000 (20:25 +0800)
committerPablo Neira Ayuso <pablo@netfilter.org>
Fri, 24 Apr 2026 18:04:56 +0000 (20:04 +0200)
commit4b2b4d7d4e203c92db8966b163edfacb1f0e1e29
treeee34797f97fcfa35568d2492922517872cdc92b6
parent10f79dbd7719d1da9f5884d13060322d8729f091
netfilter: xt_policy: fix strict mode inbound policy matching

match_policy_in() walks sec_path entries from the last transform to the
first one, but strict policy matching needs to consume info->pol[] in
the same forward order as the rule layout.

Derive the strict-match policy position from the number of transforms
already consumed so that multi-element inbound rules are matched
consistently.

Fixes: c4b885139203 ("[NETFILTER]: x_tables: replace IPv4/IPv6 policy match by address family independant version")
Reported-by: Yuan Tan <yuantan098@gmail.com>
Reported-by: Yifan Wu <yifanwucs@gmail.com>
Reported-by: Juefei Pu <tomapufckgml@gmail.com>
Reported-by: Xin Liu <bird@lzu.edu.cn>
Signed-off-by: Jiexun Wang <wangjiexun2025@gmail.com>
Signed-off-by: Ren Wei <n05ec@lzu.edu.cn>
Acked-by: Florian Westphal <fw@strlen.de>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
net/netfilter/xt_policy.c