Coverage Report

Created: 2026-04-11 06:29

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl/providers/implementations/keymgmt/ml_kem_kmgmt.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
#ifndef ml_kem_import_params_list
14
static const OSSL_PARAM ml_kem_import_params_list[] = {
15
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_KEM_SEED, NULL, 0),
16
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PRIV_KEY, NULL, 0),
17
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PUB_KEY, NULL, 0),
18
    OSSL_PARAM_utf8_string(OSSL_PKEY_PARAM_PROPERTIES, NULL, 0),
19
    OSSL_PARAM_END
20
};
21
#endif
22
23
#ifndef ml_kem_import_params_st
24
struct ml_kem_import_params_st {
25
    OSSL_PARAM *privkey;
26
    OSSL_PARAM *propq;
27
    OSSL_PARAM *pubkey;
28
    OSSL_PARAM *seed;
29
};
30
#endif
31
32
#ifndef ml_kem_import_params_decoder
33
static int ml_kem_import_params_decoder
34
    (const OSSL_PARAM *p, struct ml_kem_import_params_st *r)
35
0
{
36
0
    const char *s;
37
38
0
    memset(r, 0, sizeof(*r));
39
0
    if (p != NULL)
40
0
        for (; (s = p->key) != NULL; p++)
41
0
            switch(s[0]) {
42
0
            default:
43
0
                break;
44
0
            case 'p':
45
0
                switch(s[1]) {
46
0
                default:
47
0
                    break;
48
0
                case 'r':
49
0
                    switch(s[2]) {
50
0
                    default:
51
0
                        break;
52
0
                    case 'i':
53
0
                        if (ossl_likely(strcmp("v", s + 3) == 0)) {
54
                            /* OSSL_PKEY_PARAM_PRIV_KEY */
55
0
                            if (ossl_unlikely(r->privkey != NULL)) {
56
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
57
0
                                               "param %s is repeated", s);
58
0
                                return 0;
59
0
                            }
60
0
                            r->privkey = (OSSL_PARAM *)p;
61
0
                        }
62
0
                        break;
63
0
                    case 'o':
64
0
                        if (ossl_likely(strcmp("perties", s + 3) == 0)) {
65
                            /* OSSL_PKEY_PARAM_PROPERTIES */
66
0
                            if (ossl_unlikely(r->propq != NULL)) {
67
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
68
0
                                               "param %s is repeated", s);
69
0
                                return 0;
70
0
                            }
71
0
                            r->propq = (OSSL_PARAM *)p;
72
0
                        }
73
0
                    }
74
0
                    break;
75
0
                case 'u':
76
0
                    if (ossl_likely(strcmp("b", s + 2) == 0)) {
77
                        /* OSSL_PKEY_PARAM_PUB_KEY */
78
0
                        if (ossl_unlikely(r->pubkey != NULL)) {
79
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
80
0
                                           "param %s is repeated", s);
81
0
                            return 0;
82
0
                        }
83
0
                        r->pubkey = (OSSL_PARAM *)p;
84
0
                    }
85
0
                }
86
0
                break;
87
0
            case 's':
88
0
                if (ossl_likely(strcmp("eed", s + 1) == 0)) {
89
                    /* OSSL_PKEY_PARAM_ML_KEM_SEED */
90
0
                    if (ossl_unlikely(r->seed != NULL)) {
91
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
92
0
                                       "param %s is repeated", s);
93
0
                        return 0;
94
0
                    }
95
0
                    r->seed = (OSSL_PARAM *)p;
96
0
                }
97
0
            }
98
0
    return 1;
99
0
}
100
#endif
101
/* End of machine generated */
102
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
103
#ifndef ml_kem_export_params_list
104
static const OSSL_PARAM ml_kem_export_params_list[] = {
105
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_KEM_SEED, NULL, 0),
106
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PRIV_KEY, NULL, 0),
107
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PUB_KEY, NULL, 0),
108
    OSSL_PARAM_END
109
};
110
#endif
111
112
#ifndef ml_kem_export_params_st
113
struct ml_kem_export_params_st {
114
    OSSL_PARAM *privkey;
115
    OSSL_PARAM *pubkey;
116
    OSSL_PARAM *seed;
117
};
118
#endif
119
120
#ifndef ml_kem_export_params_decoder
121
static int ml_kem_export_params_decoder
122
    (const OSSL_PARAM *p, struct ml_kem_export_params_st *r)
