Coverage Report

Created: 2025-12-04 06:33

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_key_type_params_list
14
static const OSSL_PARAM ml_dsa_key_type_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_END
19
};
20
#endif
21
22
#ifndef ml_dsa_key_type_params_st
23
struct ml_dsa_key_type_params_st {
24
    OSSL_PARAM *privkey;
25
    OSSL_PARAM *pubkey;
26
    OSSL_PARAM *seed;
27
};
28
#endif
29
30
#ifndef ml_dsa_key_type_params_decoder
31
static int ml_dsa_key_type_params_decoder
32
    (const OSSL_PARAM *p, struct ml_dsa_key_type_params_st *r)
33
69
{
34
69
    const char *s;
35
36
69
    memset(r, 0, sizeof(*r));
37
69
    if (p != NULL)
38
138
        for (; (s = p->key) != NULL; p++)
39
69
            switch(s[0]) {
40
0
            default:
41
0
                break;
42
69
            case 'p':
43
69
                switch(s[1]) {
44
0
                default:
45
0
                    break;
46
34
                case 'r':
47
34
                    if (ossl_likely(strcmp("iv", s + 2) == 0)) {
48
                        /* OSSL_PKEY_PARAM_PRIV_KEY */
49
34
                        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
34
                        r->privkey = (OSSL_PARAM *)p;
55
34
                    }
56
34
                    break;
57
35
                case 'u':
58
35
                    if (ossl_likely(strcmp("b", s + 2) == 0)) {
59
                        /* OSSL_PKEY_PARAM_PUB_KEY */
60
35
                        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
35
                        r->pubkey = (OSSL_PARAM *)p;
66
35
                    }
67
69
                }
68
69
                break;
69
69
            case 's':
70
0
                if (ossl_likely(strcmp("eed", s + 1) == 0)) {
71
                    /* OSSL_PKEY_PARAM_ML_DSA_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
69
            }
80
69
    return 1;
81
69
}
82
#endif
83
/* End of machine generated */
84
85
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
86
#ifndef ml_dsa_get_params_list
87
static const OSSL_PARAM ml_dsa_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_utf8_string(OSSL_PKEY_PARAM_MANDATORY_DIGEST, NULL, 0),
93
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_DSA_SEED, NULL, 0),
94
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PUB_KEY, NULL, 0),
95
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_PRIV_KEY, NULL, 0),
96
    OSSL_PARAM_END
97
};
98
#endif
99
100
#ifndef ml_dsa_get_params_st
101
struct ml_dsa_get_params_st {
102
    OSSL_PARAM *bits;
103
    OSSL_PARAM *dgstp;
104
    OSSL_PARAM *maxsize;
105
    OSSL_PARAM *privkey;
106
    OSSL_PARAM *pubkey;
107
    OSSL_PARAM *secbits;
108
    OSSL_PARAM *seccat;
109
    OSSL_PARAM *seed;
110
};
111
#endif
112
113
#ifndef ml_dsa_get_params_decoder
114
static int ml_dsa_get_params_decoder
115
    (const OSSL_PARAM *p, struct ml_dsa_get_params_st *r)
