diff options
author | Tony Cheneau <tony.cheneau@amnesiak.org> | 2012-07-11 08:51:14 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-07-17 07:51:15 +0200 |
commit | d4787a15432384826a0bed42d189fc2a97dc73ea (patch) | |
tree | 211b8183a67dd12d817146265485a597a4f85942 /net/ieee802154/6lowpan.c | |
parent | arch: Use eth_random_addr (diff) | |
download | linux-d4787a15432384826a0bed42d189fc2a97dc73ea.tar.xz linux-d4787a15432384826a0bed42d189fc2a97dc73ea.zip |
6lowpan: Fix null pointer dereference in UDP uncompression function
When a UDP packet gets fragmented, a crash will occur at reassembly time.
This is because skb->transport_header is not set during earlier period of fragment reassembly.
As a consequence, call to udp_hdr() return NULL and uh (which is NULL) gets
dereferenced without much test.
Signed-off-by: Tony Cheneau <tony.cheneau@amnesiak.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ieee802154/6lowpan.c')
-rw-r--r-- | net/ieee802154/6lowpan.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/net/ieee802154/6lowpan.c b/net/ieee802154/6lowpan.c index 6871ec1b30f8..416a54d31fb2 100644 --- a/net/ieee802154/6lowpan.c +++ b/net/ieee802154/6lowpan.c @@ -314,6 +314,9 @@ lowpan_uncompress_udp_header(struct sk_buff *skb) struct udphdr *uh = udp_hdr(skb); u8 tmp; + if (!uh) + goto err; + if (lowpan_fetch_skb_u8(skb, &tmp)) goto err; |