1 1.4 maxv /* $NetBSD: if_pfsync.h,v 1.4 2018/09/14 05:09:51 maxv Exp $ */ 2 1.3 degroote /* $OpenBSD: if_pfsync.h,v 1.31 2007/05/31 04:11:42 mcbride Exp $ */ 3 1.1 itojun 4 1.1 itojun /* 5 1.1 itojun * Copyright (c) 2001 Michael Shalayeff 6 1.1 itojun * All rights reserved. 7 1.1 itojun * 8 1.1 itojun * Redistribution and use in source and binary forms, with or without 9 1.1 itojun * modification, are permitted provided that the following conditions 10 1.1 itojun * are met: 11 1.1 itojun * 1. Redistributions of source code must retain the above copyright 12 1.1 itojun * notice, this list of conditions and the following disclaimer. 13 1.1 itojun * 2. Redistributions in binary form must reproduce the above copyright 14 1.1 itojun * notice, this list of conditions and the following disclaimer in the 15 1.1 itojun * documentation and/or other materials provided with the distribution. 16 1.1 itojun * 17 1.1 itojun * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 18 1.1 itojun * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 19 1.1 itojun * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 20 1.1 itojun * IN NO EVENT SHALL THE AUTHOR OR HIS RELATIVES BE LIABLE FOR ANY DIRECT, 21 1.1 itojun * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 22 1.1 itojun * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 23 1.1 itojun * SERVICES; LOSS OF MIND, USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 24 1.1 itojun * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 25 1.1 itojun * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 26 1.1 itojun * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF 27 1.1 itojun * THE POSSIBILITY OF SUCH DAMAGE. 28 1.1 itojun */ 29 1.1 itojun 30 1.1 itojun #ifndef _NET_IF_PFSYNC_H_ 31 1.1 itojun #define _NET_IF_PFSYNC_H_ 32 1.1 itojun 33 1.3 degroote #define INADDR_PFSYNC_GROUP __IPADDR(0xe00000f0) /* 224.0.0.240 */ 34 1.1 itojun 35 1.1 itojun #define PFSYNC_ID_LEN sizeof(u_int64_t) 36 1.1 itojun 37 1.3 degroote struct pfsync_tdb { 38 1.3 degroote u_int32_t spi; 39 1.3 degroote union sockaddr_union dst; 40 1.3 degroote u_int32_t rpl; 41 1.3 degroote u_int64_t cur_bytes; 42 1.3 degroote u_int8_t sproto; 43 1.3 degroote u_int8_t updates; 44 1.3 degroote u_int8_t pad[2]; 45 1.1 itojun } __packed; 46 1.1 itojun 47 1.1 itojun struct pfsync_state_upd { 48 1.1 itojun u_int32_t id[2]; 49 1.1 itojun struct pfsync_state_peer src; 50 1.1 itojun struct pfsync_state_peer dst; 51 1.1 itojun u_int32_t creatorid; 52 1.1 itojun u_int32_t expire; 53 1.1 itojun u_int8_t timeout; 54 1.1 itojun u_int8_t updates; 55 1.1 itojun u_int8_t pad[6]; 56 1.1 itojun } __packed; 57 1.1 itojun 58 1.1 itojun struct pfsync_state_del { 59 1.1 itojun u_int32_t id[2]; 60 1.1 itojun u_int32_t creatorid; 61 1.1 itojun struct { 62 1.1 itojun u_int8_t state; 63 1.1 itojun } src; 64 1.1 itojun struct { 65 1.1 itojun u_int8_t state; 66 1.1 itojun } dst; 67 1.1 itojun u_int8_t pad[2]; 68 1.1 itojun } __packed; 69 1.1 itojun 70 1.1 itojun struct pfsync_state_upd_req { 71 1.1 itojun u_int32_t id[2]; 72 1.1 itojun u_int32_t creatorid; 73 1.1 itojun u_int32_t pad; 74 1.1 itojun } __packed; 75 1.1 itojun 76 1.1 itojun struct pfsync_state_clr { 77 1.1 itojun char ifname[IFNAMSIZ]; 78 1.1 itojun u_int32_t creatorid; 79 1.1 itojun u_int32_t pad; 80 1.1 itojun } __packed; 81 1.1 itojun 82 1.1 itojun struct pfsync_state_bus { 83 1.1 itojun u_int32_t creatorid; 84 1.1 itojun u_int32_t endtime; 85 1.1 itojun u_int8_t status; 86 1.1 itojun #define PFSYNC_BUS_START 1 87 1.1 itojun #define PFSYNC_BUS_END 2 88 1.1 itojun u_int8_t pad[7]; 89 1.1 itojun } __packed; 90 1.1 itojun 91 1.1 itojun #ifdef _KERNEL 92 1.1 itojun 93 1.1 itojun union sc_statep { 94 1.1 itojun struct pfsync_state *s; 95 1.1 itojun struct pfsync_state_upd *u; 96 1.1 itojun struct pfsync_state_del *d; 97 1.1 itojun struct pfsync_state_clr *c; 98 1.1 itojun struct pfsync_state_bus *b; 99 1.1 itojun struct pfsync_state_upd_req *r; 100 1.1 itojun }; 101 1.1 itojun 102 1.3 degroote union sc_tdb_statep { 103 1.3 degroote struct pfsync_tdb *t; 104 1.3 degroote }; 105 1.3 degroote 106 1.1 itojun extern int pfsync_sync_ok; 107 1.1 itojun 108 1.1 itojun struct pfsync_softc { 109 1.1 itojun struct ifnet sc_if; 110 1.1 itojun struct ifnet *sc_sync_ifp; 111 1.1 itojun 112 1.1 itojun struct ip_moptions sc_imo; 113 1.3 degroote struct callout sc_tmo; 114 1.3 degroote struct callout sc_tdb_tmo; 115 1.3 degroote struct callout sc_bulk_tmo; 116 1.3 degroote struct callout sc_bulkfail_tmo; 117 1.3 degroote struct in_addr sc_sync_peer; 118 1.1 itojun struct in_addr sc_sendaddr; 119 1.3 degroote struct mbuf *sc_mbuf; /* current cumulative mbuf */ 120 1.3 degroote struct mbuf *sc_mbuf_net; /* current cumulative mbuf */ 121 1.3 degroote struct mbuf *sc_mbuf_tdb; /* dito for TDB updates */ 122 1.1 itojun union sc_statep sc_statep; 123 1.1 itojun union sc_statep sc_statep_net; 124 1.3 degroote union sc_tdb_statep sc_statep_tdb; 125 1.1 itojun u_int32_t sc_ureq_received; 126 1.1 itojun u_int32_t sc_ureq_sent; 127 1.3 degroote struct pf_state *sc_bulk_send_next; 128 1.3 degroote struct pf_state *sc_bulk_terminator; 129 1.1 itojun int sc_bulk_tries; 130 1.1 itojun int sc_maxcount; /* number of states in mtu */ 131 1.1 itojun int sc_maxupdates; /* number of updates/state */ 132 1.1 itojun }; 133 1.3 degroote 134 1.3 degroote extern struct pfsync_softc *pfsyncif; 135 1.1 itojun #endif 136 1.1 itojun 137 1.1 itojun 138 1.1 itojun struct pfsync_header { 139 1.1 itojun u_int8_t version; 140 1.3 degroote #define PFSYNC_VERSION 3 141 1.1 itojun u_int8_t af; 142 1.1 itojun u_int8_t action; 143 1.1 itojun #define PFSYNC_ACT_CLR 0 /* clear all states */ 144 1.1 itojun #define PFSYNC_ACT_INS 1 /* insert state */ 145 1.1 itojun #define PFSYNC_ACT_UPD 2 /* update state */ 146 1.1 itojun #define PFSYNC_ACT_DEL 3 /* delete state */ 147 1.1 itojun #define PFSYNC_ACT_UPD_C 4 /* "compressed" state update */ 148 1.1 itojun #define PFSYNC_ACT_DEL_C 5 /* "compressed" state delete */ 149 1.1 itojun #define PFSYNC_ACT_INS_F 6 /* insert fragment */ 150 1.1 itojun #define PFSYNC_ACT_DEL_F 7 /* delete fragments */ 151 1.1 itojun #define PFSYNC_ACT_UREQ 8 /* request "uncompressed" state */ 152 1.1 itojun #define PFSYNC_ACT_BUS 9 /* Bulk Update Status */ 153 1.3 degroote #define PFSYNC_ACT_TDB_UPD 10 /* TDB replay counter update */ 154 1.3 degroote #define PFSYNC_ACT_MAX 11 155 1.1 itojun u_int8_t count; 156 1.3 degroote u_int8_t pf_chksum[PF_MD5_DIGEST_LENGTH]; 157 1.1 itojun } __packed; 158 1.1 itojun 159 1.1 itojun #define PFSYNC_BULKPACKETS 1 /* # of packets per timeout */ 160 1.3 degroote #define PFSYNC_MAX_BULKTRIES 12 161 1.1 itojun #define PFSYNC_HDRLEN sizeof(struct pfsync_header) 162 1.1 itojun #define PFSYNC_ACTIONS \ 163 1.1 itojun "CLR ST", "INS ST", "UPD ST", "DEL ST", \ 164 1.1 itojun "UPD ST COMP", "DEL ST COMP", "INS FR", "DEL FR", \ 165 1.3 degroote "UPD REQ", "BLK UPD STAT", "TDB UPD" 166 1.1 itojun 167 1.1 itojun #define PFSYNC_DFLTTL 255 168 1.1 itojun 169 1.3 degroote #define PFSYNC_STAT_IPACKETS 0 /* total input packets, IPv4 */ 170 1.3 degroote #define PFSYNC_STAT_IPACKETS6 1 /* total input packets, IPv6 */ 171 1.3 degroote #define PFSYNC_STAT_BADIF 2 /* not the right interface */ 172 1.3 degroote #define PFSYNC_STAT_BADTTL 3 /* TTL is not PFSYNC_DFLTTL */ 173 1.3 degroote #define PFSYNC_STAT_HDROPS 4 /* packets shorter than hdr */ 174 1.3 degroote #define PFSYNC_STAT_BADVER 5 /* bad (incl unsupp) version */ 175 1.3 degroote #define PFSYNC_STAT_BADACT 6 /* bad action */ 176 1.3 degroote #define PFSYNC_STAT_BADLEN 7 /* data length does not match */ 177 1.3 degroote #define PFSYNC_STAT_BADAUTH 8 /* bad authentication */ 178 1.3 degroote #define PFSYNC_STAT_STALE 9 /* stale state */ 179 1.3 degroote #define PFSYNC_STAT_BADVAL 10 /* bad values */ 180 1.3 degroote #define PFSYNC_STAT_BADSTATE 11 /* insert/lookup failed */ 181 1.3 degroote #define PFSYNC_STAT_OPACKETS 12 /* total output packets, IPv4 */ 182 1.3 degroote #define PFSYNC_STAT_OPACKETS6 13 /* total output packets, IPv6 */ 183 1.3 degroote #define PFSYNC_STAT_ONOMEM 14 /* no memory for an mbuf */ 184 1.3 degroote #define PFSYNC_STAT_OERRORS 15 /* ip output error */ 185 1.3 degroote 186 1.3 degroote #define PFSYNC_NSTATS 16 187 1.1 itojun 188 1.1 itojun /* 189 1.1 itojun * Configuration structure for SIOCSETPFSYNC SIOCGETPFSYNC 190 1.1 itojun */ 191 1.1 itojun struct pfsyncreq { 192 1.3 degroote char pfsyncr_syncdev[IFNAMSIZ]; 193 1.3 degroote struct in_addr pfsyncr_syncpeer; 194 1.3 degroote int pfsyncr_maxupdates; 195 1.3 degroote int pfsyncr_authlevel; 196 1.1 itojun }; 197 1.1 itojun 198 1.1 itojun 199 1.3 degroote /* for copies to/from network */ 200 1.1 itojun #define pf_state_peer_hton(s,d) do { \ 201 1.1 itojun (d)->seqlo = htonl((s)->seqlo); \ 202 1.1 itojun (d)->seqhi = htonl((s)->seqhi); \ 203 1.1 itojun (d)->seqdiff = htonl((s)->seqdiff); \ 204 1.1 itojun (d)->max_win = htons((s)->max_win); \ 205 1.1 itojun (d)->mss = htons((s)->mss); \ 206 1.1 itojun (d)->state = (s)->state; \ 207 1.1 itojun (d)->wscale = (s)->wscale; \ 208 1.3 degroote if ((s)->scrub) { \ 209 1.3 degroote (d)->scrub.pfss_flags = \ 210 1.3 degroote htons((s)->scrub->pfss_flags & PFSS_TIMESTAMP); \ 211 1.3 degroote (d)->scrub.pfss_ttl = (s)->scrub->pfss_ttl; \ 212 1.3 degroote (d)->scrub.pfss_ts_mod = htonl((s)->scrub->pfss_ts_mod);\ 213 1.3 degroote (d)->scrub.scrub_flag = PFSYNC_SCRUB_FLAG_VALID; \ 214 1.3 degroote } \ 215 1.1 itojun } while (0) 216 1.1 itojun 217 1.1 itojun #define pf_state_peer_ntoh(s,d) do { \ 218 1.1 itojun (d)->seqlo = ntohl((s)->seqlo); \ 219 1.1 itojun (d)->seqhi = ntohl((s)->seqhi); \ 220 1.1 itojun (d)->seqdiff = ntohl((s)->seqdiff); \ 221 1.1 itojun (d)->max_win = ntohs((s)->max_win); \ 222 1.1 itojun (d)->mss = ntohs((s)->mss); \ 223 1.1 itojun (d)->state = (s)->state; \ 224 1.1 itojun (d)->wscale = (s)->wscale; \ 225 1.3 degroote if ((s)->scrub.scrub_flag == PFSYNC_SCRUB_FLAG_VALID && \ 226 1.3 degroote (d)->scrub != NULL) { \ 227 1.3 degroote (d)->scrub->pfss_flags = \ 228 1.3 degroote ntohs((s)->scrub.pfss_flags) & PFSS_TIMESTAMP; \ 229 1.3 degroote (d)->scrub->pfss_ttl = (s)->scrub.pfss_ttl; \ 230 1.3 degroote (d)->scrub->pfss_ts_mod = ntohl((s)->scrub.pfss_ts_mod);\ 231 1.3 degroote } \ 232 1.1 itojun } while (0) 233 1.1 itojun 234 1.1 itojun #define pf_state_host_hton(s,d) do { \ 235 1.3 degroote memcpy(&(d)->addr, &(s)->addr, sizeof((d)->addr)); \ 236 1.1 itojun (d)->port = (s)->port; \ 237 1.1 itojun } while (0) 238 1.1 itojun 239 1.1 itojun #define pf_state_host_ntoh(s,d) do { \ 240 1.3 degroote memcpy(&(d)->addr, &(s)->addr, sizeof((d)->addr)); \ 241 1.1 itojun (d)->port = (s)->port; \ 242 1.1 itojun } while (0) 243 1.1 itojun 244 1.3 degroote #define pf_state_counter_hton(s,d) do { \ 245 1.3 degroote d[0] = htonl((s>>32)&0xffffffff); \ 246 1.3 degroote d[1] = htonl(s&0xffffffff); \ 247 1.3 degroote } while (0) 248 1.3 degroote 249 1.3 degroote #define pf_state_counter_ntoh(s,d) do { \ 250 1.3 degroote d = ntohl(s[0]); \ 251 1.3 degroote d = d<<32; \ 252 1.3 degroote d += ntohl(s[1]); \ 253 1.3 degroote } while (0) 254 1.3 degroote 255 1.1 itojun #ifdef _KERNEL 256 1.4 maxv void pfsync_input(struct mbuf *, int, int); 257 1.1 itojun int pfsync_clear_states(u_int32_t, char *); 258 1.1 itojun int pfsync_pack_state(u_int8_t, struct pf_state *, int); 259 1.1 itojun #define pfsync_insert_state(st) do { \ 260 1.1 itojun if ((st->rule.ptr->rule_flag & PFRULE_NOSYNC) || \ 261 1.3 degroote (st->state_key->proto == IPPROTO_PFSYNC)) \ 262 1.1 itojun st->sync_flags |= PFSTATE_NOSYNC; \ 263 1.1 itojun else if (!st->sync_flags) \ 264 1.3 degroote pfsync_pack_state(PFSYNC_ACT_INS, (st), \ 265 1.3 degroote PFSYNC_FLAG_COMPRESS); \ 266 1.1 itojun st->sync_flags &= ~PFSTATE_FROMSYNC; \ 267 1.1 itojun } while (0) 268 1.1 itojun #define pfsync_update_state(st) do { \ 269 1.1 itojun if (!st->sync_flags) \ 270 1.3 degroote pfsync_pack_state(PFSYNC_ACT_UPD, (st), \ 271 1.3 degroote PFSYNC_FLAG_COMPRESS); \ 272 1.1 itojun st->sync_flags &= ~PFSTATE_FROMSYNC; \ 273 1.1 itojun } while (0) 274 1.1 itojun #define pfsync_delete_state(st) do { \ 275 1.1 itojun if (!st->sync_flags) \ 276 1.3 degroote pfsync_pack_state(PFSYNC_ACT_DEL, (st), \ 277 1.3 degroote PFSYNC_FLAG_COMPRESS); \ 278 1.1 itojun } while (0) 279 1.3 degroote #ifdef NOTYET 280 1.3 degroote int pfsync_update_tdb(struct tdb *, int); 281 1.3 degroote #endif /* NOTYET */ 282 1.1 itojun #endif 283 1.1 itojun 284 1.1 itojun #endif /* _NET_IF_PFSYNC_H_ */ 285