X-Git-Url: https://tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=src%2Fsubnet.h;h=45e9cc12dc72a489de6318b50849bba86df2480b;hp=b409fd46e2241d3b19a42ce4b386ec2ba1c01c89;hb=f1b20b3ded5b360e426e094cf79df3bf97f350b4;hpb=408ca91766088b6c2d38e198b0692bf394b41248 diff --git a/src/subnet.h b/src/subnet.h index b409fd46..45e9cc12 100644 --- a/src/subnet.h +++ b/src/subnet.h @@ -1,7 +1,7 @@ /* subnet.h -- header for subnet.c - Copyright (C) 2000 Guus Sliepen , - 2000 Ivo Timmermans + Copyright (C) 2000,2001 Guus Sliepen , + 2000,2001 Ivo Timmermans This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -17,7 +17,7 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id: subnet.h,v 1.1.2.6 2000/11/20 19:12:17 guus Exp $ + $Id: subnet.h,v 1.1.2.14 2001/11/16 12:10:54 zarq Exp $ */ #ifndef __TINC_SUBNET_H__ @@ -28,8 +28,7 @@ enum { SUBNET_MAC = 0, - SUBNET_IPV4, - SUBNET_IPV6, + SUBNET_IP, SUBNET_TYPES /* Guardian */ }; @@ -38,27 +37,17 @@ typedef struct subnet_mac_t mac_t address; } subnet_mac_t; -typedef struct subnet_ipv4_t +typedef struct subnet_ip_t { - ipv4_t address; - ipv4_t mask; -} subnet_ipv4_t; + struct addrinfo *address; + struct addrinfo *mask; +} subnet_ip_t; -typedef struct subnet_ipv6_t -{ - ipv6_t address; - ipv6_t mask; -} subnet_ipv6_t; +#include "node.h" typedef struct subnet_t { - struct connection_t *owner; /* the owner of this subnet */ - struct connection_t *uplink; /* the uplink which we should send packets to for this subnet */ - - struct subnet_t *prev; /* previous subnet_t for this owner */ - struct subnet_t *next; /* next subnet_t for this owner */ - - struct subnet_t *global_prev; /* previous subnet_t for this subnet type */ - struct subnet_t *global_next; /* next subnet_t for this subnet type */ + struct node_t *owner; /* the owner of this subnet */ + struct node_t *uplink; /* the uplink which we should send packets to for this subnet */ int type; /* subnet type (IPv4? IPv6? MAC? something even weirder?) */ @@ -67,23 +56,24 @@ typedef struct subnet_t { union net { subnet_mac_t mac; - subnet_ipv4_t ipv4; - subnet_ipv6_t ipv6; + subnet_ip_t ip; } net; -} subnet_t; - -#include "connection.h" +} subnet_t; extern subnet_t *new_subnet(void); extern void free_subnet(subnet_t *); -extern void subnet_add(struct connection_t *, subnet_t *); -extern void subnet_del(subnet_t *); +extern void init_subnets(void); +extern void exit_subnets(void); +extern avl_tree_t *new_subnet_tree(void); +extern void free_subnet_tree(avl_tree_t *); +extern void subnet_add(struct node_t *, subnet_t *); +extern void subnet_del(struct node_t *, subnet_t *); extern char *net2str(subnet_t *); extern subnet_t *str2net(char *); -extern subnet_t *lookup_subnet_mac(mac_t); -extern subnet_t *lookup_subnet_ipv4(ipv4_t); -extern subnet_t *lookup_subnet_ipv6(ipv6_t); -extern void dump_subnet_list(void); +extern subnet_t *lookup_subnet(struct node_t *, subnet_t *); +extern subnet_t *lookup_subnet_mac(mac_t *); +extern subnet_t *lookup_subnet_ip(struct addrinfo *); +extern void dump_subnets(void); #endif /* __TINC_SUBNET_H__ */