X-Git-Url: https://tinc-vpn.org/git/browse?a=blobdiff_plain;f=src%2Fnet.h;h=8e256ce76aff54b66f8c25dd40c41245121060e4;hb=e62fd508158749a0d55eae06c2e361df5d6da6e0;hp=ba4cdb44375b11b98d3082198bad3ebe565d88ad;hpb=7208397398f7e08d741bfa83594a88e5d01b6220;p=tinc diff --git a/src/net.h b/src/net.h index ba4cdb44..8e256ce7 100644 --- a/src/net.h +++ b/src/net.h @@ -21,17 +21,23 @@ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ +#include "system.h" + #include "ipv6.h" #include "cipher.h" #include "digest.h" #include "event.h" +#define EPOLL_MAX_EVENTS_PER_LOOP 32 + #ifdef ENABLE_JUMBOGRAMS #define MTU 9018 /* 9000 bytes payload + 14 bytes ethernet header + 4 bytes VLAN tag */ #else #define MTU 1518 /* 1500 bytes payload + 14 bytes ethernet header + 4 bytes VLAN tag */ #endif +#define MINMTU 512 /* Below this we don't consider UDP to be working */ + /* MAXSIZE is the maximum size of an encapsulated packet: MTU + seqno + srcid + dstid + padding + HMAC + compressor overhead */ #define MAXSIZE (MTU + 4 + sizeof(node_id_t) + sizeof(node_id_t) + CIPHER_MAX_BLOCK_SIZE + DIGEST_MAX_SIZE + MTU/64 + 20) @@ -101,12 +107,6 @@ typedef struct vpn_packet_t { #define PKT_MAC 2 #define PKT_PROBE 4 -typedef enum packet_type_t { - PACKET_NORMAL, - PACKET_COMPRESSED, - PACKET_PROBE -} packet_type_t; - typedef struct listen_socket_t { io_t tcp; io_t udp; @@ -124,7 +124,12 @@ typedef struct outgoing_t { timeout_t ev; } outgoing_t; -extern list_t *outgoing_list; +typedef struct ports_t { + char *tcp; + char *udp; +} ports_t; + +extern list_t outgoing_list; extern int maxoutbufsize; extern int seconds_till_retry; @@ -151,7 +156,7 @@ extern bool udp_sndbuf_warnings; extern int max_connection_burst; extern int fwmark; extern bool do_prune; -extern char *myport; +extern ports_t myport; extern bool device_standby; extern bool autoconnect; extern bool disablebuggypeers; @@ -188,7 +193,7 @@ extern void handle_new_meta_connection(void *data, int flags); extern void handle_new_unix_connection(void *data, int flags); extern int setup_listen_socket(const sockaddr_t *sa); extern int setup_vpn_in_socket(const sockaddr_t *sa); -extern bool send_sptps_data(node_t *to, node_t *from, int type, const void *data, size_t len); +extern bool send_sptps_data(struct node_t *to, struct node_t *from, int type, const void *data, size_t len); extern bool receive_sptps_record(void *handle, uint8_t type, const void *data, uint16_t len); extern void send_packet(struct node_t *n, vpn_packet_t *packet); extern void receive_tcppacket(struct connection_t *c, const char *buffer, size_t length); @@ -215,7 +220,7 @@ extern void load_all_nodes(void); extern void try_tx(struct node_t *n, bool mtu); extern void tarpit(int fd); -#ifndef HAVE_MINGW +#ifndef HAVE_WINDOWS #define closesocket(s) close(s) #endif