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_dsa_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_dsa_import_params_list
14
static const OSSL_PARAM ml_dsa_import_params_list[] = {
15
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_DSA_SEED, NULL, 0),
16
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PUB_KEY, NULL, 0),
17
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PRIV_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_dsa_import_params_st
24
struct ml_dsa_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_dsa_import_params_decoder
33
static int ml_dsa_import_params_decoder
34
    (const OSSL_PARAM *p, struct ml_dsa_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_DSA_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
103
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
104
#ifndef ml_dsa_export_params_list
105
static const OSSL_PARAM ml_dsa_export_params_list[] = {
106
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_DSA_SEED, NULL, 0),
107
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PUB_KEY, NULL, 0),
108
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PRIV_KEY, NULL, 0),
109
    OSSL_PARAM_END
110
};
111
#endif
112
113
#ifndef ml_dsa_export_params_st
114
struct ml_dsa_export_params_st {
115
    OSSL_PARAM *privkey;
116
    OSSL_PARAM *pubkey;
117
    OSSL_PARAM *seed;
118
};
119
#endif
120
121
#ifndef ml_dsa_export_params_decoder
122
static int ml_dsa_export_params_decoder
123
    (const OSSL_PARAM *p, struct ml_dsa_export_params_st *r)
124
{
125
    const char *s;
126
127
    memset(r, 0, sizeof(*r));
128
    if (p != NULL)
129
        for (; (s = p->key) != NULL; p++)
130
            switch(s[0]) {
131
            default:
132
                break;
133
            case 'p':
134
                switch(s[1]) {
135
                default:
136
                    break;
137
                case 'r':
138
                    if (ossl_likely(strcmp("iv", s + 2) == 0)) {
139
                        /* OSSL_PKEY_PARAM_PRIV_KEY */
140
                        if (ossl_unlikely(r->privkey != NULL)) {
141
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
142
                                           "param %s is repeated", s);
143
                            return 0;
144
                        }
145
                        r->privkey = (OSSL_PARAM *)p;
146
                    }
147
                    break;
148
                case 'u':
149
                    if (ossl_likely(strcmp("b", s + 2) == 0)) {
150
                        /* OSSL_PKEY_PARAM_PUB_KEY */
151
                        if (ossl_unlikely(r->pubkey != NULL)) {
152
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
153
                                           "param %s is repeated", s);
154
                            return 0;
155
                        }
156
                        r->pubkey = (OSSL_PARAM *)p;
157
                    }
158
                }
159
                break;
160
            case 's':
161
                if (ossl_likely(strcmp("eed", s + 1) == 0)) {
162
                    /* OSSL_PKEY_PARAM_ML_DSA_SEED */
163
                    if (ossl_unlikely(r->seed != NULL)) {
164
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
165
                                       "param %s is repeated", s);
166
                        return 0;
167
                    }
168
                    r->seed = (OSSL_PARAM *)p;
169
                }
170
            }
171
    return 1;
172
}
173
#endif
174
/* End of machine generated */
175
176
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
177
#ifndef ml_dsa_get_params_list
178
static const OSSL_PARAM ml_dsa_get_params_list[] = {
179
    OSSL_PARAM_int(OSSL_PKEY_PARAM_BITS, NULL),
180
    OSSL_PARAM_int(OSSL_PKEY_PARAM_SECURITY_BITS, NULL),
181
    OSSL_PARAM_int(OSSL_PKEY_PARAM_MAX_SIZE, NULL),
182
    OSSL_PARAM_int(OSSL_PKEY_PARAM_SECURITY_CATEGORY, NULL),
183
    OSSL_PARAM_utf8_string(OSSL_PKEY_PARAM_MANDATORY_DIGEST, NULL, 0),
184
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_DSA_SEED, NULL, 0),
185
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PUB_KEY, NULL, 0),
186
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PRIV_KEY, NULL, 0),
187
    OSSL_PARAM_END
