tun-device: Use next free TUN device on FreeBSD
authorTobias Brunner <tobias@strongswan.org>
Wed, 3 May 2017 08:01:12 +0000 (10:01 +0200)
committerTobias Brunner <tobias@strongswan.org>
Fri, 19 May 2017 13:28:46 +0000 (15:28 +0200)
While this API is documented as legacy (and there is a sysctl option to
disable it) the documentation also mentions that it will probably stay
enabled by default due to compatibility issues with existing applications.

With the previous approach only 255 devices could be opened then the
daemon had to be restarted.

Fixes #2313.

src/libstrongswan/networking/tun_device.c

index ec6dac7..86951f1 100644 (file)
@@ -490,10 +490,25 @@ static bool init_tun(private_tun_device_t *this, const char *name_tmpl)
        strncpy(this->if_name, ifr.ifr_name, IFNAMSIZ);
        return TRUE;
 
-#else /* !IFF_TUN */
+#elif defined(__FreeBSD__)
 
-       /* this works on FreeBSD and might also work on Linux with older TUN
-        * driver versions (no IFF_TUN) */
+       if (name_tmpl)
+       {
+               DBG1(DBG_LIB, "arbitrary naming of TUN devices is not supported");
+       }
+
+       this->tunfd = open("/dev/tun", O_RDWR);
+       if (this->tunfd < 0)
+       {
+               DBG1(DBG_LIB, "failed to open /dev/tun: %s", strerror(errno));
+               return FALSE;
+       }
+       fdevname_r(this->tunfd, this->if_name, IFNAMSIZ);
+       return TRUE;
+
+#else /* !__FreeBSD__ */
+
+       /* this might work on Linux with older TUN driver versions (no IFF_TUN) */
        char devname[IFNAMSIZ];
        /* the same process is allowed to open a device again, but that's not what
         * we want (unless we previously closed a device, which we don't know at