1*5e3eaea3SApple OSS Distributions /* 2*5e3eaea3SApple OSS Distributions * Copyright (c) 2011-2019 Apple Inc. All rights reserved. 3*5e3eaea3SApple OSS Distributions * 4*5e3eaea3SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ 5*5e3eaea3SApple OSS Distributions * 6*5e3eaea3SApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code 7*5e3eaea3SApple OSS Distributions * as defined in and that are subject to the Apple Public Source License 8*5e3eaea3SApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in 9*5e3eaea3SApple OSS Distributions * compliance with the License. The rights granted to you under the License 10*5e3eaea3SApple OSS Distributions * may not be used to create, or enable the creation or redistribution of, 11*5e3eaea3SApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to 12*5e3eaea3SApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any 13*5e3eaea3SApple OSS Distributions * terms of an Apple operating system software license agreement. 14*5e3eaea3SApple OSS Distributions * 15*5e3eaea3SApple OSS Distributions * Please obtain a copy of the License at 16*5e3eaea3SApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file. 17*5e3eaea3SApple OSS Distributions * 18*5e3eaea3SApple OSS Distributions * The Original Code and all software distributed under the License are 19*5e3eaea3SApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 20*5e3eaea3SApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 21*5e3eaea3SApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 22*5e3eaea3SApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 23*5e3eaea3SApple OSS Distributions * Please see the License for the specific language governing rights and 24*5e3eaea3SApple OSS Distributions * limitations under the License. 25*5e3eaea3SApple OSS Distributions * 26*5e3eaea3SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ 27*5e3eaea3SApple OSS Distributions */ 28*5e3eaea3SApple OSS Distributions 29*5e3eaea3SApple OSS Distributions /* 30*5e3eaea3SApple OSS Distributions * Copyright (c) 2002 Luigi Rizzo, Universita` di Pisa 31*5e3eaea3SApple OSS Distributions * 32*5e3eaea3SApple OSS Distributions * Redistribution and use in source and binary forms, with or without 33*5e3eaea3SApple OSS Distributions * modification, are permitted provided that the following conditions 34*5e3eaea3SApple OSS Distributions * are met: 35*5e3eaea3SApple OSS Distributions * 1. Redistributions of source code must retain the above copyright 36*5e3eaea3SApple OSS Distributions * notice, this list of conditions and the following disclaimer. 37*5e3eaea3SApple OSS Distributions * 2. Redistributions in binary form must reproduce the above copyright 38*5e3eaea3SApple OSS Distributions * notice, this list of conditions and the following disclaimer in the 39*5e3eaea3SApple OSS Distributions * documentation and/or other materials provided with the distribution. 40*5e3eaea3SApple OSS Distributions * 41*5e3eaea3SApple OSS Distributions * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 42*5e3eaea3SApple OSS Distributions * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 43*5e3eaea3SApple OSS Distributions * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 44*5e3eaea3SApple OSS Distributions * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 45*5e3eaea3SApple OSS Distributions * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 46*5e3eaea3SApple OSS Distributions * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 47*5e3eaea3SApple OSS Distributions * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 48*5e3eaea3SApple OSS Distributions * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 49*5e3eaea3SApple OSS Distributions * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 50*5e3eaea3SApple OSS Distributions * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 51*5e3eaea3SApple OSS Distributions * SUCH DAMAGE. 52*5e3eaea3SApple OSS Distributions * 53*5e3eaea3SApple OSS Distributions */ 54*5e3eaea3SApple OSS Distributions 55*5e3eaea3SApple OSS Distributions #ifndef __IP_FLOWID_H__ 56*5e3eaea3SApple OSS Distributions #define __IP_FLOWID_H__ 57*5e3eaea3SApple OSS Distributions 58*5e3eaea3SApple OSS Distributions #include <sys/types.h> 59*5e3eaea3SApple OSS Distributions #include <netinet/in.h> 60*5e3eaea3SApple OSS Distributions 61*5e3eaea3SApple OSS Distributions /* 62*5e3eaea3SApple OSS Distributions * This structure is used as a flow mask and a flow id for various 63*5e3eaea3SApple OSS Distributions * parts of the code. 64*5e3eaea3SApple OSS Distributions */ 65*5e3eaea3SApple OSS Distributions struct ip_flow_id { 66*5e3eaea3SApple OSS Distributions u_int32_t dst_ip; 67*5e3eaea3SApple OSS Distributions u_int32_t src_ip; 68*5e3eaea3SApple OSS Distributions u_int16_t dst_port; 69*5e3eaea3SApple OSS Distributions u_int16_t src_port; 70*5e3eaea3SApple OSS Distributions u_int8_t proto; 71*5e3eaea3SApple OSS Distributions u_int8_t flags; /* protocol-specific flags */ 72*5e3eaea3SApple OSS Distributions u_int8_t addr_type; /* 4 = ipv4, 6 = ipv6, 1=ether ? */ 73*5e3eaea3SApple OSS Distributions struct in6_addr dst_ip6; /* could also store MAC addr! */ 74*5e3eaea3SApple OSS Distributions struct in6_addr src_ip6; 75*5e3eaea3SApple OSS Distributions u_int32_t flow_id6; 76*5e3eaea3SApple OSS Distributions u_int32_t frag_id6; 77*5e3eaea3SApple OSS Distributions }; 78*5e3eaea3SApple OSS Distributions 79*5e3eaea3SApple OSS Distributions #define IS_IP6_FLOW_ID(id) ((id)->addr_type == 6) 80*5e3eaea3SApple OSS Distributions 81*5e3eaea3SApple OSS Distributions #ifdef BSD_KERNEL_PRIVATE 82*5e3eaea3SApple OSS Distributions struct route_in6; 83*5e3eaea3SApple OSS Distributions struct sockaddr_in6; 84*5e3eaea3SApple OSS Distributions struct pf_rule; 85*5e3eaea3SApple OSS Distributions 86*5e3eaea3SApple OSS Distributions /* 87*5e3eaea3SApple OSS Distributions * Arguments for calling ipfw_chk() and dummynet_io(). We put them 88*5e3eaea3SApple OSS Distributions * all into a structure because this way it is easier and more 89*5e3eaea3SApple OSS Distributions * efficient to pass variables around and extend the interface. 90*5e3eaea3SApple OSS Distributions */ 91*5e3eaea3SApple OSS Distributions struct ip_fw_args { 92*5e3eaea3SApple OSS Distributions struct mbuf *fwa_m; /* the mbuf chain */ 93*5e3eaea3SApple OSS Distributions struct ifnet *fwa_oif; /* output interface */ 94*5e3eaea3SApple OSS Distributions struct pf_rule *fwa_pf_rule; /* matching PF rule */ 95*5e3eaea3SApple OSS Distributions struct ether_header *fwa_eh; /* for bridged packets */ 96*5e3eaea3SApple OSS Distributions int fwa_flags; /* for dummynet */ 97*5e3eaea3SApple OSS Distributions int fwa_oflags; /* for dummynet */ 98*5e3eaea3SApple OSS Distributions union { 99*5e3eaea3SApple OSS Distributions struct ip_out_args *_fwa_ipoa; /* for dummynet */ 100*5e3eaea3SApple OSS Distributions struct ip6_out_args *_fwa_ip6oa; /* for dummynet */ 101*5e3eaea3SApple OSS Distributions } fwa_ipoa_; 102*5e3eaea3SApple OSS Distributions union { 103*5e3eaea3SApple OSS Distributions struct route *_fwa_ro; /* for dummynet */ 104*5e3eaea3SApple OSS Distributions struct route_in6 *_fwa_ro6; /* for dummynet */ 105*5e3eaea3SApple OSS Distributions } fwa_ro_; 106*5e3eaea3SApple OSS Distributions union { 107*5e3eaea3SApple OSS Distributions struct sockaddr_in *_fwa_dst; /* for dummynet */ 108*5e3eaea3SApple OSS Distributions struct sockaddr_in6 *_fwa_dst6; /* for IPv6 dummynet */ 109*5e3eaea3SApple OSS Distributions } fwa_dst_; 110*5e3eaea3SApple OSS Distributions struct route_in6 *fwa_ro6_pmtu; /* for IPv6 output */ 111*5e3eaea3SApple OSS Distributions struct ifnet *fwa_origifp; /* for IPv6 output */ 112*5e3eaea3SApple OSS Distributions u_int32_t fwa_mtu; /* for IPv6 output */ 113*5e3eaea3SApple OSS Distributions u_int32_t fwa_unfragpartlen; /* for IPv6 output */ 114*5e3eaea3SApple OSS Distributions struct ip6_exthdrs *fwa_exthdrs; /* for IPv6 output */ 115*5e3eaea3SApple OSS Distributions struct ip_flow_id fwa_id; /* grabbed from IP header */ 116*5e3eaea3SApple OSS Distributions u_int32_t fwa_cookie; 117*5e3eaea3SApple OSS Distributions }; 118*5e3eaea3SApple OSS Distributions #define fwa_ipoa fwa_ipoa_._fwa_ipoa 119*5e3eaea3SApple OSS Distributions #define fwa_ip6oa fwa_ipoa_._fwa_ip6oa 120*5e3eaea3SApple OSS Distributions #define fwa_ro fwa_ro_._fwa_ro 121*5e3eaea3SApple OSS Distributions #define fwa_ro6 fwa_ro_._fwa_ro6 122*5e3eaea3SApple OSS Distributions #define fwa_dst fwa_dst_._fwa_dst 123*5e3eaea3SApple OSS Distributions #define fwa_dst6 fwa_dst_._fwa_dst6 124*5e3eaea3SApple OSS Distributions 125*5e3eaea3SApple OSS Distributions /* Allocate a separate structure for inputs args to save space and bzero time */ 126*5e3eaea3SApple OSS Distributions struct ip_fw_in_args { 127*5e3eaea3SApple OSS Distributions struct pf_rule *fwai_pf_rule; /* matching PF rule */ 128*5e3eaea3SApple OSS Distributions }; 129*5e3eaea3SApple OSS Distributions 130*5e3eaea3SApple OSS Distributions #endif /* BSD_KERNEL_PRIVATE */ 131*5e3eaea3SApple OSS Distributions 132*5e3eaea3SApple OSS Distributions #endif /* __IP_FLOWID_H__ */ 133