Browse Source

Add a way to specify a different interface prefix (for internal use mostly).

Adam Ierymenko 8 years ago
parent
commit
99e2098a48
1 changed files with 18 additions and 7 deletions
  1. 18 7
      osdep/LinuxEthernetTap.cpp

+ 18 - 7
osdep/LinuxEthernetTap.cpp

@@ -48,6 +48,7 @@
 
 #include <algorithm>
 #include <utility>
+#include <string>
 
 #include "../node/Constants.hpp"
 #include "../node/Utils.hpp"
@@ -97,6 +98,22 @@ LinuxEthernetTap::LinuxEthernetTap(
 	struct ifreq ifr;
 	memset(&ifr,0,sizeof(ifr));
 
+	// Linux supports arbitrary device naming -- this isn't available on other platforms so just use a simple hack for it
+#ifdef __SYNOLOGY__
+	int devno = 50;
+#else
+	int devno = 0;
+#endif
+	std::string devicepfx;
+	OSUtils::readFile((_homePath + ZT_PATH_SEPARATOR_S + "devicepfx").c_str(),devicepfx);
+	if (devicepfx.length() == 0) {
+#ifdef __SYNOLOGY__
+		devicepfx = "eth";
+#else
+		devicepfx = "zt";
+#endif
+	}
+
 	// Try to recall our last device name, or pick an unused one if that fails.
 	std::map<std::string,std::string> globalDeviceMap;
 	FILE *devmapf = fopen((_homePath + ZT_PATH_SEPARATOR_S + "devicemap").c_str(),"r");
@@ -124,14 +141,8 @@ LinuxEthernetTap::LinuxEthernetTap(
 		recalledDevice = (stat(procpath,&sbuf) != 0);
 	}
 	if (!recalledDevice) {
-		int devno = 0;
 		do {
-#ifdef __SYNOLOGY__
-			devno+=50; // Arbitrary number to prevent interface name conflicts
-			Utils::snprintf(ifr.ifr_name,sizeof(ifr.ifr_name),"eth%d",devno++);
-#else
-			Utils::snprintf(ifr.ifr_name,sizeof(ifr.ifr_name),"zt%d",devno++);
-#endif
+			Utils::snprintf(ifr.ifr_name,sizeof(ifr.ifr_name),"%s%d",devicepfx.c_str(),devno++);
 			Utils::snprintf(procpath,sizeof(procpath),"/proc/sys/net/ipv4/conf/%s",ifr.ifr_name);
 		} while (stat(procpath,&sbuf) == 0); // try zt#++ until we find one that does not exist
 	}