Coverage Report

Created: 2025-11-11 06:20

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_key_type_params_list
14
static const OSSL_PARAM ml_kem_key_type_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_END
19
};
20
#endif
21
22
#ifndef ml_kem_key_type_params_st
23
struct ml_kem_key_type_params_st {
24
    OSSL_PARAM *privkey;
25
    OSSL_PARAM *pubkey;
26
    OSSL_PARAM *seed;
27
};
28
#endif
29
30
#ifndef ml_kem_key_type_params_decoder
31
static int ml_kem_key_type_params_decoder
32
    (const OSSL_PARAM *p, struct ml_kem_key_type_params_st *r)
33
0
{
34
0
    const char *s;
35
36
0
    memset(r, 0, sizeof(*r));
37
0
    if (p != NULL)
38
0
        for (; (s = p->key) != NULL; p++)
39
0
            switch(s[0]) {
40
0
            default:
41
0
                break;
42
0
            case 'p':
43
0
                switch(s[1]) {
44
0
                default:
45
0
                    break;
46
0
                case 'r':
47
0
                    if (ossl_likely(strcmp("iv", s + 2) == 0)) {
48
                        /* OSSL_PKEY_PARAM_PRIV_KEY */
49
0
                        if (ossl_unlikely(r->privkey != NULL)) {
50
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
51
0
                                           "param %s is repeated", s);
52
0
                            return 0;
53
0
                        }
54
0
                        r->privkey = (OSSL_PARAM *)p;
55
0
                    }
56
0
                    break;
57
0
                case 'u':
58
0
                    if (ossl_likely(strcmp("b", s + 2) == 0)) {
59
                        /* OSSL_PKEY_PARAM_PUB_KEY */
60
0
                        if (ossl_unlikely(r->pubkey != 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->pubkey = (OSSL_PARAM *)p;
66
0
                    }
67
0
                }
68
0
                break;
69
0
            case 's':
70
0
                if (ossl_likely(strcmp("eed", s + 1) == 0)) {
71
                    /* OSSL_PKEY_PARAM_ML_KEM_SEED */
72
0
                    if (ossl_unlikely(r->seed != 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->seed = (OSSL_PARAM *)p;
78
0
                }
79
0
            }
80
0
    return 1;
81
0
}
82
#endif
83
/* End of machine generated */
84
85
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
86
#ifndef ml_kem_get_params_list
87
static const OSSL_PARAM ml_kem_get_params_list[] = {
88
    OSSL_PARAM_int(OSSL_PKEY_PARAM_BITS, NULL),
89
    OSSL_PARAM_int(OSSL_PKEY_PARAM_SECURITY_BITS, NULL),
90
    OSSL_PARAM_int(OSSL_PKEY_PARAM_MAX_SIZE, NULL),
91
    OSSL_PARAM_int(OSSL_PKEY_PARAM_SECURITY_CATEGORY, NULL),
92
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_KEM_SEED, NULL, 0),
93
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PRIV_KEY, NULL, 0),
94
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PUB_KEY, NULL, 0),
95
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ENCODED_PUBLIC_KEY, NULL, 0),
96
    OSSL_PARAM_int(OSSL_PKEY_PARAM_CMS_RI_TYPE, NULL),
97
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_CMS_KEMRI_KDF_ALGORITHM, NULL, 0),
98
    OSSL_PARAM_END
99
};
100
#endif
101
102
#ifndef ml_kem_get_params_st
103
struct ml_kem_get_params_st {
104
    OSSL_PARAM *bits;
105
    OSSL_PARAM *encpubkey;
106
    OSSL_PARAM *kemri_kdf_alg;
107
    OSSL_PARAM *maxsize;
108
    OSSL_PARAM *privkey;
109
    OSSL_PARAM *pubkey;
110
    OSSL_PARAM *ri_type;
111
    OSSL_PARAM *secbits;
112
    OSSL_PARAM *seccat;
113
    OSSL_PARAM *seed;
114
};
115
#endif
116
117
#ifndef ml_kem_get_params_decoder
118
static int ml_kem_get_params_decoder
119
    (const OSSL_PARAM *p, struct ml_kem_get_params_st *r)
120
0
{
121
0
    const char *s;
122
123
0
    memset(r, 0, sizeof(*r));
124
0
    if (p != NULL)
125
0
        for (; (s = p->key) != NULL; p++)
126
0
            switch(s[0]) {
127
0
            default:
128
0
                break;
129
0
            case 'b':
130
0
                if (ossl_likely(strcmp("its", s + 1) == 0)) {
131
                    /* OSSL_PKEY_PARAM_BITS */
132
0
                    if (ossl_unlikely(r->bits != NULL)) {
133
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
134
0
                                       "param %s is repeated", s);
135
0
                        return 0;
136
0
                    }
137
0
                    r->bits = (OSSL_PARAM *)p;
138
0
                }
139
0
                break;
140
0
            case 'e':
141
0
                if (ossl_likely(strcmp("ncoded-pub-key", s + 1) == 0)) {
142
                    /* OSSL_PKEY_PARAM_ENCODED_PUBLIC_KEY */
143
0
                    if (ossl_unlikely(r->encpubkey != NULL)) {
144
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
145
0
                                       "param %s is repeated", s);
146
0
                        return 0;
147
0
                    }
148
0
                    r->encpubkey = (OSSL_PARAM *)p;
149
0
                }
