mirror of
https://github.com/lwip-tcpip/lwip.git
synced 2025-01-27 03:35:38 +00:00
nd6: Handle incorrect ICMP option length in RA
Make sure ICMPv6 options have a valid length before parsing them. Found with afl-fuzz.
This commit is contained in:
parent
4e241fbf14
commit
d98e25a783
@ -443,6 +443,13 @@ nd6_input(struct pbuf *p, struct netif *inp)
|
||||
buffer = nd6_ra_buffer;
|
||||
pbuf_copy_partial(p, buffer, sizeof(struct prefix_option), offset);
|
||||
}
|
||||
if (buffer[1] == 0) {
|
||||
/* zero-length extension. drop packet */
|
||||
pbuf_free(p);
|
||||
ND6_STATS_INC(nd6.lenerr);
|
||||
ND6_STATS_INC(nd6.drop);
|
||||
return;
|
||||
}
|
||||
switch (buffer[0]) {
|
||||
case ND6_OPTION_TYPE_SOURCE_LLADDR:
|
||||
{
|
||||
@ -511,6 +518,7 @@ nd6_input(struct pbuf *p, struct netif *inp)
|
||||
ND6_STATS_INC(nd6.proterr);
|
||||
break;
|
||||
}
|
||||
/* option length is checked earlier to be non-zero to make sure loop ends */
|
||||
offset += 8 * ((u16_t)buffer[1]);
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user