]> git.meshlink.io Git - meshlink/commitdiff
Nodes use events, so event system should be initialised first and destroyed last.
authorGuus Sliepen <guus@tinc-vpn.org>
Sat, 11 Nov 2006 22:44:15 +0000 (22:44 +0000)
committerGuus Sliepen <guus@tinc-vpn.org>
Sat, 11 Nov 2006 22:44:15 +0000 (22:44 +0000)
src/event.c
src/net.c
src/net_packet.c
src/net_setup.c
src/node.c

index c58175a1e5f06da8fc815e8082c57ec726554863..e7fbb882c1cb9a42d426edfff48a9603181f2207 100644 (file)
@@ -96,7 +96,7 @@ event_t *get_expired_event(void)
                event = event_tree->head->data;
 
                if(event->time < now) {
-                       avl_delete(event_tree, event);
+                       event_del(event);
                        return event;
                }
        }
index 81a0d894daaf8f818a8139c72404be5f40a7ea5f..e834f923593c7e1e6e0c3e4ffb2aceb493f64b8d 100644 (file)
--- a/src/net.c
+++ b/src/net.c
@@ -424,7 +424,7 @@ int main_loop(void)
 
                while((event = get_expired_event())) {
                        event->handler(event->data);
-                       free(event);
+                       free_event(event);
                }
 
                if(sigalrm) {
index ffda5a1253702c3ae2733fbc084e65239f20380d..20bee349e0923b200076ac865f9d818894f7a326 100644 (file)
@@ -101,7 +101,7 @@ void send_mtu_probe(node_t *n)
                send_udppacket(n, &packet);
        }
 
-       n->mtuevent = xmalloc(sizeof(*n->mtuevent));
+       n->mtuevent = new_event();
        n->mtuevent->handler = (event_handler_t)send_mtu_probe;
        n->mtuevent->data = n;
        n->mtuevent->time = now + 1;
index 4bac3f0b0d637498f68b2f0ba84c1d7cae422f2f..ccd600b730c41816a49363f0e55464e74cd6f81d 100644 (file)
@@ -526,11 +526,11 @@ bool setup_network_connections(void)
 
        now = time(NULL);
 
+       init_events();
        init_connections();
        init_subnets();
        init_nodes();
        init_edges();
-       init_events();
        init_requests();
 
        if(get_config_int(lookup_config(config_tree, "PingInterval"), &pinginterval)) {
@@ -594,11 +594,11 @@ void close_network_connections(void)
        envp[4] = NULL;
 
        exit_requests();
-       exit_events();
        exit_edges();
        exit_subnets();
        exit_nodes();
        exit_connections();
+       exit_events();
 
        execute_script("tinc-down", envp);
 
index 5cf5d967aa0faec6aeba736d37af21059f6d2761..5dad0aaf379851c2518c586cb8fe43e63036ddbb 100644 (file)
@@ -93,12 +93,6 @@ void free_node(node_t *n)
        if(n->queue)
                list_delete_list(n->queue);
 
-       if(n->name)
-               free(n->name);
-
-       if(n->hostname)
-               free(n->hostname);
-
        if(n->key)
                free(n->key);
 
@@ -112,9 +106,17 @@ void free_node(node_t *n)
 
        EVP_CIPHER_CTX_cleanup(&n->packet_ctx);
 
-       if(n->mtuevent)
+       if(n->mtuevent) {
                event_del(n->mtuevent);
+               free_event(n->mtuevent);
+       }
        
+       if(n->hostname)
+               free(n->hostname);
+
+       if(n->name)
+               free(n->name);
+
        free(n);
 }