Commit aaf2bb42 authored by Laura Garcia Liebana's avatar Laura Garcia Liebana Committed by Ben Hutchings

netfilter: nft_exthdr: Add size check on u8 nft_exthdr attributes

commit 4da449ae upstream.

Fix the direct assignment of offset and length attributes included in
nft_exthdr structure from u32 data to u8.
Signed-off-by: default avatarLaura Garcia Liebana <nevola@gmail.com>
Signed-off-by: default avatarPablo Neira Ayuso <pablo@netfilter.org>
[bwh: Backported to 3.16: adjust context]
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent 2c40ffcb
...@@ -59,6 +59,7 @@ static int nft_exthdr_init(const struct nft_ctx *ctx, ...@@ -59,6 +59,7 @@ static int nft_exthdr_init(const struct nft_ctx *ctx,
{ {
struct nft_exthdr *priv = nft_expr_priv(expr); struct nft_exthdr *priv = nft_expr_priv(expr);
int err; int err;
u32 offset, len;
if (tb[NFTA_EXTHDR_DREG] == NULL || if (tb[NFTA_EXTHDR_DREG] == NULL ||
tb[NFTA_EXTHDR_TYPE] == NULL || tb[NFTA_EXTHDR_TYPE] == NULL ||
...@@ -66,9 +67,15 @@ static int nft_exthdr_init(const struct nft_ctx *ctx, ...@@ -66,9 +67,15 @@ static int nft_exthdr_init(const struct nft_ctx *ctx,
tb[NFTA_EXTHDR_LEN] == NULL) tb[NFTA_EXTHDR_LEN] == NULL)
return -EINVAL; return -EINVAL;
offset = ntohl(nla_get_be32(tb[NFTA_EXTHDR_OFFSET]));
len = ntohl(nla_get_be32(tb[NFTA_EXTHDR_LEN]));
if (offset > U8_MAX || len > U8_MAX)
return -ERANGE;
priv->type = nla_get_u8(tb[NFTA_EXTHDR_TYPE]); priv->type = nla_get_u8(tb[NFTA_EXTHDR_TYPE]);
priv->offset = ntohl(nla_get_be32(tb[NFTA_EXTHDR_OFFSET])); priv->offset = offset;
priv->len = ntohl(nla_get_be32(tb[NFTA_EXTHDR_LEN])); priv->len = len;
if (priv->len == 0 || if (priv->len == 0 ||
priv->len > FIELD_SIZEOF(struct nft_data, data)) priv->len > FIELD_SIZEOF(struct nft_data, data))
return -EINVAL; return -EINVAL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment