Coverage Report

Created: 2026-05-30 06:06

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