123
{
124
    const char *s;
125
126
    memset(r, 0, sizeof(*r));
127
    if (p != NULL)
128
        for (; (s = p->key) != NULL; p++)
129
            switch(s[0]) {
130
            default:
131
                break;
132
            case 'p':
133
                switch(s[1]) {
134
                default:
135
                    break;
136
                case 'r':
137
                    if (ossl_likely(strcmp("iv", s + 2) == 0)) {
138
                        /* OSSL_PKEY_PARAM_PRIV_KEY */
139
                        if (ossl_unlikely(r->privkey != NULL)) {
140
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
141
                                           "param %s is repeated", s);
142
                            return 0;
143
                        }
144
                        r->privkey = (OSSL_PARAM *)p;
145
                    }
146
                    break;
147
                case 'u':
148
                    if (ossl_likely(strcmp("b", s + 2) == 0)) {
149
                        /* OSSL_PKEY_PARAM_PUB_KEY */
150
                        if (ossl_unlikely(r->pubkey != NULL)) {
151
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
152
                                           "param %s is repeated", s);
153
                            return 0;
154
                        }
155
                        r->pubkey = (OSSL_PARAM *)p;
156
                    }
157
                }
158
                break;
159
            case 's':
160
                if (ossl_likely(strcmp("eed", s + 1) == 0)) {
161
                    /* OSSL_PKEY_PARAM_ML_KEM_SEED */
162
                    if (ossl_unlikely(r->seed != NULL)) {
163
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
164
                                       "param %s is repeated", s);
165
                        return 0;
166
                    }
167
                    r->seed = (OSSL_PARAM *)p;
168
                }
169
            }
170
    return 1;
171
}
172
#endif
173
/* End of machine generated */
174
175
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
176
#ifndef ml_kem_get_params_list
177
static const OSSL_PARAM ml_kem_get_params_list[] = {
178
    OSSL_PARAM_int(OSSL_PKEY_PARAM_BITS, NULL),
179
    OSSL_PARAM_int(OSSL_PKEY_PARAM_SECURITY_BITS, NULL),
180
    OSSL_PARAM_int(OSSL_PKEY_PARAM_MAX_SIZE, NULL),
181
    OSSL_PARAM_int(OSSL_PKEY_PARAM_SECURITY_CATEGORY, NULL),
182
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_KEM_SEED, NULL, 0),
183
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PRIV_KEY, NULL, 0),
184
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PUB_KEY, NULL, 0),
185
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ENCODED_PUBLIC_KEY, NULL, 0),
186
    OSSL_PARAM_int(OSSL_PKEY_PARAM_CMS_RI_TYPE, NULL),
187
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_CMS_KEMRI_KDF_ALGORITHM, NULL, 0),
188
    OSSL_PARAM_END
189
};
190
#endif
191
192
#ifndef ml_kem_get_params_st
193
struct ml_kem_get_params_st {
194
    OSSL_PARAM *bits;
195
    OSSL_PARAM *encpubkey;
196
    OSSL_PARAM *kemri_kdf_alg;
197
    OSSL_PARAM *maxsize;
198
    OSSL_PARAM *privkey;
199
    OSSL_PARAM *pubkey;
200
    OSSL_PARAM *ri_type;
201
    OSSL_PARAM *secbits;
202
    OSSL_PARAM *seccat;
203
    OSSL_PARAM *seed;
204
};
205
#endif
206
207
#ifndef ml_kem_get_params_decoder
208
static int ml_kem_get_params_decoder
209
    (const OSSL_PARAM *p, struct ml_kem_get_params_st *r)
210
0
{
211
0
    const char *s;
212
213
0
    memset(r, 0, sizeof(*r));
214
0
    if (p != NULL)
215
0
        for (; (s = p->key) != NULL; p++)
216
0
            switch(s[0]) {
217
0
            default:
218
0
                break;
219
0
            case 'b':
220
0
                if (ossl_likely(strcmp("its", s + 1) == 0)) {
221
                    /* OSSL_PKEY_PARAM_BITS */
222
0
                    if (ossl_unlikely(r->bits != NULL)) {
223
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
224
0
                                       "param %s is repeated", s);
225
0
                        return 0;
226
0
                    }
227
0
                    r->bits = (OSSL_PARAM *)p;
228
0
                }
229
0
                break;
230
0
            case 'e':
231
0
                if (ossl_likely(strcmp("ncoded-pub-key", s + 1) == 0)) {
232
                    /* OSSL_PKEY_PARAM_ENCODED_PUBLIC_KEY */
233
0
                    if (ossl_unlikely(r->encpubkey != NULL)) {
234
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
235
0
                                       "param %s is repeated", s);
236
0
                        return 0;
237
0
                    }
238
0
                    r->encpubkey = (OSSL_PARAM *)p;
239
0
                }