188
};
189
#endif
190
191
#ifndef ml_dsa_get_params_st
192
struct ml_dsa_get_params_st {
193
    OSSL_PARAM *bits;
194
    OSSL_PARAM *dgstp;
195
    OSSL_PARAM *maxsize;
196
    OSSL_PARAM *privkey;
197
    OSSL_PARAM *pubkey;
198
    OSSL_PARAM *secbits;
199
    OSSL_PARAM *seccat;
200
    OSSL_PARAM *seed;
201
};
202
#endif
203
204
#ifndef ml_dsa_get_params_decoder
205
static int ml_dsa_get_params_decoder
206
    (const OSSL_PARAM *p, struct ml_dsa_get_params_st *r)
207
0
{
208
0
    const char *s;
209
210
0
    memset(r, 0, sizeof(*r));
211
0
    if (p != NULL)
212
0
        for (; (s = p->key) != NULL; p++)
213
0
            switch(s[0]) {
214
0
            default:
215
0
                break;
216
0
            case 'b':
217
0
                if (ossl_likely(strcmp("its", s + 1) == 0)) {
218
                    /* OSSL_PKEY_PARAM_BITS */
219
0
                    if (ossl_unlikely(r->bits != NULL)) {
220
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
221
0
                                       "param %s is repeated", s);
222
0
                        return 0;
223
0
                    }
224
0
                    r->bits = (OSSL_PARAM *)p;
225
0
                }
226
0
                break;
227
0
            case 'm':
228
0
                switch(s[1]) {
229
0
                default:
230
0
                    break;
231
0
                case 'a':
232
0
                    switch(s[2]) {
233
0
                    default:
234
0
                        break;
235
0
                    case 'n':
236
0
                        if (ossl_likely(strcmp("datory-digest", s + 3) == 0)) {
237
                            /* OSSL_PKEY_PARAM_MANDATORY_DIGEST */
238
0
                            if (ossl_unlikely(r->dgstp != NULL)) {
239
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
240
0
                                               "param %s is repeated", s);
241
0
                                return 0;
242
0
                            }
243
0
                            r->dgstp = (OSSL_PARAM *)p;
244
0
                        }
245
0
                        break;
246
0
                    case 'x':
247
0
                        if (ossl_likely(strcmp("-size", s + 3) == 0)) {
248
                            /* OSSL_PKEY_PARAM_MAX_SIZE */
249
0
                            if (ossl_unlikely(r->maxsize != NULL)) {
250
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
251
0
                                               "param %s is repeated", s);
252
0
                                return 0;
253
0
                            }
254
0
                            r->maxsize = (OSSL_PARAM *)p;
255
0
                        }
256
0
                    }
257
0
                }
258
0
                break;
259
0
            case 'p':
