crypto: introduce async crypto infra
[vpp.git] / src / vnet / crypto / format.c
1 /*
2  * Copyright (c) 2019 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
16 #include <stdbool.h>
17 #include <vlib/vlib.h>
18 #include <vnet/crypto/crypto.h>
19
20 u8 *
21 format_vnet_crypto_alg (u8 * s, va_list * args)
22 {
23   vnet_crypto_alg_t alg = va_arg (*args, vnet_crypto_alg_t);
24   vnet_crypto_main_t *cm = &crypto_main;
25   vnet_crypto_alg_data_t *d = vec_elt_at_index (cm->algs, alg);
26   return format (s, "%s", d->name);
27 }
28
29 uword
30 unformat_vnet_crypto_alg (unformat_input_t * input, va_list * args)
31 {
32   vnet_crypto_main_t *cm = &crypto_main;
33   vnet_crypto_alg_t *alg = va_arg (*args, vnet_crypto_alg_t *);
34   uword *p;
35   u8 *name;
36
37   if (!unformat (input, "%s", &name))
38     return 0;
39
40   p = hash_get_mem (cm->alg_index_by_name, name);
41   vec_free (name);
42   if (p == 0)
43     return 0;
44
45   *alg = p[0];
46
47   return 1;
48 }
49
50 u8 *
51 format_vnet_crypto_op (u8 * s, va_list * args)
52 {
53   vnet_crypto_main_t *cm = &crypto_main;
54   vnet_crypto_op_id_t op = va_arg (*args, int); // vnet_crypto_op_id_t);
55   vnet_crypto_op_data_t *otd = cm->opt_data + op;
56
57   return format (s, "%U-%U", format_vnet_crypto_op_type, otd->type,
58                  format_vnet_crypto_alg, otd->alg);
59 }
60
61 u8 *
62 format_vnet_crypto_op_type (u8 * s, va_list * args)
63 {
64   vnet_crypto_op_type_t opt = va_arg (*args, vnet_crypto_op_type_t);
65   char *strings[] = {
66 #define _(n, s) [VNET_CRYPTO_OP_TYPE_##n] = s,
67     foreach_crypto_op_type
68 #undef _
69   };
70
71   if (opt >= VNET_CRYPTO_OP_N_TYPES)
72     return format (s, "unknown");
73
74   return format (s, "%s", strings[opt]);
75 }
76
77 u8 *
78 format_vnet_crypto_op_status (u8 * s, va_list * args)
79 {
80   vnet_crypto_op_status_t st = va_arg (*args, vnet_crypto_op_status_t);
81   char *strings[] = {
82 #define _(n, s) [VNET_CRYPTO_OP_STATUS_##n] = s,
83     foreach_crypto_op_status
84 #undef _
85   };
86
87   if (st >= VNET_CRYPTO_OP_N_STATUS)
88     return format (s, "unknown");
89
90   return format (s, "%s", strings[st]);
91 }
92
93 u8 *
94 format_vnet_crypto_engine (u8 * s, va_list * args)
95 {
96   vnet_crypto_main_t *cm = &crypto_main;
97   u32 crypto_engine_index = va_arg (*args, u32);
98   vnet_crypto_engine_t *e;
99
100   if (crypto_engine_index == ~0)
101     return s;
102
103   e = vec_elt_at_index (cm->engines, crypto_engine_index);
104
105   return format (s, "%s", e->name);
106 }
107
108 u8 *
109 format_vnet_crypto_async_op_type (u8 * s, va_list * args)
110 {
111   vnet_crypto_async_op_type_t opt =
112     va_arg (*args, vnet_crypto_async_op_type_t);
113   char *strings[] = {
114 #define _(n, s) [VNET_CRYPTO_ASYNC_OP_TYPE_##n] = s,
115     foreach_crypto_async_op_type
116 #undef _
117   };
118
119   if (opt >= VNET_CRYPTO_ASYNC_OP_N_TYPES)
120     return format (s, "unknown");
121
122   return format (s, "%s", strings[opt]);
123 }
124
125 u8 *
126 format_vnet_crypto_async_alg (u8 * s, va_list * args)
127 {
128   vnet_crypto_async_alg_t alg = va_arg (*args, vnet_crypto_async_alg_t);
129   vnet_crypto_main_t *cm = &crypto_main;
130   vnet_crypto_async_alg_data_t *d = vec_elt_at_index (cm->async_algs, alg);
131   return format (s, "%s", d->name);
132 }
133
134 u8 *
135 format_vnet_crypto_async_op (u8 * s, va_list * args)
136 {
137   vnet_crypto_main_t *cm = &crypto_main;
138   vnet_crypto_async_op_id_t op = va_arg (*args, int);   // vnet_crypto_op_id_t);
139   vnet_crypto_async_op_data_t *otd = cm->async_opt_data + op;
140
141   return format (s, "%U-%U", format_vnet_crypto_async_op_type, otd->type,
142                  format_vnet_crypto_async_alg, otd->alg);
143
144   vnet_crypto_async_op_id_t opt = va_arg (*args, vnet_crypto_async_op_id_t);
145   char *strings[] = {
146 #define _(n, s, k, t, a) \
147                 [VNET_CRYPTO_OP_##n##_TAG##t##_AAD##a##_ENC] = s "-enc", \
148                 [VNET_CRYPTO_OP_##n##_TAG##t##_AAD##a##_DEC] = s "-dec",
149     foreach_crypto_aead_async_alg
150 #undef _
151 #define _(c, h, s, k ,d) \
152                 [VNET_CRYPTO_OP_##c##_##h##_TAG##d##_ENC] = s "-enc", \
153                 [VNET_CRYPTO_OP_##c##_##h##_TAG##d##_DEC] = s "-dec",
154       foreach_crypto_link_async_alg
155 #undef _
156   };
157
158   if (opt >= VNET_CRYPTO_ASYNC_OP_N_IDS)
159     return format (s, "unknown");
160
161   return format (s, "%s", strings[opt]);
162 }
163
164 /*
165  * fd.io coding-style-patch-verification: ON
166  *
167  * Local Variables:
168  * eval: (c-set-style "gnu")
169  * End:
170  */