ipv6: Add fragment reporting to ipv6_skip_exthdr().
While parsing through IPv6 extension headers, fragment headers are skipped making them invisible to the caller. This reports the fragment offset of the last header in order to make it possible to determine whether the packet is fragmented and, if so whether it is a first or last fragment. Signed-off-by: Jesse Gross <jesse@nicira.com>
This commit is contained in:
@@ -3561,6 +3561,7 @@ static int selinux_parse_skb_ipv6(struct sk_buff *skb,
|
||||
u8 nexthdr;
|
||||
int ret = -EINVAL, offset;
|
||||
struct ipv6hdr _ipv6h, *ip6;
|
||||
__be16 frag_off;
|
||||
|
||||
offset = skb_network_offset(skb);
|
||||
ip6 = skb_header_pointer(skb, offset, sizeof(_ipv6h), &_ipv6h);
|
||||
@@ -3573,7 +3574,7 @@ static int selinux_parse_skb_ipv6(struct sk_buff *skb,
|
||||
|
||||
nexthdr = ip6->nexthdr;
|
||||
offset += sizeof(_ipv6h);
|
||||
offset = ipv6_skip_exthdr(skb, offset, &nexthdr);
|
||||
offset = ipv6_skip_exthdr(skb, offset, &nexthdr, &frag_off);
|
||||
if (offset < 0)
|
||||
goto out;
|
||||
|
||||
|
Reference in New Issue
Block a user