diff options
author | Brian Foley | 2016-10-25 14:20:55 +0200 |
---|---|---|
committer | Denys Vlasenko | 2016-10-25 14:20:55 +0200 |
commit | f9beeb22e2a4128ed85a8dc267d0823e5cfd3f47 (patch) | |
tree | 6c83a9185531079940b7c5b0d687c253a4bced06 /networking/udhcp/common.c | |
parent | 69312e87b008363575a6d6603f54f94d8150e1cc (diff) | |
download | busybox-f9beeb22e2a4128ed85a8dc267d0823e5cfd3f47.zip busybox-f9beeb22e2a4128ed85a8dc267d0823e5cfd3f47.tar.gz |
udhcpc: check read of option length byte to be within packet
function old new delta
udhcp_get_option 215 220 +5
udhcp_run_script 802 803 +1
Signed-off-by: Brian Foley <bpfoley@google.com>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'networking/udhcp/common.c')
-rw-r--r-- | networking/udhcp/common.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/networking/udhcp/common.c b/networking/udhcp/common.c index 0cf4dab..589bcd6 100644 --- a/networking/udhcp/common.c +++ b/networking/udhcp/common.c @@ -226,9 +226,12 @@ uint8_t* FAST_FUNC udhcp_get_option(struct dhcp_packet *packet, int code) rem = sizeof(packet->options); while (1) { if (rem <= 0) { + complain: bb_error_msg("bad packet, malformed option field"); return NULL; } + + /* DHCP_PADDING and DHCP_END have no [len] byte */ if (optionptr[OPT_CODE] == DHCP_PADDING) { rem--; optionptr++; @@ -251,10 +254,13 @@ uint8_t* FAST_FUNC udhcp_get_option(struct dhcp_packet *packet, int code) } break; } + + if (rem <= OPT_LEN) + goto complain; /* complain and return NULL */ len = 2 + optionptr[OPT_LEN]; rem -= len; if (rem < 0) - continue; /* complain and return NULL */ + goto complain; /* complain and return NULL */ if (optionptr[OPT_CODE] == code) { log_option("option found", optionptr); |