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_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
#include <string.h>
14
#include <openssl/params.h>
15
#include "internal/common.h"
16
#include "prov/proverr.h"
17
18
#ifndef ml_dsa_import_params_list
19
static const OSSL_PARAM ml_dsa_import_params_list[] = {
20
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_DSA_SEED, NULL, 0),
21
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PUB_KEY, NULL, 0),
22
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PRIV_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_dsa_import_params_st
29
struct ml_dsa_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_dsa_import_params_decoder
38
static int ml_dsa_import_params_decoder
39
    (const OSSL_PARAM *p, struct ml_dsa_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_DSA_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
108
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
109
#include <string.h>
110
#include <openssl/params.h>
111
#include "internal/common.h"
112
#include "prov/proverr.h"
113
114
#ifndef ml_dsa_export_params_list
115
static const OSSL_PARAM ml_dsa_export_params_list[] = {
116
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_DSA_SEED, NULL, 0),
117
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PUB_KEY, NULL, 0),
118
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PRIV_KEY, NULL, 0),
119
    OSSL_PARAM_END
120
};
121
#endif
122
123
#ifndef ml_dsa_export_params_st
124
struct ml_dsa_export_params_st {
125
    OSSL_PARAM *privkey;
126
    OSSL_PARAM *pubkey;
127
    OSSL_PARAM *seed;
128
};
129
#endif
130
131
#ifndef ml_dsa_export_params_decoder
132
static int ml_dsa_export_params_decoder
133
    (const OSSL_PARAM *p, struct ml_dsa_export_params_st *r)
134
{
135
    const char *s;
136
137
    memset(r, 0, sizeof(*r));
138
    if (p != NULL)
139
        for (; (s = p->key) != NULL; p++)
140
            switch(s[0]) {
141
            default:
142
                break;
143
            case 'p':
144
                switch(s[1]) {
145
                default:
146
                    break;
147
                case 'r':
148
                    if (ossl_likely(strcmp("iv", s + 2) == 0)) {
149
                        /* OSSL_PKEY_PARAM_PRIV_KEY */
150
                        if (ossl_unlikely(r->privkey != NULL)) {
151
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
152
                                           "param %s is repeated", s);
153
                            return 0;
154
                        }
155
                        r->privkey = (OSSL_PARAM *)p;
156
                    }
157
                    break;
158
                case 'u':
159
                    if (ossl_likely(strcmp("b", s + 2) == 0)) {
160
                        /* OSSL_PKEY_PARAM_PUB_KEY */
161
                        if (ossl_unlikely(r->pubkey != NULL)) {
162
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
163
                                           "param %s is repeated", s);
164
                            return 0;
165
                        }
166
                        r->pubkey = (OSSL_PARAM *)p;
167
                    }
168
                }
169
                break;
170
            case 's':
171
                if (ossl_likely(strcmp("eed", s + 1) == 0)) {
172
                    /* OSSL_PKEY_PARAM_ML_DSA_SEED */
173
                    if (ossl_unlikely(r->seed != NULL)) {
174
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
175
                                       "param %s is repeated", s);
176
                        return 0;
177
                    }
178
                    r->seed = (OSSL_PARAM *)p;
179
                }
180
            }
181
    return 1;
182
}
183
#endif
184
/* End of machine generated */
185
186
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
187
#include <string.h>
188
#include <openssl/params.h>
189
#include "internal/common.h"
190
#include "prov/proverr.h"
191
192
#ifndef ml_dsa_get_params_list
193
static const OSSL_PARAM ml_dsa_get_params_list[] = {
194
    OSSL_PARAM_int(OSSL_PKEY_PARAM_BITS, NULL),
195
    OSSL_PARAM_int(OSSL_PKEY_PARAM_SECURITY_BITS, NULL),
196
    OSSL_PARAM_int(OSSL_PKEY_PARAM_MAX_SIZE, NULL),
197
    OSSL_PARAM_int(OSSL_PKEY_PARAM_SECURITY_CATEGORY, NULL),
198
    OSSL_PARAM_utf8_string(OSSL_PKEY_PARAM_MANDATORY_DIGEST, NULL, 0),
199
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_DSA_SEED, NULL, 0),
200
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PUB_KEY, NULL, 0),
201
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PRIV_KEY, NULL, 0),
202
    OSSL_PARAM_END
203
};
204
#endif
205
206
#ifndef ml_dsa_get_params_st
207
struct ml_dsa_get_params_st {
208
    OSSL_PARAM *bits;
209
    OSSL_PARAM *dgstp;
210
    OSSL_PARAM *maxsize;
211
    OSSL_PARAM *privkey;
212
    OSSL_PARAM *pubkey;
213
    OSSL_PARAM *secbits;
214
    OSSL_PARAM *seccat;
215
    OSSL_PARAM *seed;
216
};
217
#endif
218
219
#ifndef ml_dsa_get_params_decoder
220
static int ml_dsa_get_params_decoder
221
    (const OSSL_PARAM *p, struct ml_dsa_get_params_st *r)
