From: Daniel Sabogal Date: Thu, 15 Sep 2016 15:27:30 +0000 (-0400) Subject: fix if_indextoname error case X-Git-Tag: v1.1.16~69 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=32055d52ca43d867d6dbb763dc5213a8d3536a23;p=musl fix if_indextoname error case posix requires errno to be set to ENXIO if the interface does not exist. linux returns ENODEV instead so we handle this. --- diff --git a/src/network/if_indextoname.c b/src/network/if_indextoname.c index 6ee7f13c..3b368bf0 100644 --- a/src/network/if_indextoname.c +++ b/src/network/if_indextoname.c @@ -3,6 +3,7 @@ #include #include #include +#include #include "syscall.h" char *if_indextoname(unsigned index, char *name) @@ -14,5 +15,9 @@ char *if_indextoname(unsigned index, char *name) ifr.ifr_ifindex = index; r = ioctl(fd, SIOCGIFNAME, &ifr); __syscall(SYS_close, fd); - return r < 0 ? 0 : strncpy(name, ifr.ifr_name, IF_NAMESIZE); + if (r < 0) { + if (errno == ENODEV) errno = ENXIO; + return 0; + } + return strncpy(name, ifr.ifr_name, IF_NAMESIZE); }