xref: /xnu-11215.1.10/bsd/net/packet_mangler.h (revision 8d741a5de7ff4191bf97d57b9f54c2f6d4a15585)
1*8d741a5dSApple OSS Distributions /*
2*8d741a5dSApple OSS Distributions  * Copyright (c) 2014 Apple Inc. All rights reserved.
3*8d741a5dSApple OSS Distributions  *
4*8d741a5dSApple OSS Distributions  * @APPLE_LICENSE_HEADER_START@
5*8d741a5dSApple OSS Distributions  *
6*8d741a5dSApple OSS Distributions  * This file contains Original Code and/or Modifications of Original Code
7*8d741a5dSApple OSS Distributions  * as defined in and that are subject to the Apple Public Source License
8*8d741a5dSApple OSS Distributions  * Version 2.0 (the 'License'). You may not use this file except in
9*8d741a5dSApple OSS Distributions  * compliance with the License. Please obtain a copy of the License at
10*8d741a5dSApple OSS Distributions  * http://www.opensource.apple.com/apsl/ and read it before using this
11*8d741a5dSApple OSS Distributions  * file.
12*8d741a5dSApple OSS Distributions  *
13*8d741a5dSApple OSS Distributions  * The Original Code and all software distributed under the License are
14*8d741a5dSApple OSS Distributions  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15*8d741a5dSApple OSS Distributions  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16*8d741a5dSApple OSS Distributions  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17*8d741a5dSApple OSS Distributions  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18*8d741a5dSApple OSS Distributions  * Please see the License for the specific language governing rights and
19*8d741a5dSApple OSS Distributions  * limitations under the License.
20*8d741a5dSApple OSS Distributions  *
21*8d741a5dSApple OSS Distributions  * @APPLE_LICENSE_HEADER_END@
22*8d741a5dSApple OSS Distributions  */
23*8d741a5dSApple OSS Distributions 
24*8d741a5dSApple OSS Distributions #ifndef __PACKET_MANGLER_H__
25*8d741a5dSApple OSS Distributions #define __PACKET_MANGLER_H__
26*8d741a5dSApple OSS Distributions 
27*8d741a5dSApple OSS Distributions #include <sys/param.h>
28*8d741a5dSApple OSS Distributions #include <sys/types.h>
29*8d741a5dSApple OSS Distributions #include <sys/socket.h>
30*8d741a5dSApple OSS Distributions #include <sys/syslog.h>
31*8d741a5dSApple OSS Distributions #include <netinet/in.h>
32*8d741a5dSApple OSS Distributions #include <stdint.h>
33*8d741a5dSApple OSS Distributions 
34*8d741a5dSApple OSS Distributions #ifdef BSD_KERNEL_PRIVATE
35*8d741a5dSApple OSS Distributions #include <sys/mbuf.h>
36*8d741a5dSApple OSS Distributions #include <sys/socketvar.h>
37*8d741a5dSApple OSS Distributions #endif /* BSD_KERNEL_PRIVATE */
38*8d741a5dSApple OSS Distributions 
39*8d741a5dSApple OSS Distributions __BEGIN_DECLS
40*8d741a5dSApple OSS Distributions 
41*8d741a5dSApple OSS Distributions #ifdef PRIVATE
42*8d741a5dSApple OSS Distributions 
43*8d741a5dSApple OSS Distributions typedef enum {
44*8d741a5dSApple OSS Distributions 	INOUT,
45*8d741a5dSApple OSS Distributions 	IN,
46*8d741a5dSApple OSS Distributions 	OUT
47*8d741a5dSApple OSS Distributions } Pkt_Mnglr_Flow;
48*8d741a5dSApple OSS Distributions 
49*8d741a5dSApple OSS Distributions /*
50*8d741a5dSApple OSS Distributions  * Kernel control name for an instance of a packet mangler.
51*8d741a5dSApple OSS Distributions  * Use CTLIOCGINFO to find out the corresponding kernel control id
52*8d741a5dSApple OSS Distributions  * to be set in the sc_id field of sockaddr_ctl for connect(2)
53*8d741a5dSApple OSS Distributions  * Note: the sc_unit is ephemeral
54*8d741a5dSApple OSS Distributions  */
55*8d741a5dSApple OSS Distributions #define PACKET_MANGLER_CONTROL_NAME "com.apple.packet-mangler"
56*8d741a5dSApple OSS Distributions 
57*8d741a5dSApple OSS Distributions #define PKT_MNGLR_OPT_PROTO_ACT_MASK    1
58*8d741a5dSApple OSS Distributions #define PKT_MNGLR_OPT_IP_ACT_MASK       2
59*8d741a5dSApple OSS Distributions #define PKT_MNGLR_OPT_LOCAL_IP          3
60*8d741a5dSApple OSS Distributions #define PKT_MNGLR_OPT_REMOTE_IP         4
61*8d741a5dSApple OSS Distributions #define PKT_MNGLR_OPT_LOCAL_PORT        5
62*8d741a5dSApple OSS Distributions #define PKT_MNGLR_OPT_REMOTE_PORT       6
63*8d741a5dSApple OSS Distributions #define PKT_MNGLR_OPT_DIRECTION         7
64*8d741a5dSApple OSS Distributions #define PKT_MNGLR_OPT_PROTOCOL          8
65*8d741a5dSApple OSS Distributions #define PKT_MNGLR_OPT_ACTIVATE          0xFFFFFFFF
66*8d741a5dSApple OSS Distributions 
67*8d741a5dSApple OSS Distributions /* Packet mangler action masks */
68*8d741a5dSApple OSS Distributions /* Packet Mangler TCP action mask */
69*8d741a5dSApple OSS Distributions #define PKT_MNGLR_TCP_ACT_NOP_MPTCP     0x00000001
70*8d741a5dSApple OSS Distributions #define PKT_MNGLR_TCP_ACT_SWAP_L_PORT   0x00000002
71*8d741a5dSApple OSS Distributions #define PKT_MNGLR_TCP_ACT_SWAP_R_PORT   0x00000004
72*8d741a5dSApple OSS Distributions #define PKT_MNGLR_TCP_ACT_DSS_DROP      0x00000008
73*8d741a5dSApple OSS Distributions #define PKT_MNGLR_TCP_ACT_CHK_EXTENDED  0x80000000
74*8d741a5dSApple OSS Distributions 
75*8d741a5dSApple OSS Distributions /* Packet Mangler IP action mask */
76*8d741a5dSApple OSS Distributions #define PKT_MNGLR_IP_ACT_FLT_L_IP       0x00000001
77*8d741a5dSApple OSS Distributions #define PKT_MNGLR_IP_ACT_FLT_R_IP       0x00000002
78*8d741a5dSApple OSS Distributions #define PKT_MNGLR_IP_ACT_SWAP_L_IP      0x00000004
79*8d741a5dSApple OSS Distributions #define PKT_MNGLR_IP_ACT_SWAP_R_IP      0x00000008
80*8d741a5dSApple OSS Distributions #define PKT_MNGLR_IP_ACT_DROP_PACKET    0x00000010
81*8d741a5dSApple OSS Distributions #define PKT_MNGLR_IP_ACT_CHK_EXTENDED   0x80000000
82*8d741a5dSApple OSS Distributions 
83*8d741a5dSApple OSS Distributions /*
84*8d741a5dSApple OSS Distributions  * How many filter may be active simultaneously
85*8d741a5dSApple OSS Distributions  */
86*8d741a5dSApple OSS Distributions #define PKT_MNGLR_MAX_FILTER_COUNT      1
87*8d741a5dSApple OSS Distributions 
88*8d741a5dSApple OSS Distributions #define PKT_MNGLR_VERSION_CURRENT 1
89*8d741a5dSApple OSS Distributions 
90*8d741a5dSApple OSS Distributions #endif /* PRIVATE */
91*8d741a5dSApple OSS Distributions 
92*8d741a5dSApple OSS Distributions #ifdef BSD_KERNEL_PRIVATE
93*8d741a5dSApple OSS Distributions 
94*8d741a5dSApple OSS Distributions extern int pkt_mnglr_log_level;
95*8d741a5dSApple OSS Distributions 
96*8d741a5dSApple OSS Distributions #define PKT_MNGLR_LOG(level, fmt, ...) \
97*8d741a5dSApple OSS Distributions do { \
98*8d741a5dSApple OSS Distributions 	if (pkt_mnglr_log_level >= level) \
99*8d741a5dSApple OSS Distributions 	        printf("%s:%d " fmt "\n",\
100*8d741a5dSApple OSS Distributions 	                __FUNCTION__, __LINE__, ##__VA_ARGS__); \
101*8d741a5dSApple OSS Distributions } while (0)
102*8d741a5dSApple OSS Distributions 
103*8d741a5dSApple OSS Distributions 
104*8d741a5dSApple OSS Distributions extern void pkt_mnglr_init(void);
105*8d741a5dSApple OSS Distributions 
106*8d741a5dSApple OSS Distributions __END_DECLS
107*8d741a5dSApple OSS Distributions 
108*8d741a5dSApple OSS Distributions #endif /* BSD_KERNEL_PRIVATE */
109*8d741a5dSApple OSS Distributions 
110*8d741a5dSApple OSS Distributions #endif /* __PACKET_MANGLER_H__ */
111