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/net | |
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/net')
-rw-r--r-- | include/net/xfrm.h | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/include/net/xfrm.h b/include/net/xfrm.h index 8f8bd82606bf..7640822bc515 100644 --- a/include/net/xfrm.h +++ b/include/net/xfrm.h | |||
@@ -186,9 +186,11 @@ struct xfrm_state { | |||
186 | 186 | ||
187 | /* State for replay detection */ | 187 | /* State for replay detection */ |
188 | struct xfrm_replay_state replay; | 188 | struct xfrm_replay_state replay; |
189 | struct xfrm_replay_state_esn *replay_esn; | ||
189 | 190 | ||
190 | /* Replay detection state at the time we sent the last notification */ | 191 | /* Replay detection state at the time we sent the last notification */ |
191 | struct xfrm_replay_state preplay; | 192 | struct xfrm_replay_state preplay; |
193 | struct xfrm_replay_state_esn *preplay_esn; | ||
192 | 194 | ||
193 | /* internal flag that only holds state for delayed aevent at the | 195 | /* internal flag that only holds state for delayed aevent at the |
194 | * moment | 196 | * moment |
@@ -1569,6 +1571,11 @@ static inline int xfrm_alg_auth_len(const struct xfrm_algo_auth *alg) | |||
1569 | return sizeof(*alg) + ((alg->alg_key_len + 7) / 8); | 1571 | return sizeof(*alg) + ((alg->alg_key_len + 7) / 8); |
1570 | } | 1572 | } |
1571 | 1573 | ||
1574 | static inline int xfrm_replay_state_esn_len(struct xfrm_replay_state_esn *replay_esn) | ||
1575 | { | ||
1576 | return sizeof(*replay_esn) + replay_esn->bmp_len * sizeof(__u32); | ||
1577 | } | ||
1578 | |||
1572 | #ifdef CONFIG_XFRM_MIGRATE | 1579 | #ifdef CONFIG_XFRM_MIGRATE |
1573 | static inline struct xfrm_algo *xfrm_algo_clone(struct xfrm_algo *orig) | 1580 | static inline struct xfrm_algo *xfrm_algo_clone(struct xfrm_algo *orig) |
1574 | { | 1581 | { |