Commit 4bc65dd8 authored by Eric Dumazet's avatar Eric Dumazet Committed by David S. Miller

filter: use size of fetched data in __load_pointer()

__load_pointer() checks data we fetch from skb is included in head
portion, but assumes we fetch one byte, instead of up to four.

This wont crash because we have extra bytes (struct skb_shared_info)
after head, but this can read uninitialized bytes.

Fix this using size of the data (1, 2, 4 bytes) in the test.
Signed-off-by: default avatarEric Dumazet <eric.dumazet@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 60d509c8
...@@ -88,7 +88,7 @@ enum { ...@@ -88,7 +88,7 @@ enum {
}; };
/* No hurry in this branch */ /* No hurry in this branch */
static void *__load_pointer(const struct sk_buff *skb, int k) static void *__load_pointer(const struct sk_buff *skb, int k, unsigned int size)
{ {
u8 *ptr = NULL; u8 *ptr = NULL;
...@@ -97,7 +97,7 @@ static void *__load_pointer(const struct sk_buff *skb, int k) ...@@ -97,7 +97,7 @@ static void *__load_pointer(const struct sk_buff *skb, int k)
else if (k >= SKF_LL_OFF) else if (k >= SKF_LL_OFF)
ptr = skb_mac_header(skb) + k - SKF_LL_OFF; ptr = skb_mac_header(skb) + k - SKF_LL_OFF;
if (ptr >= skb->head && ptr < skb_tail_pointer(skb)) if (ptr >= skb->head && ptr + size <= skb_tail_pointer(skb))
return ptr; return ptr;
return NULL; return NULL;
} }
...@@ -110,7 +110,7 @@ static inline void *load_pointer(const struct sk_buff *skb, int k, ...@@ -110,7 +110,7 @@ static inline void *load_pointer(const struct sk_buff *skb, int k,
else { else {
if (k >= SKF_AD_OFF) if (k >= SKF_AD_OFF)
return NULL; return NULL;
return __load_pointer(skb, k); return __load_pointer(skb, k, size);
} }
} }
......
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