diff options
author | Steffen Klassert <steffen.klassert@secunet.com> | 2011-03-07 19:05:43 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-03-13 23:22:28 -0400 |
commit | 9736acf395d3608583a7be70f62800b494fa103c (patch) | |
tree | ef7b50bb74a7e6a0d93f962cc7a4c98dd18c2caa /include/linux/xfrm.h | |
parent | a5079d084f8be781aae8a635cab4b179cfea4ebd (diff) |
xfrm: Add basic infrastructure to support IPsec extended sequence numbers
This patch adds the struct xfrm_replay_state_esn which will be
used to support IPsec extended sequence numbers and anti replay windows
bigger than 32 packets. Also we add a function that returns the actual
size of the xfrm_replay_state_esn, a xfrm netlink atribute and a xfrm state
flag for the use of extended sequence numbers.
Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux/xfrm.h')
-rw-r--r-- | include/linux/xfrm.h | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/include/linux/xfrm.h b/include/linux/xfrm.h index b93d6f59808..22e61fdf75a 100644 --- a/include/linux/xfrm.h +++ b/include/linux/xfrm.h | |||
@@ -84,6 +84,16 @@ struct xfrm_replay_state { | |||
84 | __u32 bitmap; | 84 | __u32 bitmap; |
85 | }; | 85 | }; |
86 | 86 | ||
87 | struct xfrm_replay_state_esn { | ||
88 | unsigned int bmp_len; | ||
89 | __u32 oseq; | ||
90 | __u32 seq; | ||
91 | __u32 oseq_hi; | ||
92 | __u32 seq_hi; | ||
93 | __u32 replay_window; | ||
94 | __u32 bmp[0]; | ||
95 | }; | ||
96 | |||
87 | struct xfrm_algo { | 97 | struct xfrm_algo { |
88 | char alg_name[64]; | 98 | char alg_name[64]; |
89 | unsigned int alg_key_len; /* in bits */ | 99 | unsigned int alg_key_len; /* in bits */ |
@@ -284,6 +294,7 @@ enum xfrm_attr_type_t { | |||
284 | XFRMA_ALG_AUTH_TRUNC, /* struct xfrm_algo_auth */ | 294 | XFRMA_ALG_AUTH_TRUNC, /* struct xfrm_algo_auth */ |
285 | XFRMA_MARK, /* struct xfrm_mark */ | 295 | XFRMA_MARK, /* struct xfrm_mark */ |
286 | XFRMA_TFCPAD, /* __u32 */ | 296 | XFRMA_TFCPAD, /* __u32 */ |
297 | XFRMA_REPLAY_ESN_VAL, /* struct xfrm_replay_esn */ | ||
287 | __XFRMA_MAX | 298 | __XFRMA_MAX |
288 | 299 | ||
289 | #define XFRMA_MAX (__XFRMA_MAX - 1) | 300 | #define XFRMA_MAX (__XFRMA_MAX - 1) |
@@ -351,6 +362,7 @@ struct xfrm_usersa_info { | |||
351 | #define XFRM_STATE_ICMP 16 | 362 | #define XFRM_STATE_ICMP 16 |
352 | #define XFRM_STATE_AF_UNSPEC 32 | 363 | #define XFRM_STATE_AF_UNSPEC 32 |
353 | #define XFRM_STATE_ALIGN4 64 | 364 | #define XFRM_STATE_ALIGN4 64 |
365 | #define XFRM_STATE_ESN 128 | ||
354 | }; | 366 | }; |
355 | 367 | ||
356 | struct xfrm_usersa_id { | 368 | struct xfrm_usersa_id { |