/* $NetBSD: npf.h,v 1.54.6.2 2018/05/09 15:35:37 martin Exp $ */ /*- * Copyright (c) 2009-2014 The NetBSD Foundation, Inc. * All rights reserved. * * This material is based upon work partially supported by The * NetBSD Foundation under a contract with Mindaugas Rasiukevicius. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ /* * Public NPF interfaces. */ #ifndef _NPF_NET_H_ #define _NPF_NET_H_ #include #include #define NPF_VERSION 19 #if defined(_NPF_STANDALONE) #include "npf_stand.h" #else #include #include #include #include #endif struct npf; typedef struct npf npf_t; /* * Storage of address (both for IPv4 and IPv6) and netmask. */ typedef union { uint8_t word8[16]; uint16_t word16[8]; uint32_t word32[4]; } npf_addr_t; typedef uint8_t npf_netmask_t; #define NPF_MAX_NETMASK (128) #define NPF_NO_NETMASK ((npf_netmask_t)~0) /* BPF coprocessor. */ #if defined(NPF_BPFCOP) #define NPF_COP_L3 0 #define NPF_COP_TABLE 1 #define BPF_MW_IPVER 0 #define BPF_MW_L4OFF 1 #define BPF_MW_L4PROTO 2 #endif /* The number of words used. */ #define NPF_BPF_NWORDS 3 /* * In-kernel declarations and definitions. */ #if defined(_KERNEL) || defined(_NPF_STANDALONE) #define NPF_DECISION_BLOCK 0 #define NPF_DECISION_PASS 1 #define NPF_EXT_MODULE(name, req) \ MODULE(MODULE_CLASS_MISC, name, (sizeof(req) - 1) ? ("npf," req) : "npf") #include #include #include #include #include #include #include /* * Network buffer interface. */ #define NBUF_DATAREF_RESET 0x01 struct mbuf; struct nbuf; typedef struct nbuf nbuf_t; void nbuf_init(npf_t *, nbuf_t *, struct mbuf *, const ifnet_t *); void nbuf_reset(nbuf_t *); struct mbuf * nbuf_head_mbuf(nbuf_t *); bool nbuf_flag_p(const nbuf_t *, int); void nbuf_unset_flag(nbuf_t *, int); void * nbuf_dataptr(nbuf_t *); size_t nbuf_offset(const nbuf_t *); void * nbuf_advance(nbuf_t *, size_t, size_t); void * nbuf_ensure_contig(nbuf_t *, size_t); void * nbuf_ensure_writable(nbuf_t *, size_t); bool nbuf_cksum_barrier(nbuf_t *, int); int nbuf_add_tag(nbuf_t *, uint32_t); int nbuf_find_tag(nbuf_t *, uint32_t *); /* * Packet information cache. */ #define NPC_IP4 0x01 /* Indicates IPv4 header. */ #define NPC_IP6 0x02 /* Indicates IPv6 header. */ #define NPC_IPFRAG 0x04 /* IPv4/IPv6 fragment. */ #define NPC_LAYER4 0x08 /* Layer 4 has been fetched. */ #define NPC_TCP 0x10 /* TCP header. */ #define NPC_UDP 0x20 /* UDP header. */ #define NPC_ICMP 0x40 /* ICMP header. */ #define NPC_ICMP_ID 0x80 /* ICMP with query ID. */ #define NPC_ALG_EXEC 0x100 /* ALG execution. */ #define NPC_FMTERR 0x200 /* Format error. */ #define NPC_IP46 (NPC_IP4|NPC_IP6) typedef struct { /* NPF context, information flags and the nbuf. */ npf_t * npc_ctx; uint32_t npc_info; nbuf_t * npc_nbuf; /* * Pointers to the IP source and destination addresses, * and the address length (4 for IPv4 or 16 for IPv6). */ npf_addr_t * npc_ips[2]; uint8_t npc_alen; /* IP header length and L4 protocol. */ uint32_t npc_hlen; uint16_t npc_proto; /* IPv4, IPv6. */ union { struct ip * v4; struct ip6_hdr * v6; } npc_ip; /* TCP, UDP, ICMP. */ union { struct tcphdr * tcp; struct udphdr * udp; struct icmp * icmp; struct icmp6_hdr * icmp6; void * hdr; } npc_l4; } npf_cache_t; static inline bool npf_iscached(const npf_cache_t *npc, const int inf) { KASSERT(npc->npc_nbuf != NULL); return __predict_true((npc->npc_info & inf) != 0); } #define NPF_SRC 0 #define NPF_DST 1 /* * NPF extensions and rule procedure interface. */ struct npf_rproc; typedef struct npf_rproc npf_rproc_t; typedef struct { uint64_t mi_rid; u_int mi_retfl; u_int mi_di; } npf_match_info_t; typedef struct { unsigned int version; void * ctx; int (*ctor)(npf_rproc_t *, prop_dictionary_t); void (*dtor)(npf_rproc_t *, void *); bool (*proc)(npf_cache_t *, void *, const npf_match_info_t *, int *); } npf_ext_ops_t; void * npf_ext_register(npf_t *, const char *, const npf_ext_ops_t *); int npf_ext_unregister(npf_t *, void *); void npf_rproc_assign(npf_rproc_t *, void *); /* * Misc. */ bool npf_autounload_p(void); #endif /* _KERNEL */ /* Rule attributes. */ #define NPF_RULE_PASS 0x00000001 #define NPF_RULE_GROUP 0x00000002 #define NPF_RULE_FINAL 0x00000004 #define NPF_RULE_STATEFUL 0x00000008 #define NPF_RULE_RETRST 0x00000010 #define NPF_RULE_RETICMP 0x00000020 #define NPF_RULE_DYNAMIC 0x00000040 #define NPF_RULE_MULTIENDS 0x00000080 #define NPF_DYNAMIC_GROUP (NPF_RULE_GROUP | NPF_RULE_DYNAMIC) #define NPF_RULE_IN 0x10000000 #define NPF_RULE_OUT 0x20000000 #define NPF_RULE_DIMASK (NPF_RULE_IN | NPF_RULE_OUT) #define NPF_RULE_FORW 0x40000000 /* Private range of rule attributes (not public and should not be set). */ #define NPF_RULE_PRIVMASK 0x0f000000 #define NPF_RULE_MAXNAMELEN 64 #define NPF_RULE_MAXKEYLEN 32 /* Priority values. */ #define NPF_PRI_FIRST (-2) #define NPF_PRI_LAST (-1) /* Types of code. */ #define NPF_CODE_NC 1 #define NPF_CODE_BPF 2 /* Address translation types and flags. */ #define NPF_NATIN 1 #define NPF_NATOUT 2 #define NPF_NAT_PORTS 0x01 #define NPF_NAT_PORTMAP 0x02 #define NPF_NAT_STATIC 0x04 #define NPF_ALGO_NPT66 1 /* Table types. */ #define NPF_TABLE_HASH 1 #define NPF_TABLE_TREE 2 #define NPF_TABLE_CDB 3 #define NPF_TABLE_MAXNAMELEN 32 /* Layers. */ #define NPF_LAYER_2 2 #define NPF_LAYER_3 3 /* XXX mbuf.h: just for now. */ #define PACKET_TAG_NPF 10 #define NPF_NTAG_PASS 0x0001 /* * Rule commands (non-ioctl). */ #define NPF_CMD_RULE_ADD 1 #define NPF_CMD_RULE_INSERT 2 #define NPF_CMD_RULE_REMOVE 3 #define NPF_CMD_RULE_REMKEY 4 #define NPF_CMD_RULE_LIST 5 #define NPF_CMD_RULE_FLUSH 6 /* * NPF ioctl(2): table commands and structures. */ #define NPF_CMD_TABLE_LOOKUP 1 #define NPF_CMD_TABLE_ADD 2 #define NPF_CMD_TABLE_REMOVE 3 #define NPF_CMD_TABLE_LIST 4 #define NPF_CMD_TABLE_FLUSH 5 typedef struct npf_ioctl_ent { int alen; npf_addr_t addr; npf_netmask_t mask; } npf_ioctl_ent_t; typedef struct npf_ioctl_buf { void * buf; size_t len; } npf_ioctl_buf_t; typedef struct npf_ioctl_table { int nct_cmd; const char * nct_name; union { npf_ioctl_ent_t ent; npf_ioctl_buf_t buf; } nct_data; } npf_ioctl_table_t; /* * IOCTL operations. */ #define IOC_NPF_VERSION _IOR('N', 100, int) #define IOC_NPF_SWITCH _IOW('N', 101, int) #define IOC_NPF_LOAD _IOWR('N', 102, struct plistref) #define IOC_NPF_TABLE _IOW('N', 103, struct npf_ioctl_table) #define IOC_NPF_STATS _IOW('N', 104, void *) #define IOC_NPF_SAVE _IOR('N', 105, struct plistref) #define IOC_NPF_RULE _IOWR('N', 107, struct plistref) #define IOC_NPF_CONN_LOOKUP _IOWR('N', 108, struct plistref) /* * NPF error report. */ typedef struct { int64_t id; char * source_file; u_int source_line; } npf_error_t; /* * Statistics counters. */ typedef enum { /* Packets passed. */ NPF_STAT_PASS_DEFAULT, NPF_STAT_PASS_RULESET, NPF_STAT_PASS_CONN, /* Packets blocked. */ NPF_STAT_BLOCK_DEFAULT, NPF_STAT_BLOCK_RULESET, /* Connection and NAT entries. */ NPF_STAT_CONN_CREATE, NPF_STAT_CONN_DESTROY, NPF_STAT_NAT_CREATE, NPF_STAT_NAT_DESTROY, /* Invalid state cases. */ NPF_STAT_INVALID_STATE, NPF_STAT_INVALID_STATE_TCP1, NPF_STAT_INVALID_STATE_TCP2, NPF_STAT_INVALID_STATE_TCP3, /* Raced packets. */ NPF_STAT_RACE_CONN, NPF_STAT_RACE_NAT, /* Fragments. */ NPF_STAT_FRAGMENTS, NPF_STAT_REASSEMBLY, NPF_STAT_REASSFAIL, /* Other errors. */ NPF_STAT_ERROR, /* nbuf non-contiguous cases. */ NPF_STAT_NBUF_NONCONTIG, NPF_STAT_NBUF_CONTIG_FAIL, /* Count (last). */ NPF_STATS_COUNT } npf_stats_t; #define NPF_STATS_SIZE (sizeof(uint64_t) * NPF_STATS_COUNT) #endif /* _NPF_NET_H_ */