260
0
                switch(s[1]) {
261
0
                default:
262
0
                    break;
263
0
                case 'r':
264
0
                    if (ossl_likely(strcmp("iv", s + 2) == 0)) {
265
                        /* OSSL_PKEY_PARAM_PRIV_KEY */
266
0
                        if (ossl_unlikely(r->privkey != 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->privkey = (OSSL_PARAM *)p;
272
0
                    }
273
0
                    break;
274
0
                case 'u':
275
0
                    if (ossl_likely(strcmp("b", s + 2) == 0)) {
276
                        /* OSSL_PKEY_PARAM_PUB_KEY */
277
0
                        if (ossl_unlikely(r->pubkey != 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->pubkey = (OSSL_PARAM *)p;
283
0
                    }
284
0
                }
285
0
                break;
286
0
            case 's':
287
0
                switch(s[1]) {
288
0
                default:
289
0
                    break;
290
0
                case 'e':
291
0
                    switch(s[2]) {
292
0
                    default:
293
0
                        break;
294
0
                    case 'c':
295
0
                        switch(s[3]) {
296
0
                        default:
297
0
                            break;
298
0
                        case 'u':
299
0
                            switch(s[4]) {
300
0
                            default:
301
0
                                break;
302
0
                            case 'r':
303
0
                                switch(s[5]) {
304
0
                                default:
305
0
                                    break;
306
0
                                case 'i':
307
0
                                    switch(s[6]) {
308
0
                                    default:
309
0
                                        break;
310
0
                                    case 't':
311
0
                                        switch(s[7]) {
312
0
                                        default:
313
0
                                            break;
314
0
                                        case 'y':
315
0
                                            switch(s[8]) {
316
0
                                            default:
317
0
                                                break;
318
0
                                            case '-':
319
0
                                                switch(s[9]) {
320
0
                                                default:
321
0
                                                    break;
322
0
                                                case 'b':
323
0
                                                    if (ossl_likely(strcmp("its", s + 10) == 0)) {
324
                                                        /* OSSL_PKEY_PARAM_SECURITY_BITS */
325
0
                                                        if (ossl_unlikely(r->secbits != NULL)) {
326
0
                                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
327
0
                                                                           "param %s is repeated", s);
328
0
                                                            return 0;
329
0
                                                        }
330
0
                                                        r->secbits = (OSSL_PARAM *)p;
331
0
                                                    }
332
0
                                                    break;
333
0
                                                case 'c':
334
0
                                                    if (ossl_likely(strcmp("ategory", s + 10) == 0)) {
335
                                                        /* OSSL_PKEY_PARAM_SECURITY_CATEGORY */
336
0
                                                        if (ossl_unlikely(r->seccat != NULL)) {
337
0
                                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
338
0
                                                                           "param %s is repeated", s);
339
0
                                                            return 0;
340
0
                                                        }
341
0
                                                        r->seccat = (OSSL_PARAM *)p;
342
0
                                                    }
343
0
                                                }
344
0
                                            }
345
0
                                        }
346
0
                                    }
347
0
                                }
348
0
                            }
349
0
                        }
350
0
                        break;
351
0
                    case 'e':
352
0
                        if (ossl_likely(strcmp("d", s + 3) == 0)) {
353
                            /* OSSL_PKEY_PARAM_ML_DSA_SEED */
354
0
                            if (ossl_unlikely(r->seed != NULL)) {
355
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
356
0
                                               "param %s is repeated", s);
357
0
                                return 0;
358
0
                            }
359
0
                            r->seed = (OSSL_PARAM *)p;
360
0
                        }
361
0
                    }
362
0
                }
363
0
            }
364
0
    return 1;
365
0
}
366
#endif
367
/* End of machine generated */
368
369
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
370
#ifndef ml_dsa_gen_set_params_list
371
static const OSSL_PARAM ml_dsa_gen_set_params_list[] = {
372
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_DSA_SEED, NULL, 0),
373
    OSSL_PARAM_utf8_string(OSSL_PKEY_PARAM_PROPERTIES, NULL, 0),
374
    OSSL_PARAM_END
375
};
376
#endif
377
378
#ifndef ml_dsa_gen_set_params_st
379
struct ml_dsa_gen_set_params_st {
380
    OSSL_PARAM *propq;
381
    OSSL_PARAM *seed;
382
};
383
#endif
384
385
#ifndef ml_dsa_gen_set_params_decoder
386
static int ml_dsa_gen_set_params_decoder
387
    (const OSSL_PARAM *p, struct ml_dsa_gen_set_params_st *r)
388
0
{
389
0
    const char *s;
390
391
0
    memset(r, 0, sizeof(*r));
392
0
    if (p != NULL)
393
0
        for (; (s = p->key) != NULL; p++)
394
0
            switch(s[0]) {
395
0
            default:
396
0
                break;
397
0
            case 'p':
398
0
                if (ossl_likely(strcmp("roperties", s + 1) == 0)) {
399
                    /* OSSL_PKEY_PARAM_PROPERTIES */
400
0
                    if (ossl_unlikely(r->propq != NULL)) {
401
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
402
0
                                       "param %s is repeated", s);
403
0
                        return 0;
404
0
                    }
405
0
                    r->propq = (OSSL_PARAM *)p;
406
0
                }
407
0
                break;
408
0
            case 's':
409
0
                if (ossl_likely(strcmp("eed", s + 1) == 0)) {
410
                    /* OSSL_PKEY_PARAM_ML_DSA_SEED */
411
0
                    if (ossl_unlikely(r->seed != NULL)) {
412
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
413
0
                                       "param %s is repeated", s);
414
0
                        return 0;
415
0
                    }
416
0
                    r->seed = (OSSL_PARAM *)p;
417
0
                }
418
0
            }
419
0
    return 1;
420
0
}
421
#endif
422
/* End of machine generated */