Commit 186e6c48 authored by Juliusz Chroboczek's avatar Juliusz Chroboczek

Fix error handling in interface_up.

Minimal fix for a strange race condition.  A more extensive fix
is in the master branch.
parent 6f27079f
...@@ -328,7 +328,11 @@ interface_up(struct interface *ifp, int up) ...@@ -328,7 +328,11 @@ interface_up(struct interface *ifp, int up)
rc = kernel_addresses(ifp->name, ifp->ifindex, 1, ll, 32); rc = kernel_addresses(ifp->name, ifp->ifindex, 1, ll, 32);
if(rc < 0) { if(rc < 0) {
perror("kernel_ll_addresses"); perror("kernel_ll_addresses");
} else if(rc > 0) { } else if(rc == 0) {
fprintf(stderr, "Interface %s has no link-local address.\n",
ifp->name);
return interface_up(ifp, 0);
} else {
ifp->ll = malloc(16 * rc); ifp->ll = malloc(16 * rc);
if(ifp->ll == NULL) { if(ifp->ll == NULL) {
perror("malloc(ll)"); perror("malloc(ll)");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment