6lowpan: fix udp header compression when using raw sockets
authorSimon Vincent <simon.vincent@xsilon.com>
Tue, 4 Nov 2014 15:29:51 +0000 (15:29 +0000)
committerMarcel Holtmann <marcel@holtmann.org>
Tue, 4 Nov 2014 16:31:01 +0000 (17:31 +0100)
If you use RAW sockets the transport header offset is not set by the
ipv6 stack so when we get to the udp header compression it does not
compress the right part of the packet.

This patch adds a check for this scenario and sets the transport
header offset.

Signed-off-by: Simon Vincent <simon.vincent@xsilon.com>
Acked-by: Alexander Aring <alex.aring@gmail.com>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
net/6lowpan/iphc.c

index 73a7065f0c6bc8243091deb20f723b2cd1f9847e..cd5f8b8e34cd81e7a2997cf9014592e07e017ef0 100644 (file)
@@ -512,9 +512,17 @@ static u8 lowpan_compress_addr_64(u8 **hc_ptr, u8 shift,
 
 static void compress_udp_header(u8 **hc_ptr, struct sk_buff *skb)
 {
-       struct udphdr *uh = udp_hdr(skb);
+       struct udphdr *uh;
        u8 tmp;
 
+       /* In the case of RAW sockets the transport header is not set by
+        * the ip6 stack so we must set it ourselves
+        */
+       if (skb->transport_header == skb->network_header)
+               skb_set_transport_header(skb, sizeof(struct ipv6hdr));
+
+       uh = udp_hdr(skb);
+
        if (((ntohs(uh->source) & LOWPAN_NHC_UDP_4BIT_MASK) ==
             LOWPAN_NHC_UDP_4BIT_PORT) &&
            ((ntohs(uh->dest) & LOWPAN_NHC_UDP_4BIT_MASK) ==