summaryrefslogtreecommitdiff
path: root/lib/libc
diff options
context:
space:
mode:
authorJonathan Lemon <jlemon@FreeBSD.org>2001-10-17 20:08:15 +0000
committerJonathan Lemon <jlemon@FreeBSD.org>2001-10-17 20:08:15 +0000
commitc479a8493c594453b59cb09cdd1daa1fc3fe09f8 (patch)
tree85e95bff7a8fc4d6e1dd7cf22d7764636155ecb3 /lib/libc
parentde5934508a18a9cb5ef9fdd2f1035f66f5155227 (diff)
Notes
Diffstat (limited to 'lib/libc')
-rw-r--r--lib/libc/net/ifname.c24
1 files changed, 22 insertions, 2 deletions
diff --git a/lib/libc/net/ifname.c b/lib/libc/net/ifname.c
index 3d3916a458ac..94fb9513a747 100644
--- a/lib/libc/net/ifname.c
+++ b/lib/libc/net/ifname.c
@@ -35,6 +35,7 @@
#include <sys/param.h>
#include <sys/socket.h>
+#include <sys/sockio.h>
#include <sys/sysctl.h>
#include <net/if.h>
#include <net/route.h>
@@ -48,8 +49,8 @@
((a) > 0 ? (1 + (((a) - 1) | (sizeof(long) - 1))) : sizeof(long))
#define ADVANCE(x, n) (x += ROUNDUP((n)->sa_len))
-unsigned int
-if_nametoindex(ifname)
+static unsigned int
+if_onametoindex(ifname)
const char *ifname;
{
struct if_nameindex *iff = if_nameindex(), *ifx;
@@ -69,6 +70,25 @@ if_nametoindex(ifname)
errno = ENXIO;
return 0;
}
+
+unsigned int
+if_nametoindex(ifname)
+ const char *ifname;
+{
+ int s;
+ struct ifreq ifr;
+
+ s = socket(AF_INET, SOCK_DGRAM, 0);
+ if (s == -1)
+ return (0);
+ strlcpy(ifr.ifr_name, ifname, sizeof(ifr.ifr_name));
+ if (ioctl(s, SIOCGIFINDEX, &ifr) == -1) {
+ close (s);
+ return (if_onametoindex(ifname));
+ }
+ close(s);
+ return (ifr.ifr_index);
+}
char *
if_indextoname(ifindex, ifname)