Przeglądaj źródła

Fixed another closure bug

Joseph Henry 10 lat temu
rodzic
commit
fe78eb77d4

+ 19 - 19
netcon/NetconEthernetTap.cpp

@@ -166,8 +166,6 @@ std::vector<InetAddress> NetconEthernetTap::ips() const
 
 void NetconEthernetTap::put(const MAC &from,const MAC &to,unsigned int etherType,const void *data,unsigned int len)
 {
-	fprintf(stderr, "__put(): len = %d\n", len);
-
 	struct pbuf *p,*q;
 	//fprintf(stderr, "_put(%s,%s,%.4x,[data],%u)\n",from.toString().c_str(),to.toString().c_str(),etherType,len);
 	if (!_enabled)
@@ -291,20 +289,25 @@ void NetconEthernetTap::closeAllClients()
  */
 void NetconEthernetTap::closeConnection(NetconConnection *conn)
 {
+	fprintf(stderr, "closeConnection(): closing: conn->type = %d, fd=%d\n", conn->type, _phy.getDescriptor(conn->sock));
+
 	NetconClient *client = conn->owner;
-	if(conn->pcb == NULL) {
+	if(conn->type == TCP_DATA && conn->pcb == NULL) {
 		fprintf(stderr, "closeConnection(): PCB is null\n");
 		return;
 	}
-  lwipstack->_tcp_arg(conn->pcb, NULL);
-  lwipstack->_tcp_sent(conn->pcb, NULL);
-  lwipstack->_tcp_recv(conn->pcb, NULL);
-  lwipstack->_tcp_err(conn->pcb, NULL);
-  lwipstack->_tcp_poll(conn->pcb, NULL, 0);
+	if(conn->type == TCP_DATA)
+	{
+		lwipstack->_tcp_arg(conn->pcb, NULL);
+	  lwipstack->_tcp_sent(conn->pcb, NULL);
+	  lwipstack->_tcp_recv(conn->pcb, NULL);
+	  lwipstack->_tcp_err(conn->pcb, NULL);
+	  lwipstack->_tcp_poll(conn->pcb, NULL, 0);
+		lwipstack->_tcp_close(conn->pcb);
+	}
 	close(_phy.getDescriptor(conn->sock));
 	close(conn->their_fd);
 	_phy.close(conn->sock);
-	lwipstack->_tcp_close(conn->pcb);
 	delete conn;
 }
 
@@ -353,9 +356,6 @@ void NetconEthernetTap::threadMain()
 	fprintf(stderr, "- DEFAULT_READ_BUFFER_SIZE  = %d\n", DEFAULT_READ_BUFFER_SIZE);
 	*/
 
-	//fprintf(stderr, "- LWIP_DEBUG = %d\n", LWIP_DEBUG);
-	fprintf(stderr, "- TCP_DEBUG = %d\n", TCP_DEBUG);
-
 	// Main timer loop
 	while (_run) {
 		uint64_t now = OSUtils::now();
@@ -386,9 +386,9 @@ void NetconEthernetTap::threadMain()
 
 void NetconEthernetTap::phyOnUnixClose(PhySocket *sock,void **uptr)
 {
-	fprintf(stderr, "phyOnUnixClose()\n");
+	fprintf(stderr, "phyOnUnixClose() CLOSING: %d\n", _phy.getDescriptor(sock));
 	//close(_phy.getDescriptor(sock));
-	closeClient((NetconClient*)*uptr);
+	//closeClient((NetconClient*)*uptr);
 }
 
 /*
@@ -401,7 +401,7 @@ void NetconEthernetTap::phyOnFileDescriptorActivity(PhySocket *sock,void **uptr,
 		NetconConnection *c = ((NetconClient*)*uptr)->getConnection(sock);
 		if(c->idx < DEFAULT_READ_BUFFER_SIZE) {
 			int read_fd = _phy.getDescriptor(sock);
-			fprintf(stderr, "phyOnFileDescriptorActivity(): read_fd = %d\n", read_fd);
+			//fprintf(stderr, "phyOnFileDescriptorActivity(): read_fd = %d\n", read_fd);
 			if((r = read(read_fd, (&c->buf)+c->idx, DEFAULT_READ_BUFFER_SIZE-(c->idx))) > 0) {
 				c->idx += r;
 				Mutex::Lock _l(lwipstack->_lock);
@@ -427,6 +427,8 @@ void NetconEthernetTap::phyOnTcpWritable(PhySocket *sock,void **uptr) {}
  */
 void NetconEthernetTap::phyOnUnixAccept(PhySocket *sockL,PhySocket *sockN,void **uptrL,void **uptrN)
 {
+	fprintf(stderr, "phyOnUnixAccept() NEW CLIENT RPC: %d\n", _phy.getDescriptor(sockN));
+
 	NetconClient *newClient = new NetconClient();
 	newClient->rpc = newClient->addConnection(RPC, sockN);
 	*uptrN = newClient;
@@ -561,7 +563,7 @@ err_t NetconEthernetTap::nc_accept(void *arg, struct tcp_pcb *newpcb, err_t err)
 		}
 		ZT_PHY_SOCKFD_TYPE fds[2];
 		socketpair(PF_LOCAL, SOCK_STREAM, 0, fds);
-		NetconConnection *new_conn = client->addConnection(BUFFER, tap->_phy.wrapSocket(fds[0], client));
+		NetconConnection *new_conn = client->addConnection(TCP_DATA, tap->_phy.wrapSocket(fds[0], client));
 		client->connections.push_back(new_conn);
 		new_conn->pcb = newpcb;
 		new_conn->their_fd = fds[1];
@@ -823,7 +825,7 @@ void NetconEthernetTap::handle_socket(NetconClient *client, struct socket_st* so
   if(pcb != NULL) {
 		ZT_PHY_SOCKFD_TYPE fds[2];
 		socketpair(PF_LOCAL, SOCK_STREAM, 0, fds);
-		NetconConnection *new_conn = client->addConnection(BUFFER, _phy.wrapSocket(fds[0], client));
+		NetconConnection *new_conn = client->addConnection(TCP_DATA, _phy.wrapSocket(fds[0], client));
 		new_conn->pcb = pcb;
 	  new_conn->their_fd = fds[1];
 		PhySocket *sock = client->rpc->sock;
@@ -903,8 +905,6 @@ void NetconEthernetTap::handle_write(NetconConnection *c)
 		}
 
 		int sz, write_allowance =  sndbuf < c->idx ? sndbuf : c->idx;
-		fprintf(stderr, "handle_write(): allow = %d\n", write_allowance);
-
 		if(write_allowance > 0) {
 			// NOTE: this assumes that lwipstack->_lock is locked, either
 			// because we are in a callback or have locked it manually.

+ 1 - 1
netcon/NetconEthernetTap.hpp

@@ -215,7 +215,7 @@ static err_t low_level_output(struct netif *netif, struct pbuf *p)
 
   tap->_handler(tap->_arg,tap->_nwid,src_mac,dest_mac,
     Utils::ntoh((uint16_t)ethhdr->type),0,buf + sizeof(struct eth_hdr),tot_len - sizeof(struct eth_hdr));
-	printf("low_level_output(): length = %d -- ethertype = %d\n", tot_len - sizeof(struct eth_hdr), Utils::ntoh((uint16_t)ethhdr->type));
+	//printf("low_level_output(): length = %d -- ethertype = %d\n", tot_len - sizeof(struct eth_hdr), Utils::ntoh((uint16_t)ethhdr->type));
   return ERR_OK;
 }
 

+ 1 - 1
netcon/NetconService.hpp

@@ -41,7 +41,7 @@ using namespace std;
 
 namespace ZeroTier {
 
-  enum NetconConnectionType { RPC, BUFFER };
+  enum NetconConnectionType { RPC, TCP_DATA };
 
   class NetconEthernetTap;