Reorder Linux TAP link sequence
This corrects the flow for bringing up a TAP device under Linux. Closes #1314
This commit is contained in:
@@ -207,12 +207,6 @@ LinuxEthernetTap::LinuxEthernetTap(
|
|||||||
printf("WARNING: ioctl() failed setting up Linux tap device (bring interface up)\n");
|
printf("WARNING: ioctl() failed setting up Linux tap device (bring interface up)\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
ifr.ifr_flags |= IFF_UP;
|
|
||||||
if (ioctl(sock,SIOCSIFFLAGS,(void *)&ifr) < 0) {
|
|
||||||
::close(sock);
|
|
||||||
printf("WARNING: ioctl() failed setting up Linux tap device (bring interface up)\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Some kernel versions seem to require you to yield while the device comes up
|
// Some kernel versions seem to require you to yield while the device comes up
|
||||||
// before they will accept MTU and MAC. For others it doesn't matter, but is
|
// before they will accept MTU and MAC. For others it doesn't matter, but is
|
||||||
@@ -235,6 +229,13 @@ LinuxEthernetTap::LinuxEthernetTap(
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ifr.ifr_flags |= IFF_UP;
|
||||||
|
if (ioctl(sock,SIOCSIFFLAGS,(void *)&ifr) < 0) {
|
||||||
|
::close(sock);
|
||||||
|
printf("WARNING: ioctl() failed setting up Linux tap device (bring interface up)\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
fcntl(_fd,F_SETFL,O_NONBLOCK);
|
fcntl(_fd,F_SETFL,O_NONBLOCK);
|
||||||
|
|
||||||
::close(sock);
|
::close(sock);
|
||||||
|
|||||||
Reference in New Issue
Block a user