Coverage Report

Created: 2026-05-20 07:05

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl/providers/implementations/kdfs/x942kdf.inc
Line
Count
Source
1
/*
2
 * Copyright 2025 The OpenSSL Project Authors. All Rights Reserved.
3
 *
4
 * Licensed under the Apache License 2.0 (the \"License\").  You may not use
5
 * this file except in compliance with the License.  You can obtain a copy
6
 * in the file LICENSE in the source distribution or at
7
 * https://www.openssl.org/source/license.html
8
 */
9
10
11
12
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
13
#include <string.h>
14
#include <openssl/params.h>
15
#include "internal/common.h"
16
#include "prov/proverr.h"
17
18
#ifndef sshkdf_set_ctx_params_list
19
static const OSSL_PARAM sshkdf_set_ctx_params_list[] = {
20
    OSSL_PARAM_utf8_string(OSSL_KDF_PARAM_PROPERTIES, NULL, 0),
21
    OSSL_PARAM_utf8_string(OSSL_KDF_PARAM_DIGEST, NULL, 0),
22
    OSSL_PARAM_octet_string(OSSL_KDF_PARAM_SECRET, NULL, 0),
23
    OSSL_PARAM_octet_string(OSSL_KDF_PARAM_KEY, NULL, 0),
24
    OSSL_PARAM_octet_string(OSSL_KDF_PARAM_UKM, NULL, 0),
25
    OSSL_PARAM_octet_string(OSSL_KDF_PARAM_X942_ACVPINFO, NULL, 0),
26
    OSSL_PARAM_octet_string(OSSL_KDF_PARAM_X942_PARTYUINFO, NULL, 0),
27
    OSSL_PARAM_octet_string(OSSL_KDF_PARAM_X942_PARTYVINFO, NULL, 0),
28
    OSSL_PARAM_octet_string(OSSL_KDF_PARAM_X942_SUPP_PUBINFO, NULL, 0),
29
    OSSL_PARAM_octet_string(OSSL_KDF_PARAM_X942_SUPP_PRIVINFO, NULL, 0),
30
    OSSL_PARAM_int(OSSL_KDF_PARAM_X942_USE_KEYBITS, NULL),
31
    OSSL_PARAM_utf8_string(OSSL_KDF_PARAM_CEK_ALG, NULL, 0),
32
# if defined(FIPS_MODULE)
33
    OSSL_PARAM_int(OSSL_KDF_PARAM_FIPS_KEY_CHECK, NULL),
34
# endif
35
    OSSL_PARAM_END
36
};
37
#endif
38
39
#ifndef sshkdf_set_ctx_params_st
40
struct sshkdf_set_ctx_params_st {
41
    OSSL_PARAM *acvp;
42
    OSSL_PARAM *cekalg;
43
    OSSL_PARAM *digest;
44
# if defined(FIPS_MODULE)
45
    OSSL_PARAM *ind_k;
46
# endif
47
    OSSL_PARAM *kbits;
48
    OSSL_PARAM *priv;
49
    OSSL_PARAM *propq;
50
    OSSL_PARAM *pub;
51
    OSSL_PARAM *secret;
52
    OSSL_PARAM *uinfo;
53
    OSSL_PARAM *vinfo;
54
};
55
#endif
56
57
#ifndef sshkdf_set_ctx_params_decoder
58
static int sshkdf_set_ctx_params_decoder
59
    (const OSSL_PARAM *p, struct sshkdf_set_ctx_params_st *r)
60
0
{
61
0
    const char *s;
62
63
0
    memset(r, 0, sizeof(*r));
64
0
    if (p != NULL)
65
0
        for (; (s = p->key) != NULL; p++)
66
0
            switch(s[0]) {
67
0
            default:
68
0
                break;
69
0
            case 'a':
70
0
                if (ossl_likely(strcmp("cvp-info", s + 1) == 0)) {
71
                    /* OSSL_KDF_PARAM_X942_ACVPINFO */
72
0
                    if (ossl_unlikely(r->acvp != NULL)) {
73
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
74
0
                                       "param %s is repeated", s);
75
0
                        return 0;
76
0
                    }
77
0
                    r->acvp = (OSSL_PARAM *)p;
78
0
                }
79
0
                break;
80
0
            case 'c':
81
0
                if (ossl_likely(strcmp("ekalg", s + 1) == 0)) {
82
                    /* OSSL_KDF_PARAM_CEK_ALG */
83
0
                    if (ossl_unlikely(r->cekalg != NULL)) {
84
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
85
0
                                       "param %s is repeated", s);
86
0
                        return 0;
87
0
                    }
88
0
                    r->cekalg = (OSSL_PARAM *)p;
89
0
                }
90
0
                break;
91
0
            case 'd':