116
1.39k
{
117
1.39k
    const char *s;
118
119
1.39k
    memset(r, 0, sizeof(*r));
120
1.39k
    if (p != NULL)
121
6.37k
        for (; (s = p->key) != NULL; p++)
122
4.97k
            switch(s[0]) {
123
312
            default:
124
312
                break;
125
1.08k
            case 'b':
126
1.08k
                if (ossl_likely(strcmp("its", s + 1) == 0)) {
127
                    /* OSSL_PKEY_PARAM_BITS */
128
1.08k
                    if (ossl_unlikely(r->bits != NULL)) {
129
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
130
0
                                       "param %s is repeated", s);
131
0
                        return 0;
132
0
                    }
133
1.08k
                    r->bits = (OSSL_PARAM *)p;
134
1.08k
                }
135
1.08k
                break;
136
1.39k
            case 'm':
137
1.39k
                switch(s[1]) {
138
0
                default:
139
0
                    break;
140
1.39k
                case 'a':
141
1.39k
                    switch(s[2]) {
142
0
                    default:
143
0
                        break;
144
312
                    case 'n':
145
312
                        if (ossl_likely(strcmp("datory-digest", s + 3) == 0)) {
146
                            /* OSSL_PKEY_PARAM_MANDATORY_DIGEST */
147
312
                            if (ossl_unlikely(r->dgstp != NULL)) {
148
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
149
0
                                               "param %s is repeated", s);
150
0
                                return 0;
151
0
                            }
152
312
                            r->dgstp = (OSSL_PARAM *)p;
153
312
                        }
154
312
                        break;
155
1.08k
                    case 'x':
156
1.08k
                        if (ossl_likely(strcmp("-size", s + 3) == 0)) {
157
                            /* OSSL_PKEY_PARAM_MAX_SIZE */
158
1.08k
                            if (ossl_unlikely(r->maxsize != NULL)) {
159
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
160
0
                                               "param %s is repeated", s);
161
0
                                return 0;
162
0
                            }
163
1.08k
                            r->maxsize = (OSSL_PARAM *)p;
164
1.08k
                        }
165
1.39k
                    }
166
1.39k
                }
167
1.39k
                break;
168
1.39k
            case 'p':
169
0
                switch(s[1]) {
170
0
                default:
171
0
                    break;
172
0
                case 'r':
173
0
                    if (ossl_likely(strcmp("iv", s + 2) == 0)) {
174
                        /* OSSL_PKEY_PARAM_PRIV_KEY */
175
0
                        if (ossl_unlikely(r->privkey != NULL)) {
176
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
177
0
                                           "param %s is repeated", s);
178
0
                            return 0;
179
0
                        }
180
0
                        r->privkey = (OSSL_PARAM *)p;
181
0
                    }
182
0
                    break;
183
0
                case 'u':
184
0
                    if (ossl_likely(strcmp("b", s + 2) == 0)) {
185
                        /* OSSL_PKEY_PARAM_PUB_KEY */
186
0
                        if (ossl_unlikely(r->pubkey != NULL)) {
187
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
188
0
                                           "param %s is repeated", s);
189
0
                            return 0;
190
0
                        }
191
0
                        r->pubkey = (OSSL_PARAM *)p;
192
0
                    }
193
0
                }
194
0
                break;
195
2.17k
            case 's':
