Fixed another closure bug

This commit is contained in:
Joseph Henry 2015-09-24 19:22:56 -04:00
parent 8a8264bc39
commit fe78eb77d4
3 changed files with 21 additions and 21 deletions

View File

@ -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) 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; struct pbuf *p,*q;
//fprintf(stderr, "_put(%s,%s,%.4x,[data],%u)\n",from.toString().c_str(),to.toString().c_str(),etherType,len); //fprintf(stderr, "_put(%s,%s,%.4x,[data],%u)\n",from.toString().c_str(),to.toString().c_str(),etherType,len);
if (!_enabled) if (!_enabled)
@ -291,20 +289,25 @@ void NetconEthernetTap::closeAllClients()
*/ */
void NetconEthernetTap::closeConnection(NetconConnection *conn) 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; NetconClient *client = conn->owner;
if(conn->pcb == NULL) { if(conn->type == TCP_DATA && conn->pcb == NULL) {
fprintf(stderr, "closeConnection(): PCB is null\n"); fprintf(stderr, "closeConnection(): PCB is null\n");
return; return;
} }
lwipstack->_tcp_arg(conn->pcb, NULL); if(conn->type == TCP_DATA)
lwipstack->_tcp_sent(conn->pcb, NULL); {
lwipstack->_tcp_recv(conn->pcb, NULL); lwipstack->_tcp_arg(conn->pcb, NULL);
lwipstack->_tcp_err(conn->pcb, NULL); lwipstack->_tcp_sent(conn->pcb, NULL);
lwipstack->_tcp_poll(conn->pcb, NULL, 0); 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(_phy.getDescriptor(conn->sock));
close(conn->their_fd); close(conn->their_fd);
_phy.close(conn->sock); _phy.close(conn->sock);
lwipstack->_tcp_close(conn->pcb);
delete conn; delete conn;
} }
@ -353,9 +356,6 @@ void NetconEthernetTap::threadMain()
fprintf(stderr, "- DEFAULT_READ_BUFFER_SIZE = %d\n", DEFAULT_READ_BUFFER_SIZE); 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 // Main timer loop
while (_run) { while (_run) {
uint64_t now = OSUtils::now(); uint64_t now = OSUtils::now();
@ -386,9 +386,9 @@ void NetconEthernetTap::threadMain()
void NetconEthernetTap::phyOnUnixClose(PhySocket *sock,void **uptr) void NetconEthernetTap::phyOnUnixClose(PhySocket *sock,void **uptr)
{ {
fprintf(stderr, "phyOnUnixClose()\n"); fprintf(stderr, "phyOnUnixClose() CLOSING: %d\n", _phy.getDescriptor(sock));
//close(_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); NetconConnection *c = ((NetconClient*)*uptr)->getConnection(sock);
if(c->idx < DEFAULT_READ_BUFFER_SIZE) { if(c->idx < DEFAULT_READ_BUFFER_SIZE) {
int read_fd = _phy.getDescriptor(sock); 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) { if((r = read(read_fd, (&c->buf)+c->idx, DEFAULT_READ_BUFFER_SIZE-(c->idx))) > 0) {
c->idx += r; c->idx += r;
Mutex::Lock _l(lwipstack->_lock); 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) 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(); NetconClient *newClient = new NetconClient();
newClient->rpc = newClient->addConnection(RPC, sockN); newClient->rpc = newClient->addConnection(RPC, sockN);
*uptrN = newClient; *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]; ZT_PHY_SOCKFD_TYPE fds[2];
socketpair(PF_LOCAL, SOCK_STREAM, 0, fds); 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); client->connections.push_back(new_conn);
new_conn->pcb = newpcb; new_conn->pcb = newpcb;
new_conn->their_fd = fds[1]; new_conn->their_fd = fds[1];
@ -823,7 +825,7 @@ void NetconEthernetTap::handle_socket(NetconClient *client, struct socket_st* so
if(pcb != NULL) { if(pcb != NULL) {
ZT_PHY_SOCKFD_TYPE fds[2]; ZT_PHY_SOCKFD_TYPE fds[2];
socketpair(PF_LOCAL, SOCK_STREAM, 0, fds); 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->pcb = pcb;
new_conn->their_fd = fds[1]; new_conn->their_fd = fds[1];
PhySocket *sock = client->rpc->sock; 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; int sz, write_allowance = sndbuf < c->idx ? sndbuf : c->idx;
fprintf(stderr, "handle_write(): allow = %d\n", write_allowance);
if(write_allowance > 0) { if(write_allowance > 0) {
// NOTE: this assumes that lwipstack->_lock is locked, either // NOTE: this assumes that lwipstack->_lock is locked, either
// because we are in a callback or have locked it manually. // because we are in a callback or have locked it manually.

View File

@ -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, 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)); 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; return ERR_OK;
} }

View File

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