222
0
{
223
0
    const char *s;
224
225
0
    memset(r, 0, sizeof(*r));
226
0
    if (p != NULL)
227
0
        for (; (s = p->key) != NULL; p++)
228
0
            switch(s[0]) {
229
0
            default:
230
0
                break;
231
0
            case 'b':
232
0
                if (ossl_likely(strcmp("its", s + 1) == 0)) {
233
                    /* OSSL_PKEY_PARAM_BITS */
234
0
                    if (ossl_unlikely(r->bits != 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->bits = (OSSL_PARAM *)p;
240
0
                }
241
0
                break;
242
0
            case 'm':
243
0
                switch(s[1]) {
244
0
                default:
245
0
                    break;
246
0
                case 'a':
247
0
                    switch(s[2]) {
248
0
                    default:
249
0
                        break;
250
0
                    case 'n':
251
0
                        if (ossl_likely(strcmp("datory-digest", s + 3) == 0)) {
252
                            /* OSSL_PKEY_PARAM_MANDATORY_DIGEST */
253
0
                            if (ossl_unlikely(r->dgstp != NULL)) {
254
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
255
0
                                               "param %s is repeated", s);
256
0
                                return 0;
257
0
                            }
258
0
                            r->dgstp = (OSSL_PARAM *)p;
259
0
                        }
260
0
                        break;
261
0
                    case 'x':
262
0
                        if (ossl_likely(strcmp("-size", s + 3) == 0)) {
263
                            /* OSSL_PKEY_PARAM_MAX_SIZE */
264
0
                            if (ossl_unlikely(r->maxsize != NULL)) {
265
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
266
0
                                               "param %s is repeated", s);
267
0
                                return 0;
268
0
                            }
269
0
                            r->maxsize = (OSSL_PARAM *)p;
270
0
                        }
271
0
                    }
272
0
                }
273
0
                break;
274
0
            case 'p':
275
0
                switch(s[1]) {
276
0
                default:
277
0
                    break;
278
0
                case 'r':
279
0
                    if (ossl_likely(strcmp("iv", s + 2) == 0)) {
280
                        /* OSSL_PKEY_PARAM_PRIV_KEY */
281
0
                        if (ossl_unlikely(r->privkey != 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->privkey = (OSSL_PARAM *)p;
287
0
                    }
288
0
                    break;
289
0
                case 'u':
290
0
                    if (ossl_likely(strcmp("b", s + 2) == 0)) {
291
                        /* OSSL_PKEY_PARAM_PUB_KEY */
292
0
                        if (ossl_unlikely(r->pubkey != NULL)) {
293
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
294
0
                                           "param %s is repeated", s);
295
0
                            return 0;
296
0
                        }
297
0
                        r->pubkey = (OSSL_PARAM *)p;
298
0
                    }
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_DSA_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
#include <string.h>
386
#include <openssl/params.h>
387
#include "internal/common.h"
388
#include "prov/proverr.h"
389
390
#ifndef ml_dsa_gen_set_params_list
391
static const OSSL_PARAM ml_dsa_gen_set_params_list[] = {
392
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_DSA_SEED, NULL, 0),
393
    OSSL_PARAM_utf8_string(OSSL_PKEY_PARAM_PROPERTIES, NULL, 0),
394
    OSSL_PARAM_END
395
};
396
#endif
397
398
#ifndef ml_dsa_gen_set_params_st
399
struct ml_dsa_gen_set_params_st {
400
    OSSL_PARAM *propq;
401
    OSSL_PARAM *seed;
402
};
403
#endif
404
405
#ifndef ml_dsa_gen_set_params_decoder
406
static int ml_dsa_gen_set_params_decoder
407
    (const OSSL_PARAM *p, struct ml_dsa_gen_set_params_st *r)
408
0
{
409
0
    const char *s;
410
411
0
    memset(r, 0, sizeof(*r));
412
0
    if (p != NULL)
413
0
        for (; (s = p->key) != NULL; p++)
414
0
            switch(s[0]) {
415
0
            default:
416
0
                break;
417
0
            case 'p':
418
0
                if (ossl_likely(strcmp("roperties", s + 1) == 0)) {
419
                    /* OSSL_PKEY_PARAM_PROPERTIES */
420
0
                    if (ossl_unlikely(r->propq != NULL)) {
421
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
422
0
                                       "param %s is repeated", s);
423
0
                        return 0;
424
0
                    }
425
0
                    r->propq = (OSSL_PARAM *)p;
426
0
                }
427
0
                break;
428
0
            case 's':
429
0
                if (ossl_likely(strcmp("eed", s + 1) == 0)) {
430
                    /* OSSL_PKEY_PARAM_ML_DSA_SEED */
431
0
                    if (ossl_unlikely(r->seed != NULL)) {
432
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
433
0
                                       "param %s is repeated", s);
434
0
                        return 0;
435
0
                    }
436
0
                    r->seed = (OSSL_PARAM *)p;
437
0
                }
438
0
            }
439
0
    return 1;
440
0
}
441
#endif
442
/* End of machine generated */