196
2.17k
                switch(s[1]) {
197
0
                default:
198
0
                    break;
199
2.17k
                case 'e':
200
2.17k
                    switch(s[2]) {
201
0
                    default:
202
0
                        break;
203
2.17k
                    case 'c':
204
2.17k
                        switch(s[3]) {
205
0
                        default:
206
0
                            break;
207
2.17k
                        case 'u':
208
2.17k
                            switch(s[4]) {
209
0
                            default:
210
0
                                break;
211
2.17k
                            case 'r':
212
2.17k
                                switch(s[5]) {
213
0
                                default:
214
0
                                    break;
215
2.17k
                                case 'i':
216
2.17k
                                    switch(s[6]) {
217
0
                                    default:
218
0
                                        break;
219
2.17k
                                    case 't':
220
2.17k
                                        switch(s[7]) {
221
0
                                        default:
222
0
                                            break;
223
2.17k
                                        case 'y':
224
2.17k
                                            switch(s[8]) {
225
0
                                            default:
226
0
                                                break;
227
2.17k
                                            case '-':
228
2.17k
                                                switch(s[9]) {
229
0
                                                default:
230
0
                                                    break;
231
1.08k
                                                case 'b':
232
1.08k
                                                    if (ossl_likely(strcmp("its", s + 10) == 0)) {
233
                                                        /* OSSL_PKEY_PARAM_SECURITY_BITS */
234
1.08k
                                                        if (ossl_unlikely(r->secbits != 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
1.08k
                                                        r->secbits = (OSSL_PARAM *)p;
240
1.08k
                                                    }
241
1.08k
                                                    break;
242
1.08k
                                                case 'c':
243
1.08k
                                                    if (ossl_likely(strcmp("ategory", s + 10) == 0)) {
244
                                                        /* OSSL_PKEY_PARAM_SECURITY_CATEGORY */
245
1.08k
                                                        if (ossl_unlikely(r->seccat != NULL)) {
246
0
                                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
247
0
                                                                           "param %s is repeated", s);
248
0
                                                            return 0;
249
0
                                                        }
250
1.08k
                                                        r->seccat = (OSSL_PARAM *)p;
251
1.08k
                                                    }
252
2.17k
                                                }
253
2.17k
                                            }
254
2.17k
                                        }
255
2.17k
                                    }
256
2.17k
                                }
257
2.17k
                            }
258
2.17k
                        }
259
2.17k
                        break;
260
2.17k
                    case 'e':
261
0
                        if (ossl_likely(strcmp("d", s + 3) == 0)) {
262
                            /* OSSL_PKEY_PARAM_ML_DSA_SEED */
263
0
                            if (ossl_unlikely(r->seed != NULL)) {
264
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
265
0
                                               "param %s is repeated", s);
266
0
                                return 0;
267
0
                            }
268
0
                            r->seed = (OSSL_PARAM *)p;
269
0
                        }
270
2.17k
                    }
271
2.17k
                }
272
4.97k
            }
273
1.39k
    return 1;
274
1.39k
}
275
#endif
276
/* End of machine generated */
277
278
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
279
#ifndef ml_dsa_gen_set_params_list
280
static const OSSL_PARAM ml_dsa_gen_set_params_list[] = {
281
    OSSL_PARAM_octet_string(OSSL_PKEY_PARAM_ML_DSA_SEED, NULL, 0),
282
    OSSL_PARAM_utf8_string(OSSL_PKEY_PARAM_PROPERTIES, NULL, 0),
283
    OSSL_PARAM_END
284
};
285
#endif
286
287
#ifndef ml_dsa_gen_set_params_st
288
struct ml_dsa_gen_set_params_st {
289
    OSSL_PARAM *propq;
290
    OSSL_PARAM *seed;
291
};
292
#endif
293
294
#ifndef ml_dsa_gen_set_params_decoder
295
static int ml_dsa_gen_set_params_decoder
296
    (const OSSL_PARAM *p, struct ml_dsa_gen_set_params_st *r)
297
966
{
298
966
    const char *s;
299
300
966
    memset(r, 0, sizeof(*r));
301
966
    if (p != NULL)
302
0
        for (; (s = p->key) != NULL; p++)
303
0
            switch(s[0]) {
304
0
            default:
305
0
                break;
306
0
            case 'p':
307
0
                if (ossl_likely(strcmp("roperties", s + 1) == 0)) {
308
                    /* OSSL_PKEY_PARAM_PROPERTIES */
309
0
                    if (ossl_unlikely(r->propq != NULL)) {
310
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
311
0
                                       "param %s is repeated", s);
312
0
                        return 0;
313
0
                    }
314
0
                    r->propq = (OSSL_PARAM *)p;
315
0
                }
316
0
                break;
317
0
            case 's':
318
0
                if (ossl_likely(strcmp("eed", s + 1) == 0)) {
319
                    /* OSSL_PKEY_PARAM_ML_DSA_SEED */
320
0
                    if (ossl_unlikely(r->seed != NULL)) {
321
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
322
0
                                       "param %s is repeated", s);
323
0
                        return 0;
324
0
                    }
325
0
                    r->seed = (OSSL_PARAM *)p;
326
0
                }
327
0
            }
328
966
    return 1;
329
966
}
330
#endif
331
/* End of machine generated */