Skip to content

Commit

Permalink
netfilter: nft_compat: restrict match/target protocol to u16
Browse files Browse the repository at this point in the history
[ Upstream commit d694b75 ]

xt_check_{match,target} expects u16, but NFTA_RULE_COMPAT_PROTO is u32.

NLA_POLICY_MAX(NLA_BE32, 65535) cannot be used because .max in
nla_policy is s16, see 3e48be0 ("netlink: add attribute range
validation to policy").

Fixes: 0ca743a ("netfilter: nf_tables: add compatibility layer for x_tables")
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
  • Loading branch information
ummakynes authored and gregkh committed Feb 16, 2024
1 parent af12244 commit c45aea3
Showing 1 changed file with 7 additions and 1 deletion.
8 changes: 7 additions & 1 deletion net/netfilter/nft_compat.c
Original file line number Diff line number Diff line change
Expand Up @@ -200,6 +200,7 @@ static const struct nla_policy nft_rule_compat_policy[NFTA_RULE_COMPAT_MAX + 1]
static int nft_parse_compat(const struct nlattr *attr, u16 *proto, bool *inv)
{
struct nlattr *tb[NFTA_RULE_COMPAT_MAX+1];
u32 l4proto;
u32 flags;
int err;

Expand All @@ -218,7 +219,12 @@ static int nft_parse_compat(const struct nlattr *attr, u16 *proto, bool *inv)
if (flags & NFT_RULE_COMPAT_F_INV)
*inv = true;

*proto = ntohl(nla_get_be32(tb[NFTA_RULE_COMPAT_PROTO]));
l4proto = ntohl(nla_get_be32(tb[NFTA_RULE_COMPAT_PROTO]));
if (l4proto > U16_MAX)
return -EINVAL;

*proto = l4proto;

return 0;
}

Expand Down

0 comments on commit c45aea3

Please sign in to comment.