blob: 9509efe02305466657c8404496dddcf97e054adf [file] [log] [blame]
Elliott Hughes180edef2023-11-02 00:08:05 +00001/*
2 * This file is auto-generated. Modifications will be lost.
3 *
4 * See https://android.googlesource.com/platform/bionic/+/master/libc/kernel/
5 * for more information.
6 */
Ben Cheng655a7c02013-10-16 16:09:24 -07007#ifndef _LINUX_XFRM_H
8#define _LINUX_XFRM_H
Christopher Ferris05d08e92016-02-04 13:16:38 -08009#include <linux/in6.h>
Ben Cheng655a7c02013-10-16 16:09:24 -070010#include <linux/types.h>
Christopher Ferris0f795212024-01-17 14:17:28 -080011#include <linux/stddef.h>
Christopher Ferris05d08e92016-02-04 13:16:38 -080012typedef union {
Tao Baod7db5942015-01-28 10:07:51 -080013 __be32 a4;
14 __be32 a6[4];
Christopher Ferris05d08e92016-02-04 13:16:38 -080015 struct in6_addr in6;
Ben Cheng655a7c02013-10-16 16:09:24 -070016} xfrm_address_t;
17struct xfrm_id {
Tao Baod7db5942015-01-28 10:07:51 -080018 xfrm_address_t daddr;
19 __be32 spi;
20 __u8 proto;
Ben Cheng655a7c02013-10-16 16:09:24 -070021};
Ben Cheng655a7c02013-10-16 16:09:24 -070022struct xfrm_sec_ctx {
Tao Baod7db5942015-01-28 10:07:51 -080023 __u8 ctx_doi;
24 __u8 ctx_alg;
25 __u16 ctx_len;
Tao Baod7db5942015-01-28 10:07:51 -080026 __u32 ctx_sid;
Christopher Ferris0f795212024-01-17 14:17:28 -080027 char ctx_str[] __counted_by(ctx_len);
Ben Cheng655a7c02013-10-16 16:09:24 -070028};
29#define XFRM_SC_DOI_RESERVED 0
Ben Cheng655a7c02013-10-16 16:09:24 -070030#define XFRM_SC_DOI_LSM 1
31#define XFRM_SC_ALG_RESERVED 0
32#define XFRM_SC_ALG_SELINUX 1
33struct xfrm_selector {
Tao Baod7db5942015-01-28 10:07:51 -080034 xfrm_address_t daddr;
35 xfrm_address_t saddr;
36 __be16 dport;
37 __be16 dport_mask;
Tao Baod7db5942015-01-28 10:07:51 -080038 __be16 sport;
39 __be16 sport_mask;
40 __u16 family;
41 __u8 prefixlen_d;
Tao Baod7db5942015-01-28 10:07:51 -080042 __u8 prefixlen_s;
43 __u8 proto;
44 int ifindex;
45 __kernel_uid32_t user;
Ben Cheng655a7c02013-10-16 16:09:24 -070046};
Tao Baod7db5942015-01-28 10:07:51 -080047#define XFRM_INF (~(__u64) 0)
Ben Cheng655a7c02013-10-16 16:09:24 -070048struct xfrm_lifetime_cfg {
Tao Baod7db5942015-01-28 10:07:51 -080049 __u64 soft_byte_limit;
Tao Baod7db5942015-01-28 10:07:51 -080050 __u64 hard_byte_limit;
51 __u64 soft_packet_limit;
52 __u64 hard_packet_limit;
53 __u64 soft_add_expires_seconds;
Tao Baod7db5942015-01-28 10:07:51 -080054 __u64 hard_add_expires_seconds;
55 __u64 soft_use_expires_seconds;
56 __u64 hard_use_expires_seconds;
Ben Cheng655a7c02013-10-16 16:09:24 -070057};
Ben Cheng655a7c02013-10-16 16:09:24 -070058struct xfrm_lifetime_cur {
Tao Baod7db5942015-01-28 10:07:51 -080059 __u64 bytes;
60 __u64 packets;
61 __u64 add_time;
Tao Baod7db5942015-01-28 10:07:51 -080062 __u64 use_time;
Ben Cheng655a7c02013-10-16 16:09:24 -070063};
64struct xfrm_replay_state {
Tao Baod7db5942015-01-28 10:07:51 -080065 __u32 oseq;
Tao Baod7db5942015-01-28 10:07:51 -080066 __u32 seq;
67 __u32 bitmap;
Ben Cheng655a7c02013-10-16 16:09:24 -070068};
69#define XFRMA_REPLAY_ESN_MAX 4096
Ben Cheng655a7c02013-10-16 16:09:24 -070070struct xfrm_replay_state_esn {
Tao Baod7db5942015-01-28 10:07:51 -080071 unsigned int bmp_len;
72 __u32 oseq;
73 __u32 seq;
Tao Baod7db5942015-01-28 10:07:51 -080074 __u32 oseq_hi;
75 __u32 seq_hi;
76 __u32 replay_window;
Christopher Ferris7447a1c2022-10-04 18:24:44 -070077 __u32 bmp[];
Ben Cheng655a7c02013-10-16 16:09:24 -070078};
79struct xfrm_algo {
Tao Baod7db5942015-01-28 10:07:51 -080080 char alg_name[64];
81 unsigned int alg_key_len;
Christopher Ferris7447a1c2022-10-04 18:24:44 -070082 char alg_key[];
Ben Cheng655a7c02013-10-16 16:09:24 -070083};
84struct xfrm_algo_auth {
Tao Baod7db5942015-01-28 10:07:51 -080085 char alg_name[64];
Tao Baod7db5942015-01-28 10:07:51 -080086 unsigned int alg_key_len;
87 unsigned int alg_trunc_len;
Christopher Ferris7447a1c2022-10-04 18:24:44 -070088 char alg_key[];
Ben Cheng655a7c02013-10-16 16:09:24 -070089};
Ben Cheng655a7c02013-10-16 16:09:24 -070090struct xfrm_algo_aead {
Tao Baod7db5942015-01-28 10:07:51 -080091 char alg_name[64];
92 unsigned int alg_key_len;
93 unsigned int alg_icv_len;
Christopher Ferris7447a1c2022-10-04 18:24:44 -070094 char alg_key[];
Ben Cheng655a7c02013-10-16 16:09:24 -070095};
96struct xfrm_stats {
Tao Baod7db5942015-01-28 10:07:51 -080097 __u32 replay_window;
Tao Baod7db5942015-01-28 10:07:51 -080098 __u32 replay;
99 __u32 integrity_failed;
Ben Cheng655a7c02013-10-16 16:09:24 -0700100};
101enum {
Tao Baod7db5942015-01-28 10:07:51 -0800102 XFRM_POLICY_TYPE_MAIN = 0,
103 XFRM_POLICY_TYPE_SUB = 1,
104 XFRM_POLICY_TYPE_MAX = 2,
105 XFRM_POLICY_TYPE_ANY = 255
Ben Cheng655a7c02013-10-16 16:09:24 -0700106};
107enum {
Tao Baod7db5942015-01-28 10:07:51 -0800108 XFRM_POLICY_IN = 0,
109 XFRM_POLICY_OUT = 1,
Tao Baod7db5942015-01-28 10:07:51 -0800110 XFRM_POLICY_FWD = 2,
111 XFRM_POLICY_MASK = 3,
112 XFRM_POLICY_MAX = 3
Ben Cheng655a7c02013-10-16 16:09:24 -0700113};
Christopher Ferris7ac54f52024-08-07 21:07:12 +0000114enum xfrm_sa_dir {
115 XFRM_SA_DIR_IN = 1,
116 XFRM_SA_DIR_OUT = 2
117};
Ben Cheng655a7c02013-10-16 16:09:24 -0700118enum {
Tao Baod7db5942015-01-28 10:07:51 -0800119 XFRM_SHARE_ANY,
120 XFRM_SHARE_SESSION,
121 XFRM_SHARE_USER,
Tao Baod7db5942015-01-28 10:07:51 -0800122 XFRM_SHARE_UNIQUE
Ben Cheng655a7c02013-10-16 16:09:24 -0700123};
124#define XFRM_MODE_TRANSPORT 0
125#define XFRM_MODE_TUNNEL 1
Ben Cheng655a7c02013-10-16 16:09:24 -0700126#define XFRM_MODE_ROUTEOPTIMIZATION 2
127#define XFRM_MODE_IN_TRIGGER 3
128#define XFRM_MODE_BEET 4
129#define XFRM_MODE_MAX 5
Ben Cheng655a7c02013-10-16 16:09:24 -0700130enum {
Tao Baod7db5942015-01-28 10:07:51 -0800131 XFRM_MSG_BASE = 0x10,
132 XFRM_MSG_NEWSA = 0x10,
Ben Cheng655a7c02013-10-16 16:09:24 -0700133#define XFRM_MSG_NEWSA XFRM_MSG_NEWSA
Tao Baod7db5942015-01-28 10:07:51 -0800134 XFRM_MSG_DELSA,
Ben Cheng655a7c02013-10-16 16:09:24 -0700135#define XFRM_MSG_DELSA XFRM_MSG_DELSA
Tao Baod7db5942015-01-28 10:07:51 -0800136 XFRM_MSG_GETSA,
Ben Cheng655a7c02013-10-16 16:09:24 -0700137#define XFRM_MSG_GETSA XFRM_MSG_GETSA
Tao Baod7db5942015-01-28 10:07:51 -0800138 XFRM_MSG_NEWPOLICY,
Ben Cheng655a7c02013-10-16 16:09:24 -0700139#define XFRM_MSG_NEWPOLICY XFRM_MSG_NEWPOLICY
Tao Baod7db5942015-01-28 10:07:51 -0800140 XFRM_MSG_DELPOLICY,
Ben Cheng655a7c02013-10-16 16:09:24 -0700141#define XFRM_MSG_DELPOLICY XFRM_MSG_DELPOLICY
Tao Baod7db5942015-01-28 10:07:51 -0800142 XFRM_MSG_GETPOLICY,
Ben Cheng655a7c02013-10-16 16:09:24 -0700143#define XFRM_MSG_GETPOLICY XFRM_MSG_GETPOLICY
Tao Baod7db5942015-01-28 10:07:51 -0800144 XFRM_MSG_ALLOCSPI,
Ben Cheng655a7c02013-10-16 16:09:24 -0700145#define XFRM_MSG_ALLOCSPI XFRM_MSG_ALLOCSPI
Tao Baod7db5942015-01-28 10:07:51 -0800146 XFRM_MSG_ACQUIRE,
Ben Cheng655a7c02013-10-16 16:09:24 -0700147#define XFRM_MSG_ACQUIRE XFRM_MSG_ACQUIRE
Tao Baod7db5942015-01-28 10:07:51 -0800148 XFRM_MSG_EXPIRE,
Ben Cheng655a7c02013-10-16 16:09:24 -0700149#define XFRM_MSG_EXPIRE XFRM_MSG_EXPIRE
Tao Baod7db5942015-01-28 10:07:51 -0800150 XFRM_MSG_UPDPOLICY,
Ben Cheng655a7c02013-10-16 16:09:24 -0700151#define XFRM_MSG_UPDPOLICY XFRM_MSG_UPDPOLICY
Tao Baod7db5942015-01-28 10:07:51 -0800152 XFRM_MSG_UPDSA,
Ben Cheng655a7c02013-10-16 16:09:24 -0700153#define XFRM_MSG_UPDSA XFRM_MSG_UPDSA
Tao Baod7db5942015-01-28 10:07:51 -0800154 XFRM_MSG_POLEXPIRE,
Ben Cheng655a7c02013-10-16 16:09:24 -0700155#define XFRM_MSG_POLEXPIRE XFRM_MSG_POLEXPIRE
Tao Baod7db5942015-01-28 10:07:51 -0800156 XFRM_MSG_FLUSHSA,
Ben Cheng655a7c02013-10-16 16:09:24 -0700157#define XFRM_MSG_FLUSHSA XFRM_MSG_FLUSHSA
Tao Baod7db5942015-01-28 10:07:51 -0800158 XFRM_MSG_FLUSHPOLICY,
Ben Cheng655a7c02013-10-16 16:09:24 -0700159#define XFRM_MSG_FLUSHPOLICY XFRM_MSG_FLUSHPOLICY
Tao Baod7db5942015-01-28 10:07:51 -0800160 XFRM_MSG_NEWAE,
Ben Cheng655a7c02013-10-16 16:09:24 -0700161#define XFRM_MSG_NEWAE XFRM_MSG_NEWAE
Tao Baod7db5942015-01-28 10:07:51 -0800162 XFRM_MSG_GETAE,
Ben Cheng655a7c02013-10-16 16:09:24 -0700163#define XFRM_MSG_GETAE XFRM_MSG_GETAE
Tao Baod7db5942015-01-28 10:07:51 -0800164 XFRM_MSG_REPORT,
Ben Cheng655a7c02013-10-16 16:09:24 -0700165#define XFRM_MSG_REPORT XFRM_MSG_REPORT
Tao Baod7db5942015-01-28 10:07:51 -0800166 XFRM_MSG_MIGRATE,
Ben Cheng655a7c02013-10-16 16:09:24 -0700167#define XFRM_MSG_MIGRATE XFRM_MSG_MIGRATE
Tao Baod7db5942015-01-28 10:07:51 -0800168 XFRM_MSG_NEWSADINFO,
Ben Cheng655a7c02013-10-16 16:09:24 -0700169#define XFRM_MSG_NEWSADINFO XFRM_MSG_NEWSADINFO
Tao Baod7db5942015-01-28 10:07:51 -0800170 XFRM_MSG_GETSADINFO,
Ben Cheng655a7c02013-10-16 16:09:24 -0700171#define XFRM_MSG_GETSADINFO XFRM_MSG_GETSADINFO
Tao Baod7db5942015-01-28 10:07:51 -0800172 XFRM_MSG_NEWSPDINFO,
Ben Cheng655a7c02013-10-16 16:09:24 -0700173#define XFRM_MSG_NEWSPDINFO XFRM_MSG_NEWSPDINFO
Tao Baod7db5942015-01-28 10:07:51 -0800174 XFRM_MSG_GETSPDINFO,
Ben Cheng655a7c02013-10-16 16:09:24 -0700175#define XFRM_MSG_GETSPDINFO XFRM_MSG_GETSPDINFO
Tao Baod7db5942015-01-28 10:07:51 -0800176 XFRM_MSG_MAPPING,
Ben Cheng655a7c02013-10-16 16:09:24 -0700177#define XFRM_MSG_MAPPING XFRM_MSG_MAPPING
Christopher Ferris2abfa9e2021-11-01 16:26:06 -0700178 XFRM_MSG_SETDEFAULT,
179#define XFRM_MSG_SETDEFAULT XFRM_MSG_SETDEFAULT
180 XFRM_MSG_GETDEFAULT,
181#define XFRM_MSG_GETDEFAULT XFRM_MSG_GETDEFAULT
Tao Baod7db5942015-01-28 10:07:51 -0800182 __XFRM_MSG_MAX
Ben Cheng655a7c02013-10-16 16:09:24 -0700183};
184#define XFRM_MSG_MAX (__XFRM_MSG_MAX - 1)
185#define XFRM_NR_MSGTYPES (XFRM_MSG_MAX + 1 - XFRM_MSG_BASE)
Ben Cheng655a7c02013-10-16 16:09:24 -0700186struct xfrm_user_sec_ctx {
Tao Baod7db5942015-01-28 10:07:51 -0800187 __u16 len;
188 __u16 exttype;
189 __u8 ctx_alg;
Tao Baod7db5942015-01-28 10:07:51 -0800190 __u8 ctx_doi;
191 __u16 ctx_len;
Ben Cheng655a7c02013-10-16 16:09:24 -0700192};
193struct xfrm_user_tmpl {
Tao Baod7db5942015-01-28 10:07:51 -0800194 struct xfrm_id id;
195 __u16 family;
196 xfrm_address_t saddr;
197 __u32 reqid;
Tao Baod7db5942015-01-28 10:07:51 -0800198 __u8 mode;
199 __u8 share;
200 __u8 optional;
201 __u32 aalgos;
Tao Baod7db5942015-01-28 10:07:51 -0800202 __u32 ealgos;
203 __u32 calgos;
Ben Cheng655a7c02013-10-16 16:09:24 -0700204};
205struct xfrm_encap_tmpl {
Tao Baod7db5942015-01-28 10:07:51 -0800206 __u16 encap_type;
207 __be16 encap_sport;
208 __be16 encap_dport;
209 xfrm_address_t encap_oa;
Ben Cheng655a7c02013-10-16 16:09:24 -0700210};
211enum xfrm_ae_ftype_t {
Tao Baod7db5942015-01-28 10:07:51 -0800212 XFRM_AE_UNSPEC,
213 XFRM_AE_RTHR = 1,
Tao Baod7db5942015-01-28 10:07:51 -0800214 XFRM_AE_RVAL = 2,
215 XFRM_AE_LVAL = 4,
216 XFRM_AE_ETHR = 8,
217 XFRM_AE_CR = 16,
Tao Baod7db5942015-01-28 10:07:51 -0800218 XFRM_AE_CE = 32,
219 XFRM_AE_CU = 64,
220 __XFRM_AE_MAX
Ben Cheng655a7c02013-10-16 16:09:24 -0700221#define XFRM_AE_MAX (__XFRM_AE_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700222};
223struct xfrm_userpolicy_type {
Tao Baod7db5942015-01-28 10:07:51 -0800224 __u8 type;
225 __u16 reserved1;
Tao Baod7db5942015-01-28 10:07:51 -0800226 __u8 reserved2;
Ben Cheng655a7c02013-10-16 16:09:24 -0700227};
228enum xfrm_attr_type_t {
Tao Baod7db5942015-01-28 10:07:51 -0800229 XFRMA_UNSPEC,
Tao Baod7db5942015-01-28 10:07:51 -0800230 XFRMA_ALG_AUTH,
231 XFRMA_ALG_CRYPT,
232 XFRMA_ALG_COMP,
233 XFRMA_ENCAP,
Tao Baod7db5942015-01-28 10:07:51 -0800234 XFRMA_TMPL,
235 XFRMA_SA,
236 XFRMA_POLICY,
237 XFRMA_SEC_CTX,
Tao Baod7db5942015-01-28 10:07:51 -0800238 XFRMA_LTIME_VAL,
239 XFRMA_REPLAY_VAL,
240 XFRMA_REPLAY_THRESH,
241 XFRMA_ETIMER_THRESH,
Tao Baod7db5942015-01-28 10:07:51 -0800242 XFRMA_SRCADDR,
243 XFRMA_COADDR,
244 XFRMA_LASTUSED,
245 XFRMA_POLICY_TYPE,
Tao Baod7db5942015-01-28 10:07:51 -0800246 XFRMA_MIGRATE,
247 XFRMA_ALG_AEAD,
248 XFRMA_KMADDRESS,
249 XFRMA_ALG_AUTH_TRUNC,
Tao Baod7db5942015-01-28 10:07:51 -0800250 XFRMA_MARK,
251 XFRMA_TFCPAD,
252 XFRMA_REPLAY_ESN_VAL,
253 XFRMA_SA_EXTRA_FLAGS,
Tao Baod7db5942015-01-28 10:07:51 -0800254 XFRMA_PROTO,
255 XFRMA_ADDRESS_FILTER,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700256 XFRMA_PAD,
Christopher Ferris525ce912017-07-26 13:12:53 -0700257 XFRMA_OFFLOAD_DEV,
Christopher Ferris9ce28842018-10-25 12:11:39 -0700258 XFRMA_SET_MARK,
259 XFRMA_SET_MARK_MASK,
260 XFRMA_IF_ID,
Christopher Ferris1ed55342022-03-22 16:06:25 -0700261 XFRMA_MTIMER_THRESH,
Christopher Ferris7ac54f52024-08-07 21:07:12 +0000262 XFRMA_SA_DIR,
Christopher Ferris63fcca42024-09-26 01:12:10 +0000263 XFRMA_NAT_KEEPALIVE_INTERVAL,
Tao Baod7db5942015-01-28 10:07:51 -0800264 __XFRMA_MAX
Christopher Ferris9ce28842018-10-25 12:11:39 -0700265#define XFRMA_OUTPUT_MARK XFRMA_SET_MARK
Ben Cheng655a7c02013-10-16 16:09:24 -0700266#define XFRMA_MAX (__XFRMA_MAX - 1)
267};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700268struct xfrm_mark {
Tao Baod7db5942015-01-28 10:07:51 -0800269 __u32 v;
270 __u32 m;
Ben Cheng655a7c02013-10-16 16:09:24 -0700271};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700272enum xfrm_sadattr_type_t {
Tao Baod7db5942015-01-28 10:07:51 -0800273 XFRMA_SAD_UNSPEC,
274 XFRMA_SAD_CNT,
Tao Baod7db5942015-01-28 10:07:51 -0800275 XFRMA_SAD_HINFO,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700276 __XFRMA_SAD_MAX
Ben Cheng655a7c02013-10-16 16:09:24 -0700277#define XFRMA_SAD_MAX (__XFRMA_SAD_MAX - 1)
278};
279struct xfrmu_sadhinfo {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700280 __u32 sadhcnt;
Tao Baod7db5942015-01-28 10:07:51 -0800281 __u32 sadhmcnt;
Ben Cheng655a7c02013-10-16 16:09:24 -0700282};
283enum xfrm_spdattr_type_t {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700284 XFRMA_SPD_UNSPEC,
Tao Baod7db5942015-01-28 10:07:51 -0800285 XFRMA_SPD_INFO,
286 XFRMA_SPD_HINFO,
Tao Baod7db5942015-01-28 10:07:51 -0800287 XFRMA_SPD_IPV4_HTHRESH,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700288 XFRMA_SPD_IPV6_HTHRESH,
Tao Baod7db5942015-01-28 10:07:51 -0800289 __XFRMA_SPD_MAX
Ben Cheng655a7c02013-10-16 16:09:24 -0700290#define XFRMA_SPD_MAX (__XFRMA_SPD_MAX - 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700291};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700292struct xfrmu_spdinfo {
Tao Baod7db5942015-01-28 10:07:51 -0800293 __u32 incnt;
294 __u32 outcnt;
Tao Baod7db5942015-01-28 10:07:51 -0800295 __u32 fwdcnt;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700296 __u32 inscnt;
Tao Baod7db5942015-01-28 10:07:51 -0800297 __u32 outscnt;
298 __u32 fwdscnt;
Ben Cheng655a7c02013-10-16 16:09:24 -0700299};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700300struct xfrmu_spdhinfo {
Tao Baod7db5942015-01-28 10:07:51 -0800301 __u32 spdhcnt;
302 __u32 spdhmcnt;
Christopher Ferris82d75042015-01-26 10:57:07 -0800303};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700304struct xfrmu_spdhthresh {
Tao Baod7db5942015-01-28 10:07:51 -0800305 __u8 lbits;
306 __u8 rbits;
Ben Cheng655a7c02013-10-16 16:09:24 -0700307};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700308struct xfrm_usersa_info {
Tao Baod7db5942015-01-28 10:07:51 -0800309 struct xfrm_selector sel;
310 struct xfrm_id id;
Tao Baod7db5942015-01-28 10:07:51 -0800311 xfrm_address_t saddr;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700312 struct xfrm_lifetime_cfg lft;
Tao Baod7db5942015-01-28 10:07:51 -0800313 struct xfrm_lifetime_cur curlft;
314 struct xfrm_stats stats;
Tao Baod7db5942015-01-28 10:07:51 -0800315 __u32 seq;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700316 __u32 reqid;
Tao Baod7db5942015-01-28 10:07:51 -0800317 __u16 family;
318 __u8 mode;
Tao Baod7db5942015-01-28 10:07:51 -0800319 __u8 replay_window;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700320 __u8 flags;
Ben Cheng655a7c02013-10-16 16:09:24 -0700321#define XFRM_STATE_NOECN 1
322#define XFRM_STATE_DECAP_DSCP 2
Ben Cheng655a7c02013-10-16 16:09:24 -0700323#define XFRM_STATE_NOPMTUDISC 4
Christopher Ferris106b3a82016-08-24 12:15:38 -0700324#define XFRM_STATE_WILDRECV 8
Ben Cheng655a7c02013-10-16 16:09:24 -0700325#define XFRM_STATE_ICMP 16
326#define XFRM_STATE_AF_UNSPEC 32
Ben Cheng655a7c02013-10-16 16:09:24 -0700327#define XFRM_STATE_ALIGN4 64
Christopher Ferris106b3a82016-08-24 12:15:38 -0700328#define XFRM_STATE_ESN 128
Ben Cheng655a7c02013-10-16 16:09:24 -0700329};
330#define XFRM_SA_XFLAG_DONT_ENCAP_DSCP 1
Christopher Ferris25c18d42020-10-14 17:42:58 -0700331#define XFRM_SA_XFLAG_OSEQ_MAY_WRAP 2
Ben Cheng655a7c02013-10-16 16:09:24 -0700332struct xfrm_usersa_id {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700333 xfrm_address_t daddr;
Tao Baod7db5942015-01-28 10:07:51 -0800334 __be32 spi;
335 __u16 family;
Tao Baod7db5942015-01-28 10:07:51 -0800336 __u8 proto;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700337};
Ben Cheng655a7c02013-10-16 16:09:24 -0700338struct xfrm_aevent_id {
Tao Baod7db5942015-01-28 10:07:51 -0800339 struct xfrm_usersa_id sa_id;
Tao Baod7db5942015-01-28 10:07:51 -0800340 xfrm_address_t saddr;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700341 __u32 flags;
Tao Baod7db5942015-01-28 10:07:51 -0800342 __u32 reqid;
Ben Cheng655a7c02013-10-16 16:09:24 -0700343};
Ben Cheng655a7c02013-10-16 16:09:24 -0700344struct xfrm_userspi_info {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700345 struct xfrm_usersa_info info;
Tao Baod7db5942015-01-28 10:07:51 -0800346 __u32 min;
347 __u32 max;
Ben Cheng655a7c02013-10-16 16:09:24 -0700348};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700349struct xfrm_userpolicy_info {
Tao Baod7db5942015-01-28 10:07:51 -0800350 struct xfrm_selector sel;
351 struct xfrm_lifetime_cfg lft;
Tao Baod7db5942015-01-28 10:07:51 -0800352 struct xfrm_lifetime_cur curlft;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700353 __u32 priority;
Tao Baod7db5942015-01-28 10:07:51 -0800354 __u32 index;
355 __u8 dir;
Tao Baod7db5942015-01-28 10:07:51 -0800356 __u8 action;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700357#define XFRM_POLICY_ALLOW 0
Ben Cheng655a7c02013-10-16 16:09:24 -0700358#define XFRM_POLICY_BLOCK 1
Tao Baod7db5942015-01-28 10:07:51 -0800359 __u8 flags;
Ben Cheng655a7c02013-10-16 16:09:24 -0700360#define XFRM_POLICY_LOCALOK 1
Christopher Ferris106b3a82016-08-24 12:15:38 -0700361#define XFRM_POLICY_ICMP 2
Tao Baod7db5942015-01-28 10:07:51 -0800362 __u8 share;
Ben Cheng655a7c02013-10-16 16:09:24 -0700363};
Ben Cheng655a7c02013-10-16 16:09:24 -0700364struct xfrm_userpolicy_id {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700365 struct xfrm_selector sel;
Tao Baod7db5942015-01-28 10:07:51 -0800366 __u32 index;
367 __u8 dir;
Ben Cheng655a7c02013-10-16 16:09:24 -0700368};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700369struct xfrm_user_acquire {
Tao Baod7db5942015-01-28 10:07:51 -0800370 struct xfrm_id id;
371 xfrm_address_t saddr;
Tao Baod7db5942015-01-28 10:07:51 -0800372 struct xfrm_selector sel;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700373 struct xfrm_userpolicy_info policy;
Tao Baod7db5942015-01-28 10:07:51 -0800374 __u32 aalgos;
375 __u32 ealgos;
Tao Baod7db5942015-01-28 10:07:51 -0800376 __u32 calgos;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700377 __u32 seq;
Ben Cheng655a7c02013-10-16 16:09:24 -0700378};
379struct xfrm_user_expire {
Tao Baod7db5942015-01-28 10:07:51 -0800380 struct xfrm_usersa_info state;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700381 __u8 hard;
Ben Cheng655a7c02013-10-16 16:09:24 -0700382};
383struct xfrm_user_polexpire {
Tao Baod7db5942015-01-28 10:07:51 -0800384 struct xfrm_userpolicy_info pol;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700385 __u8 hard;
Ben Cheng655a7c02013-10-16 16:09:24 -0700386};
387struct xfrm_usersa_flush {
Tao Baod7db5942015-01-28 10:07:51 -0800388 __u8 proto;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700389};
Ben Cheng655a7c02013-10-16 16:09:24 -0700390struct xfrm_user_report {
Tao Baod7db5942015-01-28 10:07:51 -0800391 __u8 proto;
Tao Baod7db5942015-01-28 10:07:51 -0800392 struct xfrm_selector sel;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700393};
Ben Cheng655a7c02013-10-16 16:09:24 -0700394struct xfrm_user_kmaddress {
Tao Baod7db5942015-01-28 10:07:51 -0800395 xfrm_address_t local;
Tao Baod7db5942015-01-28 10:07:51 -0800396 xfrm_address_t remote;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700397 __u32 reserved;
Tao Baod7db5942015-01-28 10:07:51 -0800398 __u16 family;
Ben Cheng655a7c02013-10-16 16:09:24 -0700399};
Ben Cheng655a7c02013-10-16 16:09:24 -0700400struct xfrm_user_migrate {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700401 xfrm_address_t old_daddr;
Tao Baod7db5942015-01-28 10:07:51 -0800402 xfrm_address_t old_saddr;
403 xfrm_address_t new_daddr;
Tao Baod7db5942015-01-28 10:07:51 -0800404 xfrm_address_t new_saddr;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700405 __u8 proto;
Tao Baod7db5942015-01-28 10:07:51 -0800406 __u8 mode;
407 __u16 reserved;
Tao Baod7db5942015-01-28 10:07:51 -0800408 __u32 reqid;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700409 __u16 old_family;
Tao Baod7db5942015-01-28 10:07:51 -0800410 __u16 new_family;
Ben Cheng655a7c02013-10-16 16:09:24 -0700411};
Ben Cheng655a7c02013-10-16 16:09:24 -0700412struct xfrm_user_mapping {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700413 struct xfrm_usersa_id id;
Tao Baod7db5942015-01-28 10:07:51 -0800414 __u32 reqid;
415 xfrm_address_t old_saddr;
Tao Baod7db5942015-01-28 10:07:51 -0800416 xfrm_address_t new_saddr;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700417 __be16 old_sport;
Tao Baod7db5942015-01-28 10:07:51 -0800418 __be16 new_sport;
Ben Cheng655a7c02013-10-16 16:09:24 -0700419};
Christopher Ferrisba8d4f42014-09-03 19:56:49 -0700420struct xfrm_address_filter {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700421 xfrm_address_t saddr;
Tao Baod7db5942015-01-28 10:07:51 -0800422 xfrm_address_t daddr;
423 __u16 family;
Tao Baod7db5942015-01-28 10:07:51 -0800424 __u8 splen;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700425 __u8 dplen;
Christopher Ferrisba8d4f42014-09-03 19:56:49 -0700426};
Christopher Ferris525ce912017-07-26 13:12:53 -0700427struct xfrm_user_offload {
428 int ifindex;
429 __u8 flags;
430};
431#define XFRM_OFFLOAD_IPV6 1
432#define XFRM_OFFLOAD_INBOUND 2
Christopher Ferris8b7fdc92023-02-21 13:36:32 -0800433#define XFRM_OFFLOAD_PACKET 4
Christopher Ferris2abfa9e2021-11-01 16:26:06 -0700434struct xfrm_userpolicy_default {
435#define XFRM_USERPOLICY_UNSPEC 0
436#define XFRM_USERPOLICY_BLOCK 1
437#define XFRM_USERPOLICY_ACCEPT 2
438 __u8 in;
439 __u8 fwd;
440 __u8 out;
441};
Ben Cheng655a7c02013-10-16 16:09:24 -0700442#define XFRMGRP_ACQUIRE 1
443#define XFRMGRP_EXPIRE 2
Christopher Ferris106b3a82016-08-24 12:15:38 -0700444#define XFRMGRP_SA 4
Christopher Ferrisba8d4f42014-09-03 19:56:49 -0700445#define XFRMGRP_POLICY 8
Ben Cheng655a7c02013-10-16 16:09:24 -0700446#define XFRMGRP_REPORT 0x20
447enum xfrm_nlgroups {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700448 XFRMNLGRP_NONE,
Christopher Ferrisba8d4f42014-09-03 19:56:49 -0700449#define XFRMNLGRP_NONE XFRMNLGRP_NONE
Tao Baod7db5942015-01-28 10:07:51 -0800450 XFRMNLGRP_ACQUIRE,
Ben Cheng655a7c02013-10-16 16:09:24 -0700451#define XFRMNLGRP_ACQUIRE XFRMNLGRP_ACQUIRE
Christopher Ferris106b3a82016-08-24 12:15:38 -0700452 XFRMNLGRP_EXPIRE,
Christopher Ferrisba8d4f42014-09-03 19:56:49 -0700453#define XFRMNLGRP_EXPIRE XFRMNLGRP_EXPIRE
Tao Baod7db5942015-01-28 10:07:51 -0800454 XFRMNLGRP_SA,
Ben Cheng655a7c02013-10-16 16:09:24 -0700455#define XFRMNLGRP_SA XFRMNLGRP_SA
Christopher Ferris106b3a82016-08-24 12:15:38 -0700456 XFRMNLGRP_POLICY,
Christopher Ferrisba8d4f42014-09-03 19:56:49 -0700457#define XFRMNLGRP_POLICY XFRMNLGRP_POLICY
Tao Baod7db5942015-01-28 10:07:51 -0800458 XFRMNLGRP_AEVENTS,
Ben Cheng655a7c02013-10-16 16:09:24 -0700459#define XFRMNLGRP_AEVENTS XFRMNLGRP_AEVENTS
Christopher Ferris106b3a82016-08-24 12:15:38 -0700460 XFRMNLGRP_REPORT,
Christopher Ferrisba8d4f42014-09-03 19:56:49 -0700461#define XFRMNLGRP_REPORT XFRMNLGRP_REPORT
Tao Baod7db5942015-01-28 10:07:51 -0800462 XFRMNLGRP_MIGRATE,
Ben Cheng655a7c02013-10-16 16:09:24 -0700463#define XFRMNLGRP_MIGRATE XFRMNLGRP_MIGRATE
Christopher Ferris106b3a82016-08-24 12:15:38 -0700464 XFRMNLGRP_MAPPING,
Christopher Ferrisba8d4f42014-09-03 19:56:49 -0700465#define XFRMNLGRP_MAPPING XFRMNLGRP_MAPPING
Tao Baod7db5942015-01-28 10:07:51 -0800466 __XFRMNLGRP_MAX
Ben Cheng655a7c02013-10-16 16:09:24 -0700467};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700468#define XFRMNLGRP_MAX (__XFRMNLGRP_MAX - 1)
Christopher Ferrisba8d4f42014-09-03 19:56:49 -0700469#endif