X-Git-Url: https://tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=src%2Fsubnet.h;h=1aab681ab868708bf0afb6f2d402c46994c5ba82;hp=b31226c0bafad7bd8057ae33344be251c31dac57;hb=394ed3fb174bb629bfb4b441fe58842562f955de;hpb=950fb8e916b0e248dcaa72c96859acd6046683aa diff --git a/src/subnet.h b/src/subnet.h index b31226c0..1aab681a 100644 --- a/src/subnet.h +++ b/src/subnet.h @@ -17,20 +17,20 @@ 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.2 2000/10/11 10:35:17 guus Exp $ + $Id: subnet.h,v 1.1.2.7 2000/11/20 19:41:13 guus Exp $ */ #ifndef __TINC_SUBNET_H__ #define __TINC_SUBNET_H__ #include "net.h" -#include "connlist.h" enum { SUBNET_MAC = 0, SUBNET_IPV4, SUBNET_IPV6, + SUBNET_TYPES /* Guardian */ }; typedef struct subnet_mac_t @@ -51,17 +51,20 @@ typedef struct subnet_ipv6_t } subnet_ipv6_t; typedef struct subnet_t { - struct conn_list_t *owner; /* the owner of this subnet */ - struct conn_list_t *uplink; /* the uplink which we should send packets to for this subnet */ + 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 */ + int type; /* subnet type (IPv4? IPv6? MAC? something even weirder?) */ /* And now for the actual subnet: */ - union + union net { subnet_mac_t mac; subnet_ipv4_t ipv4; @@ -70,15 +73,19 @@ typedef struct subnet_t { } subnet_t; +#include "connection.h" + extern subnet_t *new_subnet(void); extern void free_subnet(subnet_t *); -extern void subnet_add(conn_list_t *, subnet_t *); +extern void init_subnets(void); +extern void subnet_add(struct connection_t *, subnet_t *); extern void subnet_del(subnet_t *); extern char *net2str(subnet_t *); extern subnet_t *str2net(char *); -extern subnet_t *lookup_subnet_mac(subnet_t *, mac_t); -extern subnet_t *lookup_subnet_ipv4(subnet_t *, ipv4_t); -extern subnet_t *lookup_subnet_ipv6(subnet_t *, ipv6_t); - +extern int subnet_compare(subnet_t *, subnet_t *); +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); #endif /* __TINC_SUBNET_H__ */