summaryrefslogtreecommitdiff
path: root/sbin/dhclient/kroute.c
diff options
context:
space:
mode:
authorKenneth R Westerback <krw@cvs.openbsd.org>2017-09-09 15:08:00 +0000
committerKenneth R Westerback <krw@cvs.openbsd.org>2017-09-09 15:08:00 +0000
commit46c258727e1a85925e4c7f4a88e2bf3ddd77c667 (patch)
tree0a97169763b2af74447b62f1a0941668eb17030e /sbin/dhclient/kroute.c
parent152bd7a2c057d90ff643f447ea811b8a676b6ad7 (diff)
Tweak extract_classless_route() to return unsigned int
and accept NULL pointers for unwanted components of the route.
Diffstat (limited to 'sbin/dhclient/kroute.c')
-rw-r--r--sbin/dhclient/kroute.c39
1 files changed, 22 insertions, 17 deletions
diff --git a/sbin/dhclient/kroute.c b/sbin/dhclient/kroute.c
index 85160a1f571..6209abd46d0 100644
--- a/sbin/dhclient/kroute.c
+++ b/sbin/dhclient/kroute.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: kroute.c,v 1.145 2017/09/08 13:49:00 krw Exp $ */
+/* $OpenBSD: kroute.c,v 1.146 2017/09/09 15:07:59 krw Exp $ */
/*
* Copyright 2012 Kenneth R Westerback <krw@openbsd.org>
@@ -179,28 +179,35 @@ priv_flush_routes(int index, int routefd, int rdomain,
free(buf);
}
-int
+unsigned int
extract_classless_route(uint8_t *rtstatic, unsigned int rtstatic_len,
in_addr_t *dest, in_addr_t *netmask, in_addr_t *gateway)
{
unsigned int bits, bytes, len;
if (rtstatic[0] > 32)
- return -1;
+ return 0;
bits = rtstatic[0];
bytes = (bits + 7) / 8;
len = 1 + bytes + sizeof(*gateway);
if (len > rtstatic_len)
- return -1;
+ return 0;
+
+ if (dest != NULL)
+ memcpy(dest, &rtstatic[1], bytes);
+
+ if (netmask != NULL) {
+ if (bits == 0)
+ *netmask = INADDR_ANY;
+ else
+ *netmask = htonl(0xffffffff << (32 - bits));
+ if (dest != NULL)
+ *dest &= *netmask;
+ }
- memcpy(dest, &rtstatic[1], bytes);
- if (bits == 0)
- *netmask = INADDR_ANY;
- else
- *netmask = htonl(0xffffffff << (32 - bits));
- *dest &= *netmask;
- memcpy(gateway, &rtstatic[1 + bytes], sizeof(*gateway));
+ if (gateway != NULL)
+ memcpy(gateway, &rtstatic[1 + bytes], sizeof(*gateway));
return len;
}
@@ -211,8 +218,7 @@ set_routes(struct in_addr addr, struct in_addr addrmask, uint8_t *rtstatic,
{
const struct in_addr any = { INADDR_ANY };
struct in_addr dest, gateway, netmask;
- unsigned int i;
- int len;
+ unsigned int i, len;
flush_routes(rtstatic, rtstatic_len);
@@ -221,7 +227,7 @@ set_routes(struct in_addr addr, struct in_addr addrmask, uint8_t *rtstatic,
while (i < rtstatic_len) {
len = extract_classless_route(&rtstatic[i], rtstatic_len - i,
&dest.s_addr, &netmask.s_addr, &gateway.s_addr);
- if (len <= 0)
+ if (len == 0)
return;
i += len;
@@ -793,8 +799,7 @@ route_in_rtstatic(struct rt_msghdr *rtm, uint8_t *rtstatic,
in_addr_t dstaddr, netmaskaddr, gatewayaddr;
in_addr_t rtstaticdstaddr, rtstaticnetmaskaddr;
in_addr_t rtstaticgatewayaddr;
- unsigned int i;
- int len;
+ unsigned int i, len;
get_rtaddrs(rtm->rtm_addrs,
(struct sockaddr *)((char *)(rtm) + rtm->rtm_hdrlen),
@@ -821,7 +826,7 @@ route_in_rtstatic(struct rt_msghdr *rtm, uint8_t *rtstatic,
len = extract_classless_route(&rtstatic[i], rtstatic_len - i,
&rtstaticdstaddr, &rtstaticnetmaskaddr,
&rtstaticgatewayaddr);
- if (len <= 0)
+ if (len == 0)
break;
if (dstaddr == rtstaticdstaddr &&