240
0
                break;
241
0
            case 'k':
242
0
                if (ossl_likely(strcmp("emri-kdf-alg", s + 1) == 0)) {
243
                    /* OSSL_PKEY_PARAM_CMS_KEMRI_KDF_ALGORITHM */
244
0
                    if (ossl_unlikely(r->kemri_kdf_alg != NULL)) {
245
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
246
0
                                       "param %s is repeated", s);
247
0
                        return 0;
248
0
                    }
249
0
                    r->kemri_kdf_alg = (OSSL_PARAM *)p;
250
0
                }
251
0
                break;
252
0
            case 'm':
253
0
                if (ossl_likely(strcmp("ax-size", s + 1) == 0)) {
254
                    /* OSSL_PKEY_PARAM_MAX_SIZE */
255
0
                    if (ossl_unlikely(r->maxsize != NULL)) {
256
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
257
0
                                       "param %s is repeated", s);
258
0
                        return 0;
259
0
                    }
260
0
                    r->maxsize = (OSSL_PARAM *)p;
261
0
                }
262
0
                break;
263
0
            case 'p':
264
0
                switch(s[1]) {
265
0
                default:
266
0
                    break;
267
0
                case 'r':
268
0
                    if (ossl_likely(strcmp("iv", s + 2) == 0)) {
269
                        /* OSSL_PKEY_PARAM_PRIV_KEY */
270
0
                        if (ossl_unlikely(r->privkey != NULL)) {
271
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
272
0
                                           "param %s is repeated", s);
273
0
                            return 0;
274
0
                        }
275
0
                        r->privkey = (OSSL_PARAM *)p;
276
0
                    }
277
0
                    break;
278
0
                case 'u':
279
0
                    if (ossl_likely(strcmp("b", s + 2) == 0)) {
280
                        /* OSSL_PKEY_PARAM_PUB_KEY */
281
0
                        if (ossl_unlikely(r->pubkey != NULL)) {
282
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
283
0
                                           "param %s is repeated", s);
284
0
                            return 0;
285
0
                        }
286
0
                        r->pubkey = (OSSL_PARAM *)p;
287
0
                    }
288
0
                }
289
0
                break;
290
0
            case 'r':
291
0
                if (ossl_likely(strcmp("i-type", s + 1) == 0)) {
292
                    /* OSSL_PKEY_PARAM_CMS_RI_TYPE */
293
0
                    if (ossl_unlikely(r->ri_type != NULL)) {
294
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
295
0
                                       "param %s is repeated", s);
296
0
                        return 0;
297
0
                    }
298
0
                    r->ri_type = (OSSL_PARAM *)p;
299
0
                }
300
0
                break;
301
0
            case 's':
302
0
                switch(s[1]) {
303
0
                default:
304
0
                    break;
305
0
                case 'e':
306
0
                    switch(s[2]) {
307
0
                    default:
308
0
                        break;
309
0
                    case 'c':
310
0
                        switch(s[3]) {
311
0
                        default:
312
0
                            break;
313
0
                        case 'u':
314
0
                            switch(s[4]) {
315
0
                            default:
316
0
                                break;
317
0
                            case 'r':
318
0
                                switch(s[5]) {
319
0
                                default:
320
0
                                    break;
321
0
                                case 'i':
322
0
                                    switch(s[6]) {
323
0
                                    default:
324
0
                                        break;
325
0
                                    case 't':
326
0
                                        switch(s[7]) {
327
0
                                        default:
328
0
                                            break;
329
0
                                        case 'y':
330
0
                                            switch(s[8]) {
331
0
                                            default:
332
0
                                                break;
333
0
                                            case '-':
334
0
                                                switch(s[9]) {
335
0
                                                default:
336
0
                                                    break;
337
0
                                                case 'b':
338
0
                                                    if (ossl_likely(strcmp("its", s + 10) == 0)) {
339
                                                        /* OSSL_PKEY_PARAM_SECURITY_BITS */
340
0
                                                        if (ossl_unlikely(r->secbits != NULL)) {
341
0
                                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
342
0
                                                                           "param %s is repeated", s);
343
0
                                                            return 0;
344
0
                                                        }
345
0
                                                        r->secbits = (OSSL_PARAM *)p;
346
0
                                                    }
347
0
                                                    break;
348
0
                                                case 'c':
349
0
                                                    if (ossl_likely(strcmp("ategory", s + 10) == 0)) {
350
                                                        /* OSSL_PKEY_PARAM_SECURITY_CATEGORY */
351
0
                                                        if (ossl_unlikely(r->seccat != NULL)) {
352
0
                                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
353
0
                                                                           "param %s is repeated", s);
354
0
                                                            return 0;
355
0
                                                        }
356
0
                                                        r->seccat = (OSSL_PARAM *)p;
357
0
                                                    }
358
0
                                                }
359
0
                                            }
360
0
                                        }
361
0
                                    }
362
0
                                }
363
0
                            }
364
0
                        }
