FD.io VPP  v21.06
Vector Packet Processing
ipsec.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2015 Cisco and/or its affiliates.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at:
6  *
7  * http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 #ifndef __IPSEC_H__
16 #define __IPSEC_H__
17 
18 #include <vnet/ip/ip.h>
19 #include <vnet/crypto/crypto.h>
20 #include <vnet/feature/feature.h>
21 
22 #include <vppinfra/types.h>
23 #include <vppinfra/cache.h>
24 
25 #include <vnet/ipsec/ipsec_spd.h>
27 #include <vnet/ipsec/ipsec_sa.h>
28 
29 #include <vppinfra/bihash_8_16.h>
30 
31 #include <vppinfra/bihash_24_16.h>
32 
33 typedef clib_error_t *(*add_del_sa_sess_cb_t) (u32 sa_index, u8 is_add);
34 typedef clib_error_t *(*check_support_cb_t) (ipsec_sa_t * sa);
35 typedef clib_error_t *(*enable_disable_cb_t) (int is_enable);
36 
37 typedef struct
38 {
39  u8 *name;
40  /* add/del callback */
42  /* check support function */
53 
54 typedef struct
55 {
56  u8 *name;
57  /* add/del callback */
59  /* check support function */
61  /* enable or disable function */
79 
80 typedef struct
81 {
89 
90 typedef struct
91 {
96 
97 typedef struct
98 {
99  CLIB_CACHE_LINE_ALIGN_MARK (cacheline0);
107 
108 typedef struct
109 {
110  /* pool of tunnel instances */
112  /* pool of policies */
114 
115  /* hash tables of UDP port registrations */
117 
119 
120  /* convenience */
123 
124  /* hashes */
132 
133  clib_bihash_8_16_t tun4_protect_by_key;
134  clib_bihash_24_16_t tun6_protect_by_key;
135 
136  /* node indices */
151  /* next node indices */
162 
163  /* tun nodes to drop packets when no crypto alg set on outbound SA */
166 
167  /* tun nodes for encrypt on L2 interfaces */
170 
171  /* pool of ah backends */
173  /* pool of esp backends */
175  /* index of current ah backend */
177  /* index of current esp backend */
179  /* index of default ah backend */
181  /* index of default esp backend */
183 
184  /* crypto alg data */
186 
187  /* crypto integ data */
189 
190  /* per-thread data */
192 
193  /** Worker handoff */
198 
208 
210 } ipsec_main_t;
211 
213 {
218 
219 extern ipsec_main_t ipsec_main;
220 
222  u8 is_add);
223 
225 
228 
229 /*
230  * functions
231  */
232 
233 /*
234  * inline functions
235  */
236 
239  vlib_node_runtime_t * nr)
240 {
241  u32 next;
242  vlib_main_t *vm = vlib_get_main ();
244 
245  vnet_feature_next (&next, b);
246  return node->next_nodes[next];
247 }
248 
250  const char *name,
251  const char *ah4_encrypt_node_name,
252  const char *ah4_decrypt_node_name,
253  const char *ah6_encrypt_node_name,
254  const char *ah6_decrypt_node_name,
255  check_support_cb_t ah_check_support_cb,
256  add_del_sa_sess_cb_t ah_add_del_sa_sess_cb);
257 
259  vlib_main_t *vm, ipsec_main_t *im, const char *name,
260  const char *esp4_encrypt_node_name, const char *esp4_encrypt_tun_node_name,
261  const char *esp4_decrypt_node_name, const char *esp4_decrypt_tun_node_name,
262  const char *esp6_encrypt_node_name, const char *esp6_encrypt_tun_node_name,
263  const char *esp6_decrypt_node_name, const char *esp6_decrypt_tun_node_name,
264  const char *esp_mpls_encrypt_tun_node_name,
265  check_support_cb_t esp_check_support_cb,
266  add_del_sa_sess_cb_t esp_add_del_sa_sess_cb,
267  enable_disable_cb_t enable_disable_cb);
268 
269 int ipsec_select_ah_backend (ipsec_main_t * im, u32 ah_backend_idx);
270 int ipsec_select_esp_backend (ipsec_main_t * im, u32 esp_backend_idx);
271 
273 void ipsec_set_async_mode (u32 is_enabled);
274 
275 extern void ipsec_register_udp_port (u16 udp_port);
276 extern void ipsec_unregister_udp_port (u16 udp_port);
277 
278 #endif /* __IPSEC_H__ */
279 
280 /*
281  * fd.io coding-style-patch-verification: ON
282  *
283  * Local Variables:
284  * eval: (c-set-style "gnu")
285  * End:
286  */
u32 * next_nodes
Definition: node.h:326
u32 esp_mpls_encrypt_tun_node_index
Definition: ipsec.h:77
u32 esp4_decrypt_tun_node_index
Definition: ipsec.h:140
u32 ipsec_register_esp_backend(vlib_main_t *vm, ipsec_main_t *im, const char *name, const char *esp4_encrypt_node_name, const char *esp4_encrypt_tun_node_name, const char *esp4_decrypt_node_name, const char *esp4_decrypt_tun_node_name, const char *esp6_encrypt_node_name, const char *esp6_encrypt_tun_node_name, const char *esp6_decrypt_node_name, const char *esp6_decrypt_tun_node_name, const char *esp_mpls_encrypt_tun_node_name, check_support_cb_t esp_check_support_cb, add_del_sa_sess_cb_t esp_add_del_sa_sess_cb, enable_disable_cb_t enable_disable_cb)
Definition: ipsec.c:200
ipsec_spd_t * spds
Definition: ipsec.h:111
u32 esp_default_backend
Definition: ipsec.h:182
#define CLIB_CACHE_LINE_ALIGN_MARK(mark)
Definition: cache.h:60
u32 esp4_encrypt_next_index
Definition: ipsec.h:65
vlib_node_registration_t ipsec6_tun_input_node
(constructor) VLIB_REGISTER_NODE (ipsec6_tun_input_node)
Definition: ipsec_tun_in.c:407
ipsec_main_crypto_alg_t * crypto_algs
Definition: ipsec.h:185
ipsec_per_thread_data_t * ptd
Definition: ipsec.h:191
u32 esp6_decrypt_node_index
Definition: ipsec.h:145
vnet_crypto_op_t * integ_ops
Definition: ipsec.h:101
uword * tunnel_index_by_key
Definition: ipsec.h:118
enable_disable_cb_t enable_disable_cb
Definition: ipsec.h:62
u32 ah4_decrypt_next_index
Definition: ipsec.h:156
uword * ipsec4_if_pool_index_by_key
Definition: ipsec.h:128
clib_error_t * ipsec_check_support_cb(ipsec_main_t *im, ipsec_sa_t *sa)
Definition: ipsec.c:91
u32 esp6_encrypt_tun_node_index
Definition: ipsec.h:76
u32 esp4_decrypt_node_index
Definition: ipsec.h:64
u32 ah6_decrypt_next_index
Definition: ipsec.h:51
u32 esp6_decrypt_tun_node_index
Definition: ipsec.h:146
u32 esp6_decrypt_next_index
Definition: ipsec.h:70
vnet_crypto_op_t * crypto_ops
Definition: ipsec.h:100
u32 ah4_encrypt_next_index
Definition: ipsec.h:155
u32 ah4_encrypt_node_index
Definition: ipsec.h:44
u32 esp6_encrypt_node_index
Definition: ipsec.h:67
u32 ah_current_backend
Definition: ipsec.h:176
u32 esp6_decrypt_tun_next_index
Definition: ipsec.h:75
int ipsec_select_esp_backend(ipsec_main_t *im, u32 esp_backend_idx)
Definition: ipsec.c:280
A Secruity Policy Database.
Definition: ipsec_spd.h:46
vnet_crypto_op_chunk_t * chunks
Definition: ipsec.h:104
u32 esp_current_backend
Definition: ipsec.h:178
u32 esp6_encrypt_l2_tun_node_index
Definition: ipsec.h:169
u32 ah6_decrypt_node_index
Definition: ipsec.h:49
unsigned char u8
Definition: types.h:56
vlib_buffer_t ** b
uword * spd_index_by_sw_if_index
Definition: ipsec.h:126
unsigned int u32
Definition: types.h:88
u32 esp4_decrypt_tun_next_index
Definition: ipsec.h:154
vnet_crypto_alg_t alg
Definition: ipsec.h:93
u32 esp4_enc_tun_fq_index
Definition: ipsec.h:203
u32 esp6_encrypt_next_index
Definition: ipsec.h:69
uword * ipsec6_if_pool_index_by_key
Definition: ipsec.h:129
u32 ah6_encrypt_node_index
Definition: ipsec.h:48
#define static_always_inline
Definition: clib.h:112
uword * udp_port_registrations
Definition: ipsec.h:116
ipsec_main_t ipsec_main
Definition: ipsec.c:28
u32 ah_default_backend
Definition: ipsec.h:180
u32 esp6_encrypt_node_index
Definition: ipsec.h:144
u32 esp4_decrypt_next_index
Definition: ipsec.h:153
u32 ah6_encrypt_next_index
Definition: ipsec.h:50
uword * ipsec_if_by_sw_if_index
Definition: ipsec.h:131
u32 esp_mpls_encrypt_tun_node_index
Definition: ipsec.h:148
u32 esp4_dec_tun_fq_index
Definition: ipsec.h:206
check_support_cb_t check_support_cb
Definition: ipsec.h:60
u32 ah6_dec_fq_index
Definition: ipsec.h:197
u32 esp4_dec_fq_index
Definition: ipsec.h:200
clib_bihash_8_16_t tun4_protect_by_key
Definition: ipsec.h:133
static_always_inline u32 get_next_output_feature_node_index(vlib_buffer_t *b, vlib_node_runtime_t *nr)
Definition: ipsec.h:238
u32 esp6_decrypt_node_index
Definition: ipsec.h:68
void ipsec_register_udp_port(u16 udp_port)
Definition: ipsec.c:153
ipsec_format_flags_t_
Definition: ipsec.h:212
vnet_crypto_alg_t
Definition: crypto.h:145
u32 ah4_decrypt_node_index
Definition: ipsec.h:143
u32 esp4_encrypt_l2_tun_node_index
Definition: ipsec.h:168
u32 error_drop_node_index
Definition: ipsec.h:137
u16 * next
clib_error_t *(* check_support_cb_t)(ipsec_sa_t *sa)
Definition: ipsec.h:34
clib_bihash_24_16_t tun6_protect_by_key
Definition: ipsec.h:134
u32 esp4_encrypt_node_index
Definition: ipsec.h:138
vnet_main_t * vnet_main
Definition: ipsec.h:122
vnet_crypto_op_id_t enc_op_id
Definition: ipsec.h:82
unsigned short u16
Definition: types.h:57
u32 esp6_no_crypto_tun_node_index
Definition: ipsec.h:165
u32 ah4_decrypt_next_index
Definition: ipsec.h:47
u32 esp6_dec_tun_fq_index
Definition: ipsec.h:207
u32 esp4_decrypt_tun_next_index
Definition: ipsec.h:72
clib_error_t *(* enable_disable_cb_t)(int is_enable)
Definition: ipsec.h:35
u32 ah4_enc_fq_index
Worker handoff.
Definition: ipsec.h:194
u32 esp6_decrypt_tun_node_index
Definition: ipsec.h:74
u32 node_index
Node index.
Definition: node.h:479
u32 ah4_dec_fq_index
Definition: ipsec.h:195
u32 esp4_encrypt_node_index
Definition: ipsec.h:63
uword * spd_index_by_spd_id
Definition: ipsec.h:125
u32 esp_mpls_enc_tun_fq_index
Definition: ipsec.h:205
vnet_crypto_op_t * chained_crypto_ops
Definition: ipsec.h:102
u32 ah6_enc_fq_index
Definition: ipsec.h:196
u32 ah4_decrypt_node_index
Definition: ipsec.h:45
u32 ah6_encrypt_next_index
Definition: ipsec.h:160
u32 esp6_decrypt_tun_next_index
Definition: ipsec.h:159
ipsec_ah_backend_t * ah_backends
Definition: ipsec.h:172
vnet_crypto_async_frame_t ** async_frames
Definition: ipsec.h:105
static_always_inline void vnet_feature_next(u32 *next0, vlib_buffer_t *b0)
Definition: feature.h:322
u32 esp6_enc_tun_fq_index
Definition: ipsec.h:204
u32 esp4_encrypt_next_index
Definition: ipsec.h:152
u32 ah4_encrypt_next_index
Definition: ipsec.h:46
uword * sa_index_by_sa_id
Definition: ipsec.h:127
void ipsec_set_async_mode(u32 is_enabled)
Definition: ipsec.c:327
int ipsec_select_ah_backend(ipsec_main_t *im, u32 ah_backend_idx)
Definition: ipsec.c:257
u32 esp6_decrypt_next_index
Definition: ipsec.h:158
u32 esp4_encrypt_tun_node_index
Definition: ipsec.h:141
A Secruity Policy.
vlib_main_t * vlib_main
Definition: ipsec.h:121
uword * ipsec_if_real_dev_by_show_dev
Definition: ipsec.h:130
u32 esp4_no_crypto_tun_node_index
Definition: ipsec.h:164
u32 esp6_encrypt_next_index
Definition: ipsec.h:157
vnet_crypto_op_id_t op_id
Definition: ipsec.h:92
u32 ah4_encrypt_node_index
Definition: ipsec.h:142
ipsec_main_integ_alg_t * integ_algs
Definition: ipsec.h:188
u32 esp6_dec_fq_index
Definition: ipsec.h:202
ipsec_policy_t * policies
Definition: ipsec.h:113
clib_error_t * ipsec_add_del_sa_sess_cb(ipsec_main_t *im, u32 sa_index, u8 is_add)
Definition: ipsec.c:69
u32 esp6_enc_fq_index
Definition: ipsec.h:201
u32 esp4_decrypt_node_index
Definition: ipsec.h:139
add_del_sa_sess_cb_t add_del_sa_sess_cb
Definition: ipsec.h:58
vnet_crypto_op_id_t dec_op_id
Definition: ipsec.h:83
u32 ah6_decrypt_node_index
Definition: ipsec.h:150
static vlib_main_t * vlib_get_main(void)
Definition: global_funcs.h:38
struct _vlib_node_registration vlib_node_registration_t
u32 esp4_enc_fq_index
Definition: ipsec.h:199
u32 ah6_encrypt_node_index
Definition: ipsec.h:149
u32 ipsec_register_ah_backend(vlib_main_t *vm, ipsec_main_t *im, const char *name, const char *ah4_encrypt_node_name, const char *ah4_decrypt_node_name, const char *ah6_encrypt_node_name, const char *ah6_decrypt_node_name, check_support_cb_t ah_check_support_cb, add_del_sa_sess_cb_t ah_add_del_sa_sess_cb)
Definition: ipsec.c:172
clib_error_t * ipsec_rsc_in_use(ipsec_main_t *im)
Definition: ipsec.c:246
u32 ah6_decrypt_next_index
Definition: ipsec.h:161
check_support_cb_t check_support_cb
Definition: ipsec.h:43
u32 esp4_decrypt_tun_node_index
Definition: ipsec.h:71
vlib_main_t vlib_node_runtime_t * node
Definition: nat44_ei.c:3047
VLIB buffer representation.
Definition: buffer.h:111
u64 uword
Definition: types.h:112
u32 esp4_encrypt_tun_node_index
Definition: ipsec.h:73
vnet_crypto_op_t * chained_integ_ops
Definition: ipsec.h:103
u32 esp4_decrypt_next_index
Definition: ipsec.h:66
vnet_crypto_op_id_t
Definition: crypto.h:219
void ipsec_unregister_udp_port(u16 udp_port)
Definition: ipsec.c:128
static vlib_node_t * vlib_get_node(vlib_main_t *vm, u32 i)
Get vlib node by index.
Definition: node_funcs.h:86
vnet_crypto_alg_t alg
Definition: ipsec.h:84
add_del_sa_sess_cb_t add_del_sa_sess_cb
Definition: ipsec.h:41
ipsec_esp_backend_t * esp_backends
Definition: ipsec.h:174
clib_error_t *(* add_del_sa_sess_cb_t)(u32 sa_index, u8 is_add)
Definition: ipsec.h:33
u8 async_mode
Definition: ipsec.h:209
u32 esp6_encrypt_tun_node_index
Definition: ipsec.h:147
enum ipsec_format_flags_t_ ipsec_format_flags_t
vlib_node_registration_t ipsec4_tun_input_node
(constructor) VLIB_REGISTER_NODE (ipsec4_tun_input_node)
Definition: ipsec_tun_in.c:388