summaryrefslogtreecommitdiffstats
path: root/sbin/dhclient
diff options
context:
space:
mode:
authorcem <cem@FreeBSD.org>2016-05-18 23:35:37 +0000
committercem <cem@FreeBSD.org>2016-05-18 23:35:37 +0000
commit35a390d5d6ab9833c51e86c159f9df048741373b (patch)
tree10d21f60c576eeef615db79c6a98b6d1b63ce888 /sbin/dhclient
parent699ba04bd68bbdeffcc735483c58bc77c0fdef4c (diff)
downloadFreeBSD-src-35a390d5d6ab9833c51e86c159f9df048741373b.zip
FreeBSD-src-35a390d5d6ab9833c51e86c159f9df048741373b.tar.gz
Revert r299512
It broke client identifiers because I misunderstood the intent of the code. There is still a minor issue detected by Coverity (at least, I can't find where the code proves it isn't an issue). I'll follow up with a better fix for the CIDs. Reported by: Ian FREISLICH Sponsored by: EMC / Isilon Storage Division
Diffstat (limited to 'sbin/dhclient')
-rw-r--r--sbin/dhclient/dhclient.c24
1 files changed, 10 insertions, 14 deletions
diff --git a/sbin/dhclient/dhclient.c b/sbin/dhclient/dhclient.c
index 7da12aa..4444f29 100644
--- a/sbin/dhclient/dhclient.c
+++ b/sbin/dhclient/dhclient.c
@@ -56,8 +56,6 @@
#include <sys/cdefs.h>
__FBSDID("$FreeBSD$");
-#include <stddef.h>
-
#include "dhcpd.h"
#include "privsep.h"
@@ -1572,18 +1570,16 @@ make_discover(struct interface_info *ip, struct client_lease *lease)
}
/* set unique client identifier */
- struct hardware client_ident;
+ char client_ident[sizeof(struct hardware)];
if (!options[DHO_DHCP_CLIENT_IDENTIFIER]) {
- size_t hwlen = MIN(ip->hw_address.hlen,
- sizeof(client_ident.haddr));
- client_ident.htype = ip->hw_address.htype;
- client_ident.hlen = hwlen;
- memcpy(client_ident.haddr, ip->hw_address.haddr, hwlen);
+ int hwlen = (ip->hw_address.hlen < sizeof(client_ident)-1) ?
+ ip->hw_address.hlen : sizeof(client_ident)-1;
+ client_ident[0] = ip->hw_address.htype;
+ memcpy(&client_ident[1], ip->hw_address.haddr, hwlen);
options[DHO_DHCP_CLIENT_IDENTIFIER] = &option_elements[DHO_DHCP_CLIENT_IDENTIFIER];
- options[DHO_DHCP_CLIENT_IDENTIFIER]->value = (void *)&client_ident;
- hwlen += offsetof(struct hardware, haddr);
- options[DHO_DHCP_CLIENT_IDENTIFIER]->len = hwlen;
- options[DHO_DHCP_CLIENT_IDENTIFIER]->buf_size = hwlen;
+ options[DHO_DHCP_CLIENT_IDENTIFIER]->value = client_ident;
+ options[DHO_DHCP_CLIENT_IDENTIFIER]->len = hwlen+1;
+ options[DHO_DHCP_CLIENT_IDENTIFIER]->buf_size = hwlen+1;
options[DHO_DHCP_CLIENT_IDENTIFIER]->timeout = 0xFFFFFFFF;
}
@@ -1609,8 +1605,8 @@ make_discover(struct interface_info *ip, struct client_lease *lease)
0, sizeof(ip->client->packet.siaddr));
memset(&(ip->client->packet.giaddr),
0, sizeof(ip->client->packet.giaddr));
- memcpy(ip->client->packet.chaddr, ip->hw_address.haddr,
- MIN(ip->hw_address.hlen, sizeof(ip->client->packet.chaddr)));
+ memcpy(ip->client->packet.chaddr,
+ ip->hw_address.haddr, ip->hw_address.hlen);
}
OpenPOWER on IntegriCloud