summaryrefslogtreecommitdiffstats
path: root/usr.sbin/rtadvd
diff options
context:
space:
mode:
authorfabient <fabient@FreeBSD.org>2017-01-04 16:36:51 +0000
committerfabient <fabient@FreeBSD.org>2017-01-04 16:36:51 +0000
commite1a9b52b1c4ea5bd141b06ca296a85231fa72262 (patch)
treebf4a6ae1afe74082b144186d4e04a346fa1637d5 /usr.sbin/rtadvd
parent9a8301a4ac83ed89159a12a65af5c3c80a4de2f5 (diff)
downloadFreeBSD-src-e1a9b52b1c4ea5bd141b06ca296a85231fa72262.zip
FreeBSD-src-e1a9b52b1c4ea5bd141b06ca296a85231fa72262.tar.gz
MFC r308216:
In rtadvd, interface lookup calls if_indextoname() many times in a loop, (it takes a long time on systems with many interfaces) without reason and without checking its return value. Sponsored by: Stormshield
Diffstat (limited to 'usr.sbin/rtadvd')
-rw-r--r--usr.sbin/rtadvd/if.c19
1 files changed, 9 insertions, 10 deletions
diff --git a/usr.sbin/rtadvd/if.c b/usr.sbin/rtadvd/if.c
index bd26dec..72ea36a 100644
--- a/usr.sbin/rtadvd/if.c
+++ b/usr.sbin/rtadvd/if.c
@@ -474,11 +474,18 @@ update_ifinfo(struct ifilist_head_t *ifi_head, int ifindex)
ifindex != ifm->ifm_index)
continue;
+ /* ifname */
+ if (if_indextoname(ifm->ifm_index, ifname) == NULL) {
+ syslog(LOG_WARNING,
+ "<%s> ifname not found (idx=%d)",
+ __func__, ifm->ifm_index);
+ continue;
+ }
+
/* lookup an entry with the same ifindex */
TAILQ_FOREACH(ifi, ifi_head, ifi_next) {
if (ifm->ifm_index == ifi->ifi_ifindex)
break;
- if_indextoname(ifm->ifm_index, ifname);
if (strncmp(ifname, ifi->ifi_ifname,
sizeof(ifname)) == 0)
break;
@@ -497,15 +504,7 @@ update_ifinfo(struct ifilist_head_t *ifi_head, int ifindex)
ifi->ifi_ifindex = ifm->ifm_index;
/* ifname */
- if_indextoname(ifm->ifm_index, ifi->ifi_ifname);
- if (ifi->ifi_ifname == NULL) {
- syslog(LOG_WARNING,
- "<%s> ifname not found (idx=%d)",
- __func__, ifm->ifm_index);
- if (ifi_new)
- free(ifi);
- continue;
- }
+ strlcpy(ifi->ifi_ifname, ifname, IFNAMSIZ);
if ((s = socket(AF_INET6, SOCK_DGRAM, 0)) < 0) {
syslog(LOG_ERR,
OpenPOWER on IntegriCloud