92
0
                if (ossl_likely(strcmp("igest", s + 1) == 0)) {
93
                    /* OSSL_KDF_PARAM_DIGEST */
94
0
                    if (ossl_unlikely(r->digest != NULL)) {
95
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
96
0
                                       "param %s is repeated", s);
97
0
                        return 0;
98
0
                    }
99
0
                    r->digest = (OSSL_PARAM *)p;
100
0
                }
101
0
                break;
102
0
            case 'k':
103
0
                switch(s[1]) {
104
0
                default:
105
0
                    break;
106
0
                case 'e':
107
0
                    switch(s[2]) {
108
0
                    default:
109
0
                        break;
110
0
                    case 'y':
111
0
                        switch(s[3]) {
112
0
                        default:
113
0
                            break;
114
0
                        case '-':
115
# if defined(FIPS_MODULE)
116
                            if (ossl_likely(strcmp("check", s + 4) == 0)) {
117
                                /* OSSL_KDF_PARAM_FIPS_KEY_CHECK */
118
                                if (ossl_unlikely(r->ind_k != NULL)) {
119
                                    ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
120
                                                   "param %s is repeated", s);
121
                                    return 0;
122
                                }
123
                                r->ind_k = (OSSL_PARAM *)p;
124
                            }
125
# endif
126
0
                            break;
127
0
                        case '\0':
128
0
                            if (ossl_unlikely(r->secret != NULL)) {
129
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
130
0
                                               "param %s is repeated", s);
131
0
                                return 0;
132
0
                            }
133
0
                            r->secret = (OSSL_PARAM *)p;
134
0
                        }
135
0
                    }
136
0
                }
137
0
                break;
138
0
            case 'p':
139
0
                switch(s[1]) {
140
0
                default:
141
0
                    break;
142
0
                case 'a':
143
0
                    switch(s[2]) {
144
0
                    default:
145
0
                        break;
146
0
                    case 'r':
147
0
                        switch(s[3]) {
148
0
                        default:
149
0
                            break;
150
0
                        case 't':
151
0
                            switch(s[4]) {
152
0
                            default:
153
0
                                break;
154
0
                            case 'y':
155
0
                                switch(s[5]) {
156
0
                                default:
157
0
                                    break;
158
0
                                case 'u':
159
0
                                    if (ossl_likely(strcmp("-info", s + 6) == 0)) {
160
                                        /* OSSL_KDF_PARAM_X942_PARTYUINFO */
161
0
                                        if (ossl_unlikely(r->uinfo != NULL)) {
162
0
                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
163
0
                                                           "param %s is repeated", s);
164
0
                                            return 0;
165
0
                                        }
166
0
                                        r->uinfo = (OSSL_PARAM *)p;
167
0
                                    }
168
0
                                    break;
169
0
                                case 'v':
170
0
                                    if (ossl_likely(strcmp("-info", s + 6) == 0)) {
171
                                        /* OSSL_KDF_PARAM_X942_PARTYVINFO */
172
0
                                        if (ossl_unlikely(r->vinfo != NULL)) {
173
0
                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
174
0
                                                           "param %s is repeated", s);
175
0
                                            return 0;
176
0
                                        }
177
0
                                        r->vinfo = (OSSL_PARAM *)p;
178
0
                                    }
179
0
                                }
180
0
                            }
181
0
                        }
182
0
                    }
183
0
                    break;
184
0
                case 'r':
185
0
                    if (ossl_likely(strcmp("operties", s + 2) == 0)) {
186
                        /* OSSL_KDF_PARAM_PROPERTIES */
187
0
                        if (ossl_unlikely(r->propq != NULL)) {
188
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
189
0
                                           "param %s is repeated", s);
190
0
                            return 0;
191
0
                        }
192
0
                        r->propq = (OSSL_PARAM *)p;
193
0
                    }
194
0
                }
195
0
                break;
196
0
            case 's':
197
0
                switch(s[1]) {
198
0
                default:
199
0
                    break;
200
0
                case 'e':
201
0
                    if (ossl_likely(strcmp("cret", s + 2) == 0)) {
202
                        /* OSSL_KDF_PARAM_SECRET */
203
0
                        if (ossl_unlikely(r->secret != NULL)) {
204
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
205
0
                                           "param %s is repeated", s);
206
0
                            return 0;
207
0
                        }
208
0
                        r->secret = (OSSL_PARAM *)p;
209
0
                    }
210
0
                    break;
211
0
                case 'u':