150
0
                break;
151
0
            case 'k':
152
0
                if (ossl_likely(strcmp("emri-kdf-alg", s + 1) == 0)) {
153
                    /* OSSL_PKEY_PARAM_CMS_KEMRI_KDF_ALGORITHM */
154
0
                    if (ossl_unlikely(r->kemri_kdf_alg != NULL)) {
155
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
156
0
                                       "param %s is repeated", s);
157
0
                        return 0;
158
0
                    }
159
0
                    r->kemri_kdf_alg = (OSSL_PARAM *)p;
160
0
                }
161
0
                break;
162
0
            case 'm':
163
0
                if (ossl_likely(strcmp("ax-size", s + 1) == 0)) {
164
                    /* OSSL_PKEY_PARAM_MAX_SIZE */
165
0
                    if (ossl_unlikely(r->maxsize != NULL)) {
166
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
167
0
                                       "param %s is repeated", s);
168
0
                        return 0;
169
0
                    }
170
0
                    r->maxsize = (OSSL_PARAM *)p;
171
0
                }
172
0
                break;
173
0
            case 'p':
174
0
                switch(s[1]) {
175
0
                default:
176
0
                    break;
177
0
                case 'r':
178
0
                    if (ossl_likely(strcmp("iv", s + 2) == 0)) {
179
                        /* OSSL_PKEY_PARAM_PRIV_KEY */
180
0
                        if (ossl_unlikely(r->privkey != NULL)) {
181
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
182
0
                                           "param %s is repeated", s);
183
0
                            return 0;
184
0
                        }
185
0
                        r->privkey = (OSSL_PARAM *)p;
186
0
                    }
187
0
                    break;
188
0
                case 'u':
189
0
                    if (ossl_likely(strcmp("b", s + 2) == 0)) {
190
                        /* OSSL_PKEY_PARAM_PUB_KEY */
191
0
                        if (ossl_unlikely(r->pubkey != NULL)) {
192
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
193
0
                                           "param %s is repeated", s);
194
0
                            return 0;
195
0
                        }
196
0
                        r->pubkey = (OSSL_PARAM *)p;
197
0
                    }
198
0
                }
199
0
                break;
200
0
            case 'r':
201
0
                if (ossl_likely(strcmp("i-type", s + 1) == 0)) {
202
                    /* OSSL_PKEY_PARAM_CMS_RI_TYPE */
203
0
                    if (ossl_unlikely(r->ri_type != 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->ri_type = (OSSL_PARAM *)p;
209
0
                }
210
0
                break;
211
0
            case 's':
212
0
                switch(s[1]) {
213
0
                default:
214
0
                    break;
215
0
                case 'e':
216
0
                    switch(s[2]) {
217
0
                    default:
218
0
                        break;
219
0
                    case 'c':
220
0
                        switch(s[3]) {
221
0
                        default:
222
0
                            break;
223
0
                        case 'u':
224
0
                            switch(s[4]) {
225
0
                            default:
226
0
                                break;
227
0
                            case 'r':
228
0
                                switch(s[5]) {
229
0
                                default:
230
0
                                    break;
231
0
                                case 'i':
232
0
                                    switch(s[6]) {
233
0
                                    default:
234
0
                                        break;
235
0
                                    case 't':
236
0
                                        switch(s[7]) {
237
0
                                        default:
238
0
                                            break;
239
0
                                        case 'y':
240
0
                                            switch(s[8]) {
241
0
                                            default:
242
0
                                                break;
243
0
                                            case '-':
244
0
                                                switch(s[9]) {
245
0
                                                default:
246
0
                                                    break;
247
0
                                                case 'b':
248
0
                                                    if (ossl_likely(strcmp("its", s + 10) == 0)) {
249
                                                        /* OSSL_PKEY_PARAM_SECURITY_BITS */
250
0
                                                        if (ossl_unlikely(r->secbits != NULL)) {
251
0
                                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
252
0
                                                                           "param %s is repeated", s);
253
0
                                                            return 0;
254
0
                                                        }
255
0
                                                        r->secbits = (OSSL_PARAM *)p;
256
0
                                                    }
257
0
                                                    break;
258
0
                                                case 'c':
259
0
                                                    if (ossl_likely(strcmp("ategory", s + 10) == 0)) {
260
                                                        /* OSSL_PKEY_PARAM_SECURITY_CATEGORY */
261
0
                                                        if (ossl_unlikely(r->seccat != NULL)) {
262
0
                                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
263
0
                                                                           "param %s is repeated", s);
264
0
                                                            return 0;
265
0
                                                        }
266
0
                                                        r->seccat = (OSSL_PARAM *)p;
267
0
                                                    }
268
0
                                                }
269
0
                                            }
270
0
                                        }
271
0
                                    }
272
0
                                }
273
0
                            }
274
0
                        }
275
0
                        break;
276
0
                    case 'e':
277
0
                        if (ossl_likely(strcmp("d", s + 3) == 0)) {
278
                            /* OSSL_PKEY_PARAM_ML_KEM_SEED */
279
0
                            if (ossl_unlikely(r->seed != NULL)) {
280
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
281
0
                                               "param %s is repeated", s);
282
0
                                return 0;
283
0
                            }
284
0
                            r->seed = (OSSL_PARAM *)p;
285
0
                        }
286
0
                    }
