/* $FreeBSD$ */
/*
* Copyright (C) 2012 by Darren Reed.
*
* See the IPFILTER.LICENCE file for details on licencing.
*/
#ifndef __RADIX_IPF_H__
#define __RADIX_IPF_H__
#ifndef U_32_T
typedef unsigned int u_32_t;
# define U_32_T 1
#endif
typedef struct ipf_rdx_mask {
struct ipf_rdx_mask *next;
struct ipf_rdx_node *node;
u_32_t *mask;
int maskbitcount;
} ipf_rdx_mask_t;
typedef struct ipf_rdx_node {
struct ipf_rdx_node *left;
struct ipf_rdx_node *right;
struct ipf_rdx_node *parent;
struct ipf_rdx_node *dupkey;
struct ipf_rdx_mask *masks;
struct ipf_rdx_mask *mymask;
u_32_t *addrkey;
u_32_t *maskkey;
u_32_t *addroff;
u_32_t *maskoff;
u_32_t lastmask;
u_32_t bitmask;
int offset;
int index;
int maskbitcount;
int root;
#ifdef RDX_DEBUG
char name[40];
#endif
} ipf_rdx_node_t;
struct ipf_rdx_head;
typedef void (* radix_walk_func_t)(ipf_rdx_node_t *, void *);
typedef ipf_rdx_node_t *(* idx_hamn_func_t)(struct ipf_rdx_head *,
addrfamily_t *, addrfamily_t *,
ipf_rdx_node_t *);
typedef ipf_rdx_node_t *(* idx_ham_func_t)(struct ipf_rdx_head *,
addrfamily_t *, addrfamily_t *);
typedef ipf_rdx_node_t *(* idx_ha_func_t)(struct ipf_rdx_head *,
addrfamily_t *);
typedef void (* idx_walk_func_t)(struct ipf_rdx_head *,
radix_walk_func_t, void *);
typedef struct ipf_rdx_head {
ipf_rdx_node_t *root;
ipf_rdx_node_t nodes[3];
ipfmutex_t lock;
idx_hamn_func_t addaddr; /* add addr/mask to tree */
idx_ham_func_t deladdr; /* delete addr/mask from tree */
idx_ham_func_t lookup; /* look for specific addr/mask */
idx_ha_func_t matchaddr; /* search tree for address match */
idx_walk_func_t walktree; /* walk entire tree */
} ipf_rdx_head_t;
typedef struct radix_softc {
u_char *zeros;
u_char *ones;
} radix_softc_t;
#undef RADIX_NODE_HEAD_LOCK
#undef RADIX_NODE_HEAD_UNLOCK
#ifdef _KERNEL
# define RADIX_NODE_HEAD_LOCK(x) MUTEX_ENTER(&(x)->lock)
# define RADIX_NODE_HEAD_UNLOCK(x) MUTEX_UNLOCK(&(x)->lock)
#else
# define RADIX_NODE_HEAD_LOCK(x)
# define RADIX_NODE_HEAD_UNLOCK(x)
#endif
extern void *ipf_rx_create __P((void));
extern int ipf_rx_init __P((void *));
extern void ipf_rx_destroy __P((void *));
extern int ipf_rx_inithead __P((radix_softc_t *, ipf_rdx_head_t **));
extern void ipf_rx_freehead __P((ipf_rdx_head_t *));
extern ipf_rdx_node_t *ipf_rx_addroute __P((ipf_rdx_head_t *,
addrfamily_t *, addrfamily_t *,
ipf_rdx_node_t *));
extern ipf_rdx_node_t *ipf_rx_delete __P((ipf_rdx_head_t *, addrfamily_t *,
addrfamily_t *));
extern void ipf_rx_walktree __P((ipf_rdx_head_t *, radix_walk_func_t,
void *));
#endif /* __RADIX_IPF_H__ */