1 /**************************************************************************** 2 **************************************************************************** 3 *** 4 *** This header was automatically generated from a Linux kernel header 5 *** of the same name, to make information necessary for userspace to 6 *** call into the kernel available to libc. It contains only constants, 7 *** structures, and macros generated from the original header, and thus, 8 *** contains no copyrightable information. 9 *** 10 *** To edit the content of this header, modify the corresponding 11 *** source file (e.g. under external/kernel-headers/original/) then 12 *** run bionic/libc/kernel/tools/update_all.py 13 *** 14 *** Any manual change here will be lost the next time this script will 15 *** be run. You've been warned! 16 *** 17 **************************************************************************** 18 ****************************************************************************/ 19 #ifndef _LINUX_XFRM_H 20 #define _LINUX_XFRM_H 21 #include <linux/in6.h> 22 #include <linux/types.h> 23 typedef union { 24 __be32 a4; 25 __be32 a6[4]; 26 struct in6_addr in6; 27 } xfrm_address_t; 28 struct xfrm_id { 29 xfrm_address_t daddr; 30 __be32 spi; 31 __u8 proto; 32 }; 33 struct xfrm_sec_ctx { 34 __u8 ctx_doi; 35 __u8 ctx_alg; 36 __u16 ctx_len; 37 __u32 ctx_sid; 38 char ctx_str[0]; 39 }; 40 #define XFRM_SC_DOI_RESERVED 0 41 #define XFRM_SC_DOI_LSM 1 42 #define XFRM_SC_ALG_RESERVED 0 43 #define XFRM_SC_ALG_SELINUX 1 44 struct xfrm_selector { 45 xfrm_address_t daddr; 46 xfrm_address_t saddr; 47 __be16 dport; 48 __be16 dport_mask; 49 __be16 sport; 50 __be16 sport_mask; 51 __u16 family; 52 __u8 prefixlen_d; 53 __u8 prefixlen_s; 54 __u8 proto; 55 int ifindex; 56 __kernel_uid32_t user; 57 }; 58 #define XFRM_INF (~(__u64) 0) 59 struct xfrm_lifetime_cfg { 60 __u64 soft_byte_limit; 61 __u64 hard_byte_limit; 62 __u64 soft_packet_limit; 63 __u64 hard_packet_limit; 64 __u64 soft_add_expires_seconds; 65 __u64 hard_add_expires_seconds; 66 __u64 soft_use_expires_seconds; 67 __u64 hard_use_expires_seconds; 68 }; 69 struct xfrm_lifetime_cur { 70 __u64 bytes; 71 __u64 packets; 72 __u64 add_time; 73 __u64 use_time; 74 }; 75 struct xfrm_replay_state { 76 __u32 oseq; 77 __u32 seq; 78 __u32 bitmap; 79 }; 80 #define XFRMA_REPLAY_ESN_MAX 4096 81 struct xfrm_replay_state_esn { 82 unsigned int bmp_len; 83 __u32 oseq; 84 __u32 seq; 85 __u32 oseq_hi; 86 __u32 seq_hi; 87 __u32 replay_window; 88 __u32 bmp[0]; 89 }; 90 struct xfrm_algo { 91 char alg_name[64]; 92 unsigned int alg_key_len; 93 char alg_key[0]; 94 }; 95 struct xfrm_algo_auth { 96 char alg_name[64]; 97 unsigned int alg_key_len; 98 unsigned int alg_trunc_len; 99 char alg_key[0]; 100 }; 101 struct xfrm_algo_aead { 102 char alg_name[64]; 103 unsigned int alg_key_len; 104 unsigned int alg_icv_len; 105 char alg_key[0]; 106 }; 107 struct xfrm_stats { 108 __u32 replay_window; 109 __u32 replay; 110 __u32 integrity_failed; 111 }; 112 enum { 113 XFRM_POLICY_TYPE_MAIN = 0, 114 XFRM_POLICY_TYPE_SUB = 1, 115 XFRM_POLICY_TYPE_MAX = 2, 116 XFRM_POLICY_TYPE_ANY = 255 117 }; 118 enum { 119 XFRM_POLICY_IN = 0, 120 XFRM_POLICY_OUT = 1, 121 XFRM_POLICY_FWD = 2, 122 XFRM_POLICY_MASK = 3, 123 XFRM_POLICY_MAX = 3 124 }; 125 enum { 126 XFRM_SHARE_ANY, 127 XFRM_SHARE_SESSION, 128 XFRM_SHARE_USER, 129 XFRM_SHARE_UNIQUE 130 }; 131 #define XFRM_MODE_TRANSPORT 0 132 #define XFRM_MODE_TUNNEL 1 133 #define XFRM_MODE_ROUTEOPTIMIZATION 2 134 #define XFRM_MODE_IN_TRIGGER 3 135 #define XFRM_MODE_BEET 4 136 #define XFRM_MODE_MAX 5 137 enum { 138 XFRM_MSG_BASE = 0x10, 139 XFRM_MSG_NEWSA = 0x10, 140 #define XFRM_MSG_NEWSA XFRM_MSG_NEWSA 141 XFRM_MSG_DELSA, 142 #define XFRM_MSG_DELSA XFRM_MSG_DELSA 143 XFRM_MSG_GETSA, 144 #define XFRM_MSG_GETSA XFRM_MSG_GETSA 145 XFRM_MSG_NEWPOLICY, 146 #define XFRM_MSG_NEWPOLICY XFRM_MSG_NEWPOLICY 147 XFRM_MSG_DELPOLICY, 148 #define XFRM_MSG_DELPOLICY XFRM_MSG_DELPOLICY 149 XFRM_MSG_GETPOLICY, 150 #define XFRM_MSG_GETPOLICY XFRM_MSG_GETPOLICY 151 XFRM_MSG_ALLOCSPI, 152 #define XFRM_MSG_ALLOCSPI XFRM_MSG_ALLOCSPI 153 XFRM_MSG_ACQUIRE, 154 #define XFRM_MSG_ACQUIRE XFRM_MSG_ACQUIRE 155 XFRM_MSG_EXPIRE, 156 #define XFRM_MSG_EXPIRE XFRM_MSG_EXPIRE 157 XFRM_MSG_UPDPOLICY, 158 #define XFRM_MSG_UPDPOLICY XFRM_MSG_UPDPOLICY 159 XFRM_MSG_UPDSA, 160 #define XFRM_MSG_UPDSA XFRM_MSG_UPDSA 161 XFRM_MSG_POLEXPIRE, 162 #define XFRM_MSG_POLEXPIRE XFRM_MSG_POLEXPIRE 163 XFRM_MSG_FLUSHSA, 164 #define XFRM_MSG_FLUSHSA XFRM_MSG_FLUSHSA 165 XFRM_MSG_FLUSHPOLICY, 166 #define XFRM_MSG_FLUSHPOLICY XFRM_MSG_FLUSHPOLICY 167 XFRM_MSG_NEWAE, 168 #define XFRM_MSG_NEWAE XFRM_MSG_NEWAE 169 XFRM_MSG_GETAE, 170 #define XFRM_MSG_GETAE XFRM_MSG_GETAE 171 XFRM_MSG_REPORT, 172 #define XFRM_MSG_REPORT XFRM_MSG_REPORT 173 XFRM_MSG_MIGRATE, 174 #define XFRM_MSG_MIGRATE XFRM_MSG_MIGRATE 175 XFRM_MSG_NEWSADINFO, 176 #define XFRM_MSG_NEWSADINFO XFRM_MSG_NEWSADINFO 177 XFRM_MSG_GETSADINFO, 178 #define XFRM_MSG_GETSADINFO XFRM_MSG_GETSADINFO 179 XFRM_MSG_NEWSPDINFO, 180 #define XFRM_MSG_NEWSPDINFO XFRM_MSG_NEWSPDINFO 181 XFRM_MSG_GETSPDINFO, 182 #define XFRM_MSG_GETSPDINFO XFRM_MSG_GETSPDINFO 183 XFRM_MSG_MAPPING, 184 #define XFRM_MSG_MAPPING XFRM_MSG_MAPPING 185 __XFRM_MSG_MAX 186 }; 187 #define XFRM_MSG_MAX (__XFRM_MSG_MAX - 1) 188 #define XFRM_NR_MSGTYPES (XFRM_MSG_MAX + 1 - XFRM_MSG_BASE) 189 struct xfrm_user_sec_ctx { 190 __u16 len; 191 __u16 exttype; 192 __u8 ctx_alg; 193 __u8 ctx_doi; 194 __u16 ctx_len; 195 }; 196 struct xfrm_user_tmpl { 197 struct xfrm_id id; 198 __u16 family; 199 xfrm_address_t saddr; 200 __u32 reqid; 201 __u8 mode; 202 __u8 share; 203 __u8 optional; 204 __u32 aalgos; 205 __u32 ealgos; 206 __u32 calgos; 207 }; 208 struct xfrm_encap_tmpl { 209 __u16 encap_type; 210 __be16 encap_sport; 211 __be16 encap_dport; 212 xfrm_address_t encap_oa; 213 }; 214 enum xfrm_ae_ftype_t { 215 XFRM_AE_UNSPEC, 216 XFRM_AE_RTHR = 1, 217 XFRM_AE_RVAL = 2, 218 XFRM_AE_LVAL = 4, 219 XFRM_AE_ETHR = 8, 220 XFRM_AE_CR = 16, 221 XFRM_AE_CE = 32, 222 XFRM_AE_CU = 64, 223 __XFRM_AE_MAX 224 #define XFRM_AE_MAX (__XFRM_AE_MAX - 1) 225 }; 226 struct xfrm_userpolicy_type { 227 __u8 type; 228 __u16 reserved1; 229 __u8 reserved2; 230 }; 231 enum xfrm_attr_type_t { 232 XFRMA_UNSPEC, 233 XFRMA_ALG_AUTH, 234 XFRMA_ALG_CRYPT, 235 XFRMA_ALG_COMP, 236 XFRMA_ENCAP, 237 XFRMA_TMPL, 238 XFRMA_SA, 239 XFRMA_POLICY, 240 XFRMA_SEC_CTX, 241 XFRMA_LTIME_VAL, 242 XFRMA_REPLAY_VAL, 243 XFRMA_REPLAY_THRESH, 244 XFRMA_ETIMER_THRESH, 245 XFRMA_SRCADDR, 246 XFRMA_COADDR, 247 XFRMA_LASTUSED, 248 XFRMA_POLICY_TYPE, 249 XFRMA_MIGRATE, 250 XFRMA_ALG_AEAD, 251 XFRMA_KMADDRESS, 252 XFRMA_ALG_AUTH_TRUNC, 253 XFRMA_MARK, 254 XFRMA_TFCPAD, 255 XFRMA_REPLAY_ESN_VAL, 256 XFRMA_SA_EXTRA_FLAGS, 257 XFRMA_PROTO, 258 XFRMA_ADDRESS_FILTER, 259 XFRMA_PAD, 260 XFRMA_OFFLOAD_DEV, 261 XFRMA_SET_MARK, 262 XFRMA_SET_MARK_MASK, 263 XFRMA_IF_ID, 264 __XFRMA_MAX 265 #define XFRMA_OUTPUT_MARK XFRMA_SET_MARK 266 #define XFRMA_MAX (__XFRMA_MAX - 1) 267 }; 268 struct xfrm_mark { 269 __u32 v; 270 __u32 m; 271 }; 272 enum xfrm_sadattr_type_t { 273 XFRMA_SAD_UNSPEC, 274 XFRMA_SAD_CNT, 275 XFRMA_SAD_HINFO, 276 __XFRMA_SAD_MAX 277 #define XFRMA_SAD_MAX (__XFRMA_SAD_MAX - 1) 278 }; 279 struct xfrmu_sadhinfo { 280 __u32 sadhcnt; 281 __u32 sadhmcnt; 282 }; 283 enum xfrm_spdattr_type_t { 284 XFRMA_SPD_UNSPEC, 285 XFRMA_SPD_INFO, 286 XFRMA_SPD_HINFO, 287 XFRMA_SPD_IPV4_HTHRESH, 288 XFRMA_SPD_IPV6_HTHRESH, 289 __XFRMA_SPD_MAX 290 #define XFRMA_SPD_MAX (__XFRMA_SPD_MAX - 1) 291 }; 292 struct xfrmu_spdinfo { 293 __u32 incnt; 294 __u32 outcnt; 295 __u32 fwdcnt; 296 __u32 inscnt; 297 __u32 outscnt; 298 __u32 fwdscnt; 299 }; 300 struct xfrmu_spdhinfo { 301 __u32 spdhcnt; 302 __u32 spdhmcnt; 303 }; 304 struct xfrmu_spdhthresh { 305 __u8 lbits; 306 __u8 rbits; 307 }; 308 struct xfrm_usersa_info { 309 struct xfrm_selector sel; 310 struct xfrm_id id; 311 xfrm_address_t saddr; 312 struct xfrm_lifetime_cfg lft; 313 struct xfrm_lifetime_cur curlft; 314 struct xfrm_stats stats; 315 __u32 seq; 316 __u32 reqid; 317 __u16 family; 318 __u8 mode; 319 __u8 replay_window; 320 __u8 flags; 321 #define XFRM_STATE_NOECN 1 322 #define XFRM_STATE_DECAP_DSCP 2 323 #define XFRM_STATE_NOPMTUDISC 4 324 #define XFRM_STATE_WILDRECV 8 325 #define XFRM_STATE_ICMP 16 326 #define XFRM_STATE_AF_UNSPEC 32 327 #define XFRM_STATE_ALIGN4 64 328 #define XFRM_STATE_ESN 128 329 }; 330 #define XFRM_SA_XFLAG_DONT_ENCAP_DSCP 1 331 #define XFRM_SA_XFLAG_OSEQ_MAY_WRAP 2 332 struct xfrm_usersa_id { 333 xfrm_address_t daddr; 334 __be32 spi; 335 __u16 family; 336 __u8 proto; 337 }; 338 struct xfrm_aevent_id { 339 struct xfrm_usersa_id sa_id; 340 xfrm_address_t saddr; 341 __u32 flags; 342 __u32 reqid; 343 }; 344 struct xfrm_userspi_info { 345 struct xfrm_usersa_info info; 346 __u32 min; 347 __u32 max; 348 }; 349 struct xfrm_userpolicy_info { 350 struct xfrm_selector sel; 351 struct xfrm_lifetime_cfg lft; 352 struct xfrm_lifetime_cur curlft; 353 __u32 priority; 354 __u32 index; 355 __u8 dir; 356 __u8 action; 357 #define XFRM_POLICY_ALLOW 0 358 #define XFRM_POLICY_BLOCK 1 359 __u8 flags; 360 #define XFRM_POLICY_LOCALOK 1 361 #define XFRM_POLICY_ICMP 2 362 __u8 share; 363 }; 364 struct xfrm_userpolicy_id { 365 struct xfrm_selector sel; 366 __u32 index; 367 __u8 dir; 368 }; 369 struct xfrm_user_acquire { 370 struct xfrm_id id; 371 xfrm_address_t saddr; 372 struct xfrm_selector sel; 373 struct xfrm_userpolicy_info policy; 374 __u32 aalgos; 375 __u32 ealgos; 376 __u32 calgos; 377 __u32 seq; 378 }; 379 struct xfrm_user_expire { 380 struct xfrm_usersa_info state; 381 __u8 hard; 382 }; 383 struct xfrm_user_polexpire { 384 struct xfrm_userpolicy_info pol; 385 __u8 hard; 386 }; 387 struct xfrm_usersa_flush { 388 __u8 proto; 389 }; 390 struct xfrm_user_report { 391 __u8 proto; 392 struct xfrm_selector sel; 393 }; 394 struct xfrm_user_kmaddress { 395 xfrm_address_t local; 396 xfrm_address_t remote; 397 __u32 reserved; 398 __u16 family; 399 }; 400 struct xfrm_user_migrate { 401 xfrm_address_t old_daddr; 402 xfrm_address_t old_saddr; 403 xfrm_address_t new_daddr; 404 xfrm_address_t new_saddr; 405 __u8 proto; 406 __u8 mode; 407 __u16 reserved; 408 __u32 reqid; 409 __u16 old_family; 410 __u16 new_family; 411 }; 412 struct xfrm_user_mapping { 413 struct xfrm_usersa_id id; 414 __u32 reqid; 415 xfrm_address_t old_saddr; 416 xfrm_address_t new_saddr; 417 __be16 old_sport; 418 __be16 new_sport; 419 }; 420 struct xfrm_address_filter { 421 xfrm_address_t saddr; 422 xfrm_address_t daddr; 423 __u16 family; 424 __u8 splen; 425 __u8 dplen; 426 }; 427 struct xfrm_user_offload { 428 int ifindex; 429 __u8 flags; 430 }; 431 #define XFRM_OFFLOAD_IPV6 1 432 #define XFRM_OFFLOAD_INBOUND 2 433 #define XFRMGRP_ACQUIRE 1 434 #define XFRMGRP_EXPIRE 2 435 #define XFRMGRP_SA 4 436 #define XFRMGRP_POLICY 8 437 #define XFRMGRP_REPORT 0x20 438 enum xfrm_nlgroups { 439 XFRMNLGRP_NONE, 440 #define XFRMNLGRP_NONE XFRMNLGRP_NONE 441 XFRMNLGRP_ACQUIRE, 442 #define XFRMNLGRP_ACQUIRE XFRMNLGRP_ACQUIRE 443 XFRMNLGRP_EXPIRE, 444 #define XFRMNLGRP_EXPIRE XFRMNLGRP_EXPIRE 445 XFRMNLGRP_SA, 446 #define XFRMNLGRP_SA XFRMNLGRP_SA 447 XFRMNLGRP_POLICY, 448 #define XFRMNLGRP_POLICY XFRMNLGRP_POLICY 449 XFRMNLGRP_AEVENTS, 450 #define XFRMNLGRP_AEVENTS XFRMNLGRP_AEVENTS 451 XFRMNLGRP_REPORT, 452 #define XFRMNLGRP_REPORT XFRMNLGRP_REPORT 453 XFRMNLGRP_MIGRATE, 454 #define XFRMNLGRP_MIGRATE XFRMNLGRP_MIGRATE 455 XFRMNLGRP_MAPPING, 456 #define XFRMNLGRP_MAPPING XFRMNLGRP_MAPPING 457 __XFRMNLGRP_MAX 458 }; 459 #define XFRMNLGRP_MAX (__XFRMNLGRP_MAX - 1) 460 #endif 461