blob: 9735c134d9d8e1b0e25cc3ef97b5c79fbf6d1381 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
--- sys/netinet6/frag6.c.orig
+++ sys/netinet6/frag6.c
@@ -807,6 +807,11 @@
/* Adjust offset to point where the original next header starts. */
offset = ip6af->ip6af_offset - sizeof(struct ip6_frag);
free(ip6af, M_FRAG6);
+ if ((u_int)plen + (u_int)offset - sizeof(struct ip6_hdr) >
+ IPV6_MAXPACKET) {
+ frag6_freef(q6, bucket);
+ goto dropfrag;
+ }
ip6 = mtod(m, struct ip6_hdr *);
ip6->ip6_plen = htons((u_short)plen + offset - sizeof(struct ip6_hdr));
if (q6->ip6q_ecn == IPTOS_ECN_CE)
|