dhcpc: fix the case where we might add extra space at the end of envvar.
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
@@ -36,6 +36,9 @@ const struct dhcp_optflag dhcp_optflags[] = {
|
|||||||
{ OPTION_STRING , 0x11 }, /* DHCP_ROOT_PATH */
|
{ OPTION_STRING , 0x11 }, /* DHCP_ROOT_PATH */
|
||||||
{ OPTION_U8 , 0x17 }, /* DHCP_IP_TTL */
|
{ OPTION_U8 , 0x17 }, /* DHCP_IP_TTL */
|
||||||
{ OPTION_U16 , 0x1a }, /* DHCP_MTU */
|
{ OPTION_U16 , 0x1a }, /* DHCP_MTU */
|
||||||
|
//TODO: why do we request DHCP_BROADCAST? Can't we assume that
|
||||||
|
//in the unlikely case it is different from typical N.N.255.255,
|
||||||
|
//server would let us know anyway?
|
||||||
{ OPTION_IP | OPTION_REQ, 0x1c }, /* DHCP_BROADCAST */
|
{ OPTION_IP | OPTION_REQ, 0x1c }, /* DHCP_BROADCAST */
|
||||||
{ OPTION_IP_PAIR | OPTION_LIST , 0x21 }, /* DHCP_ROUTES */
|
{ OPTION_IP_PAIR | OPTION_LIST , 0x21 }, /* DHCP_ROUTES */
|
||||||
{ OPTION_STRING , 0x28 }, /* DHCP_NIS_DOMAIN */
|
{ OPTION_STRING , 0x28 }, /* DHCP_NIS_DOMAIN */
|
||||||
|
@@ -173,16 +173,13 @@ static NOINLINE char *xmalloc_optname_optval(uint8_t *option, const struct dhcp_
|
|||||||
dest += sprintf(ret, "%s=", opt_name);
|
dest += sprintf(ret, "%s=", opt_name);
|
||||||
|
|
||||||
while (len >= optlen) {
|
while (len >= optlen) {
|
||||||
unsigned ip_ofs = 0;
|
|
||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
|
case OPTION_IP:
|
||||||
case OPTION_IP_PAIR:
|
case OPTION_IP_PAIR:
|
||||||
dest += sprint_nip(dest, "", option);
|
dest += sprint_nip(dest, "", option);
|
||||||
*dest++ = '/';
|
if (type == OPTION_IP)
|
||||||
ip_ofs = 4;
|
break;
|
||||||
/* fall through */
|
dest += sprint_nip(dest, "/", option + 4);
|
||||||
case OPTION_IP:
|
|
||||||
dest += sprint_nip(dest, "", option + ip_ofs);
|
|
||||||
break;
|
break;
|
||||||
// case OPTION_BOOLEAN:
|
// case OPTION_BOOLEAN:
|
||||||
// dest += sprintf(dest, *option ? "yes" : "no");
|
// dest += sprintf(dest, *option ? "yes" : "no");
|
||||||
@@ -204,10 +201,14 @@ static NOINLINE char *xmalloc_optname_optval(uint8_t *option, const struct dhcp_
|
|||||||
dest += sprintf(dest, type == OPTION_U32 ? "%lu" : "%ld", (unsigned long) ntohl(val_u32));
|
dest += sprintf(dest, type == OPTION_U32 ? "%lu" : "%ld", (unsigned long) ntohl(val_u32));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
/* Note: options which use 'return' instead of 'break'
|
||||||
|
* (for example, OPTION_STRING) skip the code which handles
|
||||||
|
* the case of list of options.
|
||||||
|
*/
|
||||||
case OPTION_STRING:
|
case OPTION_STRING:
|
||||||
memcpy(dest, option, len);
|
memcpy(dest, option, len);
|
||||||
dest[len] = '\0';
|
dest[len] = '\0';
|
||||||
return ret; /* Short circuit this case */
|
return ret;
|
||||||
case OPTION_STATIC_ROUTES: {
|
case OPTION_STATIC_ROUTES: {
|
||||||
/* Option binary format:
|
/* Option binary format:
|
||||||
* mask [one byte, 0..32]
|
* mask [one byte, 0..32]
|
||||||
@@ -347,7 +348,7 @@ static NOINLINE char *xmalloc_optname_optval(uint8_t *option, const struct dhcp_
|
|||||||
// TODO: it can be a list only if (optflag->flags & OPTION_LIST).
|
// TODO: it can be a list only if (optflag->flags & OPTION_LIST).
|
||||||
// Should we bail out/warn if we see multi-ip option which is
|
// Should we bail out/warn if we see multi-ip option which is
|
||||||
// not allowed to be such (for example, DHCP_BROADCAST)? -
|
// not allowed to be such (for example, DHCP_BROADCAST)? -
|
||||||
if (len <= 0 /* || !(optflag->flags & OPTION_LIST) */)
|
if (len < optlen /* || !(optflag->flags & OPTION_LIST) */)
|
||||||
break;
|
break;
|
||||||
*dest++ = ' ';
|
*dest++ = ' ';
|
||||||
*dest = '\0';
|
*dest = '\0';
|
||||||
|
Reference in New Issue
Block a user