2005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
* if_ioctl.c: (interface_list_ioctl) Use if_get_by_name_len.
* if_proc.c: (ifaddr_proc_ipv6) Increase size of ifname buffer to
avoid overflow.
* kernel_socket.c: (ifan_read) Use if_get_by_name_len.
* if.h: Fix comments to reflect that if_lookup_by_name and
if_get_by_name now require the argument strings to be NUL-terminated.
* if.c: (if_lookup_by_name) Compare using strcmp.
(if_get_by_name) Pass strlen(ifname) as 2nd arg to if_create.
diff --git a/zebra/if_ioctl.c b/zebra/if_ioctl.c
index 90f18e2..0d7713d 100644
--- a/zebra/if_ioctl.c
+++ b/zebra/if_ioctl.c
@@ -102,7 +102,9 @@
int size;
ifreq = (struct ifreq *)((caddr_t) ifconf.ifc_req + n);
- ifp = if_get_by_name (ifreq->ifr_name);
+ ifp = if_get_by_name_len(ifreq->ifr_name,
+ strnlen(ifreq->ifr_name,
+ sizeof(ifreq->ifr_name)));
if_add_update (ifp);
size = ifreq->ifr_addr.sa_len;
if (size < sizeof (ifreq->ifr_addr))
@@ -113,7 +115,9 @@
#else
for (n = 0; n < ifconf.ifc_len; n += sizeof(struct ifreq))
{
- ifp = if_get_by_name (ifreq->ifr_name);
+ ifp = if_get_by_name_len(ifreq->ifr_name,
+ strnlen(ifreq->ifr_name,
+ sizeof(ifreq->ifr_name)));
if_add_update (ifp);
ifreq++;
}