287
0
                }
288
0
            }
289
0
    return 1;
290
0
}
291
#endif
292
/* End of machine generated */
293
294
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
295
#ifndef ml_kem_set_params_list
296
static const OSSL_PARAM ml_kem_set_params_list[] = {
297
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ENCODED_PUBLIC_KEY, NULL, 0),
298
    OSSL_PARAM_END
299
};
300
#endif
301
302
#ifndef ml_kem_set_params_st
303
struct ml_kem_set_params_st {
304
    OSSL_PARAM *pub;
305
};
306
#endif
307
308
#ifndef ml_kem_set_params_decoder
309
static int ml_kem_set_params_decoder
310
    (const OSSL_PARAM *p, struct ml_kem_set_params_st *r)
311
0
{
312
0
    const char *s;
313
314
0
    memset(r, 0, sizeof(*r));
315
0
    if (p != NULL)
316
0
        for (; (s = p->key) != NULL; p++)
317
0
            if (ossl_likely(strcmp("encoded-pub-key", s + 0) == 0)) {
318
                /* OSSL_PKEY_PARAM_ENCODED_PUBLIC_KEY */
319
0
                if (ossl_unlikely(r->pub != NULL)) {
320
0
                    ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
321
0
                                   "param %s is repeated", s);
322
0
                    return 0;
323
0
                }
324
0
                r->pub = (OSSL_PARAM *)p;
325
0
            }
326
0
    return 1;
327
0
}
328
#endif
329
/* End of machine generated */
330
331
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
332
#ifndef ml_kem_gen_set_params_list
333
static const OSSL_PARAM ml_kem_gen_set_params_list[] = {
334
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_DSA_SEED, NULL, 0),
335
    OSSL_PARAM_utf8_string(OSSL_PKEY_PARAM_PROPERTIES, NULL, 0),
336
    OSSL_PARAM_END
337
};
338
#endif
339
340
#ifndef ml_kem_gen_set_params_st
341
struct ml_kem_gen_set_params_st {
342
    OSSL_PARAM *propq;
343
    OSSL_PARAM *seed;
344
};
345
#endif
346
347
#ifndef ml_kem_gen_set_params_decoder
348
static int ml_kem_gen_set_params_decoder
349
    (const OSSL_PARAM *p, struct ml_kem_gen_set_params_st *r)
350
0
{
351
0
    const char *s;
352
353
0
    memset(r, 0, sizeof(*r));
354
0
    if (p != NULL)
355
0
        for (; (s = p->key) != NULL; p++)
356
0
            switch(s[0]) {
357
0
            default:
358
0
                break;
359
0
            case 'p':
360
0
                if (ossl_likely(strcmp("roperties", s + 1) == 0)) {
361
                    /* OSSL_PKEY_PARAM_PROPERTIES */
362
0
                    if (ossl_unlikely(r->propq != NULL)) {
363
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
364
0
                                       "param %s is repeated", s);
365
0
                        return 0;
366
0
                    }
367
0
                    r->propq = (OSSL_PARAM *)p;
368
0
                }
369
0
                break;
370
0
            case 's':
371
0
                if (ossl_likely(strcmp("eed", s + 1) == 0)) {
372
                    /* OSSL_PKEY_PARAM_ML_DSA_SEED */
373
0
                    if (ossl_unlikely(r->seed != NULL)) {
374
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
375
0
                                       "param %s is repeated", s);
376
0
                        return 0;
377
0
                    }
378
0
                    r->seed = (OSSL_PARAM *)p;
379
0
                }
380
0
            }
381
0
    return 1;
382
0
}
383
#endif
384
/* End of machine generated */