365
0
                        break;
366
0
                    case 'e':
367
0
                        if (ossl_likely(strcmp("d", s + 3) == 0)) {
368
                            /* OSSL_PKEY_PARAM_ML_KEM_SEED */
369
0
                            if (ossl_unlikely(r->seed != NULL)) {
370
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
371
0
                                               "param %s is repeated", s);
372
0
                                return 0;
373
0
                            }
374
0
                            r->seed = (OSSL_PARAM *)p;
375
0
                        }
376
0
                    }
377
0
                }
378
0
            }
379
0
    return 1;
380
0
}
381
#endif
382
/* End of machine generated */
383
384
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
385
#ifndef ml_kem_set_params_list
386
static const OSSL_PARAM ml_kem_set_params_list[] = {
387
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ENCODED_PUBLIC_KEY, NULL, 0),
388
    OSSL_PARAM_END
389
};
390
#endif
391
392
#ifndef ml_kem_set_params_st
393
struct ml_kem_set_params_st {
394
    OSSL_PARAM *pub;
395
};
396
#endif
397
398
#ifndef ml_kem_set_params_decoder
399
static int ml_kem_set_params_decoder
400
    (const OSSL_PARAM *p, struct ml_kem_set_params_st *r)
401
0
{
402
0
    const char *s;
403
404
0
    memset(r, 0, sizeof(*r));
405
0
    if (p != NULL)
406
0
        for (; (s = p->key) != NULL; p++)
407
0
            if (ossl_likely(strcmp("encoded-pub-key", s + 0) == 0)) {
408
                /* OSSL_PKEY_PARAM_ENCODED_PUBLIC_KEY */
409
0
                if (ossl_unlikely(r->pub != NULL)) {
410
0
                    ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
411
0
                                   "param %s is repeated", s);
412
0
                    return 0;
413
0
                }
414
0
                r->pub = (OSSL_PARAM *)p;
415
0
            }
416
0
    return 1;
417
0
}
418
#endif
419
/* End of machine generated */
420
421
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
422
#ifndef ml_kem_gen_set_params_list
423
static const OSSL_PARAM ml_kem_gen_set_params_list[] = {
424
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_KEM_SEED, NULL, 0),
425
    OSSL_PARAM_utf8_string(OSSL_PKEY_PARAM_PROPERTIES, NULL, 0),
426
    OSSL_PARAM_END
427
};
428
#endif
429
430
#ifndef ml_kem_gen_set_params_st
431
struct ml_kem_gen_set_params_st {
432
    OSSL_PARAM *propq;
433
    OSSL_PARAM *seed;
434
};
435
#endif
436
437
#ifndef ml_kem_gen_set_params_decoder
438
static int ml_kem_gen_set_params_decoder
439
    (const OSSL_PARAM *p, struct ml_kem_gen_set_params_st *r)
440
0
{
441
0
    const char *s;
442
443
0
    memset(r, 0, sizeof(*r));
444
0
    if (p != NULL)
445
0
        for (; (s = p->key) != NULL; p++)
446
0
            switch(s[0]) {
447
0
            default:
448
0
                break;
449
0
            case 'p':
450
0
                if (ossl_likely(strcmp("roperties", s + 1) == 0)) {
451
                    /* OSSL_PKEY_PARAM_PROPERTIES */
452
0
                    if (ossl_unlikely(r->propq != NULL)) {
453
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
454
0
                                       "param %s is repeated", s);
455
0
                        return 0;
456
0
                    }
457
0
                    r->propq = (OSSL_PARAM *)p;
458
0
                }
459
0
                break;
460
0
            case 's':
461
0
                if (ossl_likely(strcmp("eed", s + 1) == 0)) {
462
                    /* OSSL_PKEY_PARAM_ML_KEM_SEED */
463
0
                    if (ossl_unlikely(r->seed != NULL)) {
464
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
465
0
                                       "param %s is repeated", s);
466
0
                        return 0;
467
0
                    }
468
0
                    r->seed = (OSSL_PARAM *)p;
469
0
                }
470
0
            }
471
0
    return 1;
472
0
}
473
#endif
474
/* End of machine generated */