X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=src%2Fnode.c;h=164fdb159e701b8da13785b4c0ceb90e2e67792b;hb=6a73467d16a57ca1645d805776c4dfcaf2b05798;hp=c6213a17016b61d755973be24a0d0518cf8e7630;hpb=01eaeb3c9fa60ae9c6e5b866acd9baef79622d99;p=meshlink diff --git a/src/node.c b/src/node.c index c6213a17..164fdb15 100644 --- a/src/node.c +++ b/src/node.c @@ -48,9 +48,8 @@ void exit_nodes(meshlink_handle_t *mesh) { } node_t *new_node(void) { - node_t *n = xzalloc(sizeof *n); + node_t *n = xzalloc(sizeof(*n)); - if(replaywin) n->late = xzalloc(replaywin); n->edge_tree = new_edge_tree(); n->mtu = MTU; n->maxmtu = MTU; @@ -60,6 +59,8 @@ node_t *new_node(void) { } void free_node(node_t *n) { + n->status.destroyed = true; + if(n->edge_tree) free_edge_tree(n->edge_tree); @@ -71,14 +72,9 @@ void free_node(node_t *n) { if(n->mtutimeout.cb) abort(); - if(n->hostname) - free(n->hostname); - - if(n->name) - free(n->name); + free(n->name); - if(n->late) - free(n->late); + utcp_exit(n->utcp); free(n); } @@ -127,9 +123,15 @@ void update_node_udp(meshlink_handle_t *mesh, node_t *n, const sockaddr_t *sa) { break; } } + hash_insert(mesh->node_udp_cache, sa, n); - free(n->hostname); - n->hostname = sockaddr2hostname(&n->address); - logger(mesh, MESHLINK_DEBUG, "UDP address of %s set to %s", n->name, n->hostname); + + meshlink_hint_address(mesh, (meshlink_node_t *)n, &sa->sa); + + if(mesh->log_level >= MESHLINK_DEBUG) { + char *hostname = sockaddr2hostname(&n->address); + logger(mesh, MESHLINK_DEBUG, "UDP address of %s set to %s", n->name, hostname); + free(hostname); + } } }