Parcourir la source

mimic BSDEthernetTap but with creating/destroying char tap device

Daniel Skowroński il y a 9 ans
Parent
commit
9a2310395d
1 fichiers modifiés avec 27 ajouts et 1 suppressions
  1. 27 1
      osdep/NetBSDEthernetTap.cpp

+ 27 - 1
osdep/NetBSDEthernetTap.cpp

@@ -115,7 +115,8 @@ NetBSDEthernetTap::NetBSDEthernetTap(
 
 	// On NetBSD there are /dev/tap{0..3} pre-created and for a moment I will stick with only them
 	std::vector<std::string> devFiles(OSUtils::listDirectory("/dev"));
-	for(int i=0;i<4;++i) {
+//	for(int i=0;i<4;++i) {
+	for(int i=9993;i<(9993+128);++i) {
 		Utils::snprintf(tmpdevname,sizeof(tmpdevname),"tap%d",i);
 		Utils::snprintf(devpath,sizeof(devpath),"/dev/%s",tmpdevname);
 		//if (std::find(devFiles.begin(),devFiles.end(),std::string(tmpdevname)) == devFiles.end()) {
@@ -128,6 +129,20 @@ NetBSDEthernetTap::NetBSDEthernetTap(
 				::waitpid(cpid,&exitcode,0);
 			} else throw std::runtime_error("fork() failed");
 
+			cpid = (long)vfork();
+			if (cpid == 0) {
+				string tmp;
+				sprintf((char*)tmp.c_str(), "%d", i);
+				string minor = tmp.c_str();
+				::execl("/sbin/mknod","/sbin/mknod",devpath,"c","169",minor.c_str(),(const char *)0); //major 169 => tap
+				::_exit(-1);
+			} else if (cpid > 0) {
+				int exitcode = -1;
+				::waitpid(cpid,&exitcode,0);
+			} else throw std::runtime_error("fork() failed");
+
+			cerr<<"created device "<<devpath<<endl;
+
 			_dev = tmpdevname;
 			_fd = ::open(  devpath,O_RDWR);
 			if (!stat(devpath,&stattmp)) {
@@ -219,6 +234,17 @@ NetBSDEthernetTap::~NetBSDEthernetTap()
 		int exitcode = -1;
 		::waitpid(cpid,&exitcode,0);
 	}
+
+	cpid = (long)vfork();
+	if (cpid == 0) {
+		string tmp="/dev/";
+		tmp+=_dev.c_str();
+		::execl("/bin/rm","/bin/rm",tmp.c_str(),(const char *)0);
+		::_exit(-1);
+	} else if (cpid > 0) {
+		int exitcode = -1;
+		::waitpid(cpid,&exitcode,0);
+	} else throw std::runtime_error("fork() failed");
 }
 
 void NetBSDEthernetTap::setEnabled(bool en)