X-Git-Url: https://tinc-vpn.org/git/browse?a=blobdiff_plain;f=src%2Fnet.h;h=2be797d947c55a2ea3c2eca3df1eff8905a917de;hb=6834b882015a9323672e9fce8811aa4283f196f0;hp=9b625a0d9873c7a32723e55210559157c9df8ffc;hpb=886a6f61a1f4cc48a77b42d10f34f9126377d904;p=tinc diff --git a/src/net.h b/src/net.h index 9b625a0d..2be797d9 100644 --- a/src/net.h +++ b/src/net.h @@ -21,9 +21,11 @@ #ifndef __TINC_NET_H__ #define __TINC_NET_H__ +#include "event.h" #include "ipv6.h" #include "cipher.h" #include "digest.h" +#include "threads.h" #ifdef ENABLE_JUMBOGRAMS #define MTU 9018 /* 9000 bytes payload + 14 bytes ethernet header + 4 bytes VLAN tag */ @@ -84,10 +86,10 @@ typedef struct vpn_packet_t { } vpn_packet_t; typedef struct listen_socket_t { - struct event ev_tcp; - struct event ev_udp; int tcp; int udp; + thread_t tcp_thread; + thread_t udp_thread; sockaddr_t sa; } listen_socket_t; @@ -125,10 +127,10 @@ extern int contradicting_del_edge; #include "node.h" extern void retry_outgoing(outgoing_t *); -extern void handle_incoming_vpn_data(int, short, void *); +extern void handle_incoming_vpn_data(void *); extern void finish_connecting(struct connection_t *); extern void do_outgoing_connection(struct connection_t *); -extern void handle_new_meta_connection(int, short, void *); +extern void handle_new_meta_connection(void *); extern int setup_listen_socket(const sockaddr_t *); extern int setup_vpn_in_socket(const sockaddr_t *); extern void send_packet(const struct node_t *, vpn_packet_t *); @@ -144,7 +146,7 @@ extern void flush_queue(struct node_t *); extern bool read_rsa_public_key(struct connection_t *); extern void send_mtu_probe(struct node_t *); extern void handle_device_data(int, short, void *); -extern void handle_meta_connection_data(int, short, void *); +extern void handle_meta_connection_data(void *); extern void regenerate_key(); extern void purge(void); extern void retry(void); @@ -153,8 +155,8 @@ extern void load_all_subnets(); #ifndef HAVE_MINGW #define closesocket(s) close(s) -#else -extern CRITICAL_SECTION mutex; #endif +extern mutex_t mutex; + #endif /* __TINC_NET_H__ */