212
0
                    switch(s[2]) {
213
0
                    default:
214
0
                        break;
215
0
                    case 'p':
216
0
                        switch(s[3]) {
217
0
                        default:
218
0
                            break;
219
0
                        case 'p':
220
0
                            switch(s[4]) {
221
0
                            default:
222
0
                                break;
223
0
                            case '-':
224
0
                                switch(s[5]) {
225
0
                                default:
226
0
                                    break;
227
0
                                case 'p':
228
0
                                    switch(s[6]) {
229
0
                                    default:
230
0
                                        break;
231
0
                                    case 'r':
232
0
                                        if (ossl_likely(strcmp("ivinfo", s + 7) == 0)) {
233
                                            /* OSSL_KDF_PARAM_X942_SUPP_PRIVINFO */
234
0
                                            if (ossl_unlikely(r->priv != NULL)) {
235
0
                                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
236
0
                                                               "param %s is repeated", s);
237
0
                                                return 0;
238
0
                                            }
239
0
                                            r->priv = (OSSL_PARAM *)p;
240
0
                                        }
241
0
                                        break;
242
0
                                    case 'u':
243
0
                                        if (ossl_likely(strcmp("binfo", s + 7) == 0)) {
244
                                            /* OSSL_KDF_PARAM_X942_SUPP_PUBINFO */
245
0
                                            if (ossl_unlikely(r->pub != NULL)) {
246
0
                                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
247
0
                                                               "param %s is repeated", s);
248
0
                                                return 0;
249
0
                                            }
250
0
                                            r->pub = (OSSL_PARAM *)p;
251
0
                                        }
252
0
                                    }
253
0
                                }
254
0
                            }
255
0
                        }
256
0
                    }
257
0
                }
258
0
                break;
259
0
            case 'u':
260
0
                switch(s[1]) {
261
0
                default:
262
0
                    break;
263
0
                case 'k':
264
0
                    if (ossl_likely(strcmp("m", s + 2) == 0)) {
265
                        /* OSSL_KDF_PARAM_UKM */
266
0
                        if (ossl_unlikely(r->uinfo != NULL)) {
267
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
268
0
                                           "param %s is repeated", s);
269
0
                            return 0;
270
0
                        }
271
0
                        r->uinfo = (OSSL_PARAM *)p;
272
0
                    }
273
0
                    break;
274
0
                case 's':
275
0
                    if (ossl_likely(strcmp("e-keybits", s + 2) == 0)) {
276
                        /* OSSL_KDF_PARAM_X942_USE_KEYBITS */
277
0
                        if (ossl_unlikely(r->kbits != NULL)) {
278
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
279
0
                                           "param %s is repeated", s);
280
0
                            return 0;
281
0
                        }
282
0
                        r->kbits = (OSSL_PARAM *)p;
283
0
                    }
284
0
                }
285
0
            }
286
0
    return 1;
287
0
}
288
#endif
289
/* End of machine generated */
290
291
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
292
#include <string.h>
293
#include <openssl/params.h>
294
#include "internal/common.h"
295
#include "prov/proverr.h"
296
297
#ifndef sshkdf_get_ctx_params_list
298
static const OSSL_PARAM sshkdf_get_ctx_params_list[] = {
299
    OSSL_PARAM_size_t(OSSL_KDF_PARAM_SIZE, NULL),
300
# if defined(FIPS_MODULE)
301
    OSSL_PARAM_int(OSSL_KDF_PARAM_FIPS_APPROVED_INDICATOR, NULL),
302
# endif
303
    OSSL_PARAM_END
304
};
305
#endif
306
307
#ifndef sshkdf_get_ctx_params_st
308
struct sshkdf_get_ctx_params_st {
309
# if defined(FIPS_MODULE)
310
    OSSL_PARAM *ind;
311
# endif
312
    OSSL_PARAM *size;
313
};
314
#endif
315
316
#ifndef sshkdf_get_ctx_params_decoder
317
static int sshkdf_get_ctx_params_decoder
318
    (const OSSL_PARAM *p, struct sshkdf_get_ctx_params_st *r)
319
0
{
320
0
    const char *s;
321
322
0
    memset(r, 0, sizeof(*r));
323
0
    if (p != NULL)
324
0
        for (; (s = p->key) != NULL; p++)
325
0
            switch(s[0]) {
326
0
            default:
327
0
                break;
328
0
            case 'f':
329
# if defined(FIPS_MODULE)
330
                if (ossl_likely(strcmp("ips-indicator", s + 1) == 0)) {
331
                    /* OSSL_KDF_PARAM_FIPS_APPROVED_INDICATOR */
332
                    if (ossl_unlikely(r->ind != NULL)) {
333
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
334
                                       "param %s is repeated", s);
335
                        return 0;
336
                    }
337
                    r->ind = (OSSL_PARAM *)p;
338
                }
339
# endif
340
0
                break;
341
0
            case 's':
342
0
                if (ossl_likely(strcmp("ize", s + 1) == 0)) {
343
                    /* OSSL_KDF_PARAM_SIZE */
344
0
                    if (ossl_unlikely(r->size != NULL)) {
345
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
346
0
                                       "param %s is repeated", s);
347
0
                        return 0;
348
0
                    }
349
0
                    r->size = (OSSL_PARAM *)p;
350
0
                }
351
0
            }
352
0
    return 1;
353
0
}
354
#endif
355
/* End of machine generated */