X-Git-Url: https://tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=src%2Fsubnet.h;h=04e5c286286c5250a3f703254d88a7f2abeb7df0;hp=45e9cc12dc72a489de6318b50849bba86df2480b;hb=c2b9c06062d36bde859b630b99a08c7b7428e721;hpb=f1b20b3ded5b360e426e094cf79df3bf97f350b4 diff --git a/src/subnet.h b/src/subnet.h index 45e9cc12..04e5c286 100644 --- a/src/subnet.h +++ b/src/subnet.h @@ -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.14 2001/11/16 12:10:54 zarq Exp $ + $Id: subnet.h,v 1.1.2.16 2002/02/18 16:25:19 guus Exp $ */ #ifndef __TINC_SUBNET_H__ @@ -28,7 +28,8 @@ enum { SUBNET_MAC = 0, - SUBNET_IP, + SUBNET_IPV4, + SUBNET_IPV6, SUBNET_TYPES /* Guardian */ }; @@ -37,11 +38,17 @@ typedef struct subnet_mac_t mac_t address; } subnet_mac_t; -typedef struct subnet_ip_t +typedef struct subnet_ipv4_t { - struct addrinfo *address; - struct addrinfo *mask; -} subnet_ip_t; + ipv4_t address; + int masklength; +} subnet_ipv4_t; + +typedef struct subnet_ipv6_t +{ + ipv6_t address; + int masklength; +} subnet_ipv6_t; #include "node.h" @@ -56,9 +63,9 @@ typedef struct subnet_t { union net { subnet_mac_t mac; - subnet_ip_t ip; + subnet_ipv4_t ipv4; + subnet_ipv6_t ipv6; } net; - } subnet_t; extern subnet_t *new_subnet(void); @@ -73,7 +80,8 @@ extern char *net2str(subnet_t *); extern subnet_t *str2net(char *); 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 subnet_t *lookup_subnet_ipv4(ipv4_t *); +extern subnet_t *lookup_subnet_ipv6(ipv6_t *); extern void dump_subnets(void); #endif /* __TINC_SUBNET_H__ */