| /* |
| * Copyright (C) 2012 by Darren Reed. |
| * |
| * See the IPFILTER.LICENCE file for details on licencing. |
| * |
| * @(#)ip_frag.h 1.5 3/24/96 |
| * $Id$ |
| */ |
| |
| #ifndef __IP_FRAG_H__ |
| #define __IP_FRAG_H__ |
| |
| #define IPFT_SIZE 257 |
| |
| typedef struct ipfr { |
| struct ipfr *ipfr_hnext, **ipfr_hprev; |
| struct ipfr *ipfr_next, **ipfr_prev; |
| void *ipfr_data; |
| frentry_t *ipfr_rule; |
| u_long ipfr_ttl; |
| u_int ipfr_pkts; |
| u_int ipfr_bytes; |
| u_int ipfr_badorder; |
| int ipfr_ref; |
| u_short ipfr_off; |
| u_short ipfr_firstend; |
| u_char ipfr_p; |
| u_char ipfr_seen0; |
| /* |
| * All of the fields, from ipfr_ifp to ipfr_pass, are compared |
| * using bcmp to see if an identical entry is present. It is |
| * therefore important for this set to remain together. |
| */ |
| void *ipfr_ifp; |
| i6addr_t ipfr_source; |
| i6addr_t ipfr_dest; |
| u_32_t ipfr_optmsk; |
| u_short ipfr_secmsk; |
| u_short ipfr_auth; |
| u_32_t ipfr_id; |
| u_32_t ipfr_pass; |
| int ipfr_v; |
| } ipfr_t; |
| |
| #define ipfr_src ipfr_source.in4 |
| #define ipfr_dst ipfr_dest.in4 |
| |
| |
| typedef struct ipfrstat { |
| u_long ifs_exists; /* add & already exists */ |
| u_long ifs_nomem; |
| u_long ifs_new; |
| u_long ifs_hits; |
| u_long ifs_expire; |
| u_long ifs_inuse; |
| u_long ifs_retrans0; |
| u_long ifs_short; |
| u_long ifs_bad; |
| u_long ifs_overlap; |
| u_long ifs_unordered; |
| u_long ifs_strict; |
| u_long ifs_miss; |
| u_long ifs_maximum; |
| u_long ifs_newbad; |
| u_long ifs_newrestrictnot0; |
| struct ipfr **ifs_table; |
| struct ipfr **ifs_nattab; |
| } ipfrstat_t; |
| |
| #define IPFR_CMPSZ (offsetof(ipfr_t, ipfr_pass) - \ |
| offsetof(ipfr_t, ipfr_ifp)) |
| |
| extern void *ipf_frag_soft_create __P((ipf_main_softc_t *)); |
| extern int ipf_frag_soft_init __P((ipf_main_softc_t *, void *)); |
| extern int ipf_frag_soft_fini __P((ipf_main_softc_t *, void *)); |
| extern void ipf_frag_soft_destroy __P((ipf_main_softc_t *, void *)); |
| extern int ipf_frag_main_load __P((void)); |
| extern int ipf_frag_main_unload __P((void)); |
| extern int ipf_frag_load __P((void)); |
| extern void ipf_frag_clear __P((ipf_main_softc_t *)); |
| extern void ipf_frag_expire __P((ipf_main_softc_t *)); |
| extern void ipf_frag_forget __P((void *)); |
| extern int ipf_frag_init __P((void)); |
| extern u_32_t ipf_frag_ipidknown __P((fr_info_t *)); |
| extern int ipf_frag_ipidnew __P((fr_info_t *, u_32_t)); |
| extern frentry_t *ipf_frag_known __P((fr_info_t *, u_32_t *)); |
| extern void ipf_frag_natforget __P((ipf_main_softc_t *, void *)); |
| extern int ipf_frag_natnew __P((ipf_main_softc_t *, fr_info_t *, u_32_t, struct nat *)); |
| extern nat_t *ipf_frag_natknown __P((fr_info_t *)); |
| extern int ipf_frag_new __P((ipf_main_softc_t *, fr_info_t *, u_32_t)); |
| extern ipfrstat_t *ipf_frag_stats __P((void *)); |
| extern void ipf_frag_setlock __P((void *, int)); |
| extern void ipf_frag_pkt_deref __P((ipf_main_softc_t *, void *)); |
| extern int ipf_frag_pkt_next __P((ipf_main_softc_t *, ipftoken_t *, |
| ipfgeniter_t *)); |
| extern void ipf_frag_nat_deref __P((ipf_main_softc_t *, void *)); |
| extern int ipf_frag_nat_next __P((ipf_main_softc_t *, ipftoken_t *, |
| ipfgeniter_t *)); |
| extern void ipf_slowtimer __P((ipf_main_softc_t *)); |
| |
| #endif /* __IP_FRAG_H__ */ |