nameif: fix use-after-free in ENABLE_FEATURE_CLEAN_UP code

Signed-off-by: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
1_22_stable
Thomas De Schampheleire 2013-02-28 10:31:54 +01:00 committed by Denys Vlasenko
parent 1e43a381b2
commit bc0ffc0e97
1 changed files with 9 additions and 6 deletions

View File

@ -292,12 +292,11 @@ int nameif_main(int argc UNUSED_PARAM, char **argv)
if (ch->mac && memcmp(ch->mac, ifr.ifr_hwaddr.sa_data, ETH_ALEN) != 0) if (ch->mac && memcmp(ch->mac, ifr.ifr_hwaddr.sa_data, ETH_ALEN) != 0)
continue; continue;
/* if we came here, all selectors have matched */ /* if we came here, all selectors have matched */
break; goto found;
} }
/* Nothing found for current interface */ /* Nothing found for current interface */
if (!ch) continue;
continue; found:
if (strcmp(ifr.ifr_name, ch->ifname) != 0) { if (strcmp(ifr.ifr_name, ch->ifname) != 0) {
strcpy(ifr.ifr_newname, ch->ifname); strcpy(ifr.ifr_newname, ch->ifname);
ioctl_or_perror_and_die(ctl_sk, SIOCSIFNAME, &ifr, ioctl_or_perror_and_die(ctl_sk, SIOCSIFNAME, &ifr,
@ -313,10 +312,14 @@ int nameif_main(int argc UNUSED_PARAM, char **argv)
ch->next->prev = ch->prev; ch->next->prev = ch->prev;
if (ENABLE_FEATURE_CLEAN_UP) if (ENABLE_FEATURE_CLEAN_UP)
delete_eth_table(ch); delete_eth_table(ch);
} } /* while */
if (ENABLE_FEATURE_CLEAN_UP) { if (ENABLE_FEATURE_CLEAN_UP) {
for (ch = clist; ch; ch = ch->next) ethtable_t *next;
for (ch = clist; ch; ch = next) {
next = ch->next;
delete_eth_table(ch); delete_eth_table(ch);
}
config_close(parser); config_close(parser);
}; };