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.12 2001/10/27 13:13:35 guus Exp $
+ $Id: subnet.h,v 1.1.2.14 2001/11/16 12:10:54 zarq Exp $
*/
#ifndef __TINC_SUBNET_H__
enum
{
SUBNET_MAC = 0,
- SUBNET_IPV4,
- SUBNET_IPV6,
+ SUBNET_IP,
SUBNET_TYPES /* Guardian */
};
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;
-
-typedef struct subnet_ipv6_t
-{
- ipv6_t address;
- ipv6_t mask;
-} subnet_ipv6_t;
+ struct addrinfo *address;
+ struct addrinfo *mask;
+} subnet_ip_t;
#include "node.h"
union net
{
subnet_mac_t mac;
- subnet_ipv4_t ipv4;
- subnet_ipv6_t ipv6;
+ subnet_ip_t ip;
} net;
} subnet_t;
extern subnet_t *new_subnet(void);
extern void free_subnet(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 int subnet_compare(subnet_t *, subnet_t *);
extern subnet_t *lookup_subnet(struct node_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 subnet_t *lookup_subnet_ip(struct addrinfo *);
extern void dump_subnets(void);
#endif /* __TINC_SUBNET_H__ */