Snap for 4526935 from d60dc7ef5c306e57ac345476b5f3a1e474d18f5b to oreo-mr1-cts-release Change-Id: Ibd4e672bae0a9b1ec064d48adcf1fed133c497a8
diff --git a/libnetutils/packet.c b/libnetutils/packet.c index e53a4c8..9ecdd4f 100644 --- a/libnetutils/packet.c +++ b/libnetutils/packet.c
@@ -218,6 +218,20 @@ * to construct the pseudo header used in the checksum calculation. */ dhcp_size = ntohs(packet.udp.len) - sizeof(packet.udp); + /* + * check validity of dhcp_size. + * 1) cannot be negative or zero. + * 2) src buffer contains enough bytes to copy + * 3) cannot exceed destination buffer + */ + if ((dhcp_size <= 0) || + ((int)(nread - sizeof(struct iphdr) - sizeof(struct udphdr)) < dhcp_size) || + ((int)sizeof(struct dhcp_msg) < dhcp_size)) { +#if VERBOSE + ALOGD("Malformed Packet"); +#endif + return -1; + } saddr = packet.ip.saddr; daddr = packet.ip.daddr; nread = ntohs(packet.ip.tot_len);