Coverage Report

Created: 2026-05-20 07:05

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl/providers/implementations/rands/drbg_ctr.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 drbg_ctr_get_ctx_params_list
19
static const OSSL_PARAM drbg_ctr_get_ctx_params_list[] = {
20
    OSSL_PARAM_utf8_string(OSSL_DRBG_PARAM_CIPHER, NULL, 0),
21
    OSSL_PARAM_int(OSSL_DRBG_PARAM_USE_DF, NULL),
22
    OSSL_PARAM_int(OSSL_RAND_PARAM_STATE, NULL),
23
    OSSL_PARAM_uint(OSSL_RAND_PARAM_STRENGTH, NULL),
24
    OSSL_PARAM_size_t(OSSL_RAND_PARAM_MAX_REQUEST, NULL),
25
    OSSL_PARAM_size_t(OSSL_DRBG_PARAM_MIN_ENTROPYLEN, NULL),
26
    OSSL_PARAM_size_t(OSSL_DRBG_PARAM_MAX_ENTROPYLEN, NULL),
27
    OSSL_PARAM_size_t(OSSL_DRBG_PARAM_MIN_NONCELEN, NULL),
28
    OSSL_PARAM_size_t(OSSL_DRBG_PARAM_MAX_NONCELEN, NULL),
29
    OSSL_PARAM_size_t(OSSL_DRBG_PARAM_MAX_PERSLEN, NULL),
30
    OSSL_PARAM_size_t(OSSL_DRBG_PARAM_MAX_ADINLEN, NULL),
31
    OSSL_PARAM_uint(OSSL_DRBG_PARAM_RESEED_COUNTER, NULL),
32
    OSSL_PARAM_time_t(OSSL_DRBG_PARAM_RESEED_TIME, NULL),
33
    OSSL_PARAM_uint(OSSL_DRBG_PARAM_RESEED_REQUESTS, NULL),
34
    OSSL_PARAM_uint64(OSSL_DRBG_PARAM_RESEED_TIME_INTERVAL, NULL),
35
# if defined(FIPS_MODULE)
36
    OSSL_PARAM_int(OSSL_KDF_PARAM_FIPS_APPROVED_INDICATOR, NULL),
37
# endif
38
    OSSL_PARAM_END
39
};
40
#endif
41
42
#ifndef drbg_ctr_get_ctx_params_st
43
struct drbg_ctr_get_ctx_params_st {
44
    OSSL_PARAM *cipher;
45
    OSSL_PARAM *df;
46
# if defined(FIPS_MODULE)
47
    OSSL_PARAM *ind;
48
# endif
49
    OSSL_PARAM *maxadlen;
50
    OSSL_PARAM *maxentlen;
51
    OSSL_PARAM *maxnonlen;
52
    OSSL_PARAM *maxperlen;
53
    OSSL_PARAM *maxreq;
54
    OSSL_PARAM *minentlen;
55
    OSSL_PARAM *minnonlen;
56
    OSSL_PARAM *reseed_cnt;
57
    OSSL_PARAM *reseed_int;
58
    OSSL_PARAM *reseed_req;
59
    OSSL_PARAM *reseed_time;
60
    OSSL_PARAM *state;
61
    OSSL_PARAM *str;
62
};
63
#endif
64
65
#ifndef drbg_ctr_get_ctx_params_decoder
66
static int drbg_ctr_get_ctx_params_decoder
67
    (const OSSL_PARAM *p, struct drbg_ctr_get_ctx_params_st *r)
68
144
{
69
144
    const char *s;
70
71
144
    memset(r, 0, sizeof(*r));
72
144
    if (p != NULL)
73
288
        for (; (s = p->key) != NULL; p++)
74
144
            switch(s[0]) {
75
0
            default:
76
0
                break;
77
0
            case 'c':
78
0
                if (ossl_likely(strcmp("ipher", s + 1) == 0)) {
79
                    /* OSSL_DRBG_PARAM_CIPHER */
80
0
                    if (ossl_unlikely(r->cipher != NULL)) {
81
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
82
0
                                       "param %s is repeated", s);
83
0
                        return 0;
84
0
                    }
85
0
                    r->cipher = (OSSL_PARAM *)p;
86
0
                }
87
0
                break;
88
0
            case 'f':
89
# if defined(FIPS_MODULE)
90
                if (ossl_likely(strcmp("ips-indicator", s + 1) == 0)) {
91
                    /* OSSL_KDF_PARAM_FIPS_APPROVED_INDICATOR */
92
                    if (ossl_unlikely(r->ind != NULL)) {
93
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
94
                                       "param %s is repeated", s);
95
                        return 0;
96
                    }
97
                    r->ind = (OSSL_PARAM *)p;
98
                }
99
# endif
100
0
                break;
101
32
            case 'm':
102
32
                switch(s[1]) {
103
0
                default:
104
0
                    break;
105
32
                case 'a':
106
32
                    switch(s[2]) {
107
0
                    default:
108
0
                        break;
109
32
                    case 'x':
110
32
                        switch(s[3]) {
111
0
                        default:
112
0
                            break;
113
32
                        case '_':
114
32
                            switch(s[4]) {
115
0
                            default:
116
0
                                break;
117
0
                            case 'a':
118
0
                                if (ossl_likely(strcmp("dinlen", s + 5) == 0)) {
119
                                    /* OSSL_DRBG_PARAM_MAX_ADINLEN */
120
0
                                    if (ossl_unlikely(r->maxadlen != NULL)) {
121
0
                                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
122
0
                                                       "param %s is repeated", s);
123
0
                                        return 0;
124
0
                                    }
125
0
                                    r->maxadlen = (OSSL_PARAM *)p;
126
0
                                }
127
0
                                break;
128
0
                            case 'e':
129
0
                                if (ossl_likely(strcmp("ntropylen", s + 5) == 0)) {
130
                                    /* OSSL_DRBG_PARAM_MAX_ENTROPYLEN */
131
0
                                    if (ossl_unlikely(r->maxentlen != NULL)) {
132
0
                                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
133
0
                                                       "param %s is repeated", s);
134
0
                                        return 0;
135
0
                                    }
136
0
                                    r->maxentlen = (OSSL_PARAM *)p;
137
0
                                }
138
0
                                break;
139
0
                            case 'n':
140
0
                                if (ossl_likely(strcmp("oncelen", s + 5) == 0)) {
141
                                    /* OSSL_DRBG_PARAM_MAX_NONCELEN */
142
0
                                    if (ossl_unlikely(r->maxnonlen != NULL)) {
143
0
                                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
144
0
                                                       "param %s is repeated", s);
145
0
                                        return 0;
146
0
                                    }
147
0
                                    r->maxnonlen = (OSSL_PARAM *)p;
148
0
                                }
149
0
                                break;
150
0
                            case 'p':
151
0
                                if (ossl_likely(strcmp("erslen", s + 5) == 0)) {
152
                                    /* OSSL_DRBG_PARAM_MAX_PERSLEN */
153
0
                                    if (ossl_unlikely(r->maxperlen != NULL)) {
154
0
                                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
155
0
                                                       "param %s is repeated", s);
156
0
                                        return 0;
157
0
                                    }
158
0
                                    r->maxperlen = (OSSL_PARAM *)p;
159
0
                                }
160
0
                                break;
161
32
                            case 'r':
162
32
                                if (ossl_likely(strcmp("equest", s + 5) == 0)) {
163
                                    /* OSSL_RAND_PARAM_MAX_REQUEST */
164
32
                                    if (ossl_unlikely(r->maxreq != NULL)) {
165
0
                                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
166
0
                                                       "param %s is repeated", s);
167
0
                                        return 0;
168
0
                                    }
169
32
                                    r->maxreq = (OSSL_PARAM *)p;
170
32
                                }
171
32
                            }
172
32
                        }
173
32
                    }
174
32
                    break;
175
32
                case 'i':
176
0
                    switch(s[2]) {
177
0
                    default:
178
0
                        break;
179
0
                    case 'n':
180
0
                        switch(s[3]) {
181
0
                        default:
182
0
                            break;
183
0
                        case '_':
184
0
                            switch(s[4]) {
185
0
                            default:
186
0
                                break;
187
0
                            case 'e':
188
0
                                if (ossl_likely(strcmp("ntropylen", s + 5) == 0)) {
189
                                    /* OSSL_DRBG_PARAM_MIN_ENTROPYLEN */
190
0
                                    if (ossl_unlikely(r->minentlen != NULL)) {
191
0
                                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
192
0
                                                       "param %s is repeated", s);
193
0
                                        return 0;
194
0
                                    }
195
0
                                    r->minentlen = (OSSL_PARAM *)p;
196
0
                                }
197
0
                                break;
198
0
                            case 'n':
199
0
                                if (ossl_likely(strcmp("oncelen", s + 5) == 0)) {
200
                                    /* OSSL_DRBG_PARAM_MIN_NONCELEN */
201
0
                                    if (ossl_unlikely(r->minnonlen != NULL)) {
202
0
                                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
203
0
                                                       "param %s is repeated", s);
204
0
                                        return 0;
205
0
                                    }
206
0
                                    r->minnonlen = (OSSL_PARAM *)p;
207
0
                                }
208
0
                            }
209
0
                        }
210
0
                    }
211
32
                }
212
32
                break;
213
48
            case 'r':
214
48
                switch(s[1]) {
215
0
                default:
216
0
                    break;
217
48
                case 'e':
218
48
                    switch(s[2]) {
219
0
                    default:
220
0
                        break;
221
48
                    case 's':
222
48
                        switch(s[3]) {
223
0
                        default:
224
0
                            break;
225
48
                        case 'e':
226
48
                            switch(s[4]) {
227
0
                            default:
228
0
                                break;
229
48
                            case 'e':
230
48
                                switch(s[5]) {
231
0
                                default:
232
0
                                    break;
233
48
                                case 'd':
234
48
                                    switch(s[6]) {
235
0
                                    default:
236
0
                                        break;
237
48
                                    case '_':
238
48
                                        switch(s[7]) {
239
0
                                        default:
240
0
                                            break;
241
48
                                        case 'c':
242
48
                                            if (ossl_likely(strcmp("ounter", s + 8) == 0)) {
243
                                                /* OSSL_DRBG_PARAM_RESEED_COUNTER */
244
48
                                                if (ossl_unlikely(r->reseed_cnt != NULL)) {
245
0
                                                    ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
246
0
                                                                   "param %s is repeated", s);
247
0
                                                    return 0;
248
0
                                                }
249
48
                                                r->reseed_cnt = (OSSL_PARAM *)p;
250
48
                                            }
251
48
                                            break;
252
48
                                        case 'r':
253
0
                                            if (ossl_likely(strcmp("equests", s + 8) == 0)) {
254
                                                /* OSSL_DRBG_PARAM_RESEED_REQUESTS */
255
0
                                                if (ossl_unlikely(r->reseed_req != NULL)) {
256
0
                                                    ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
257
0
                                                                   "param %s is repeated", s);
258
0
                                                    return 0;
259
0
                                                }
260
0
                                                r->reseed_req = (OSSL_PARAM *)p;
261
0
                                            }
262
0
                                            break;
263
0
                                        case 't':
264
0
                                            switch(s[8]) {
265
0
                                            default:
266
0
                                                break;
267
0
                                            case 'i':
268
0
                                                switch(s[9]) {
269
0
                                                default:
270
0
                                                    break;
271
0
                                                case 'm':
272
0
                                                    switch(s[10]) {
273
0
                                                    default:
274
0
                                                        break;
275
0
                                                    case 'e':
276
0
                                                        switch(s[11]) {
277
0
                                                        default:
278
0
                                                            break;
279
0
                                                        case '_':
280
0
                                                            if (ossl_likely(strcmp("interval", s + 12) == 0)) {
281
                                                                /* OSSL_DRBG_PARAM_RESEED_TIME_INTERVAL */
282
0
                                                                if (ossl_unlikely(r->reseed_int != NULL)) {
283
0
                                                                    ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
284
0
                                                                                   "param %s is repeated", s);
285
0
                                                                    return 0;
286
0
                                                                }
287
0
                                                                r->reseed_int = (OSSL_PARAM *)p;
288
0
                                                            }
289
0
                                                            break;
290
0
                                                        case '\0':
291
0
                                                            if (ossl_unlikely(r->reseed_time != NULL)) {
292
0
                                                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
293
0
                                                                               "param %s is repeated", s);
294
0
                                                                return 0;
295
0
                                                            }
296
0
                                                            r->reseed_time = (OSSL_PARAM *)p;
297
0
                                                        }
298
0
                                                    }
299
0
                                                }
300
0
                                            }
301
48
                                        }
302
48
                                    }
303
48
                                }
304
48
                            }
305
48
                        }
306
48
                    }
307
48
                }
308
48
                break;
309
64
            case 's':
310
64
                switch(s[1]) {
311
0
                default:
312
0
                    break;
313
64
                case 't':
314
64
                    switch(s[2]) {
315
0
                    default:
316
0
                        break;
317
16
                    case 'a':
318
16
                        if (ossl_likely(strcmp("te", s + 3) == 0)) {
319
                            /* OSSL_RAND_PARAM_STATE */
320
16
                            if (ossl_unlikely(r->state != 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
16
                            r->state = (OSSL_PARAM *)p;
326
16
                        }
327
16
                        break;
328
48
                    case 'r':
329
48
                        if (ossl_likely(strcmp("ength", s + 3) == 0)) {
330
                            /* OSSL_RAND_PARAM_STRENGTH */
331
48
                            if (ossl_unlikely(r->str != NULL)) {
332
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
333
0
                                               "param %s is repeated", s);
334
0
                                return 0;
335
0
                            }
336
48
                            r->str = (OSSL_PARAM *)p;
337
48
                        }
338
64
                    }
339
64
                }
340
64
                break;
341
64
            case 'u':
342
0
                if (ossl_likely(strcmp("se_derivation_function", s + 1) == 0)) {
343
                    /* OSSL_DRBG_PARAM_USE_DF */
344
0
                    if (ossl_unlikely(r->df != NULL)) {
345
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
346
0
                                       "param %s is repeated", s);
347
0
                        return 0;
348
0
                    }
349
0
                    r->df = (OSSL_PARAM *)p;
350
0
                }
351
144
            }
352
144
    return 1;
353
144
}
354
#endif
355
/* End of machine generated */
356
357
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
358
#include <string.h>
359
#include <openssl/params.h>
360
#include "internal/common.h"
361
#include "prov/proverr.h"
362
363
#ifndef drbg_ctr_set_ctx_params_list
364
static const OSSL_PARAM drbg_ctr_set_ctx_params_list[] = {
365
    OSSL_PARAM_utf8_string(OSSL_DRBG_PARAM_PROPERTIES, NULL, 0),
366
    OSSL_PARAM_utf8_string(OSSL_DRBG_PARAM_CIPHER, NULL, 0),
367
    OSSL_PARAM_int(OSSL_DRBG_PARAM_USE_DF, NULL),
368
    OSSL_PARAM_utf8_string(OSSL_PROV_PARAM_CORE_PROV_NAME, NULL, 0),
369
    OSSL_PARAM_uint(OSSL_DRBG_PARAM_RESEED_REQUESTS, NULL),
370
    OSSL_PARAM_uint64(OSSL_DRBG_PARAM_RESEED_TIME_INTERVAL, NULL),
371
    OSSL_PARAM_END
372
};
373
#endif
374
375
#ifndef drbg_ctr_set_ctx_params_st
376
struct drbg_ctr_set_ctx_params_st {
377
    OSSL_PARAM *cipher;
378
    OSSL_PARAM *df;
379
    OSSL_PARAM *propq;
380
    OSSL_PARAM *prov;
381
    OSSL_PARAM *reseed_req;
382
    OSSL_PARAM *reseed_time;
383
};
384
#endif
385
386
#ifndef drbg_ctr_set_ctx_params_decoder
387
static int drbg_ctr_set_ctx_params_decoder
388
    (const OSSL_PARAM *p, struct drbg_ctr_set_ctx_params_st *r)
389
32
{
390
32
    const char *s;
391
392
32
    memset(r, 0, sizeof(*r));
393
32
    if (p != NULL)
394
192
        for (; (s = p->key) != NULL; p++)
395
160
            switch(s[0]) {
396
0
            default:
397
0
                break;
398
32
            case 'c':
399
32
                if (ossl_likely(strcmp("ipher", s + 1) == 0)) {
400
                    /* OSSL_DRBG_PARAM_CIPHER */
401
32
                    if (ossl_unlikely(r->cipher != NULL)) {
402
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
403
0
                                       "param %s is repeated", s);
404
0
                        return 0;
405
0
                    }
406
32
                    r->cipher = (OSSL_PARAM *)p;
407
32
                }
408
32
                break;
409
32
            case 'p':
410
32
                switch(s[1]) {
411
0
                default:
412
0
                    break;
413
32
                case 'r':
414
32
                    switch(s[2]) {
415
0
                    default:
416
0
                        break;
417
32
                    case 'o':
418
32
                        switch(s[3]) {
419
0
                        default:
420
0
                            break;
421
0
                        case 'p':
422
0
                            if (ossl_likely(strcmp("erties", s + 4) == 0)) {
423
                                /* OSSL_DRBG_PARAM_PROPERTIES */
424
0
                                if (ossl_unlikely(r->propq != NULL)) {
425
0
                                    ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
426
0
                                                   "param %s is repeated", s);
427
0
                                    return 0;
428
0
                                }
429
0
                                r->propq = (OSSL_PARAM *)p;
430
0
                            }
431
0
                            break;
432
32
                        case 'v':
433
32
                            if (ossl_likely(strcmp("ider-name", s + 4) == 0)) {
434
                                /* OSSL_PROV_PARAM_CORE_PROV_NAME */
435
32
                                if (ossl_unlikely(r->prov != NULL)) {
436
0
                                    ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
437
0
                                                   "param %s is repeated", s);
438
0
                                    return 0;
439
0
                                }
440
32
                                r->prov = (OSSL_PARAM *)p;
441
32
                            }
442
32
                        }
443
32
                    }
444
32
                }
445
32
                break;
446
64
            case 'r':
447
64
                switch(s[1]) {
448
0
                default:
449
0
                    break;
450
64
                case 'e':
451
64
                    switch(s[2]) {
452
0
                    default:
453
0
                        break;
454
64
                    case 's':
455
64
                        switch(s[3]) {
456
0
                        default:
457
0
                            break;
458
64
                        case 'e':
459
64
                            switch(s[4]) {
460
0
                            default:
461
0
                                break;
462
64
                            case 'e':
463
64
                                switch(s[5]) {
464
0
                                default:
465
0
                                    break;
466
64
                                case 'd':
467
64
                                    switch(s[6]) {
468
0
                                    default:
469
0
                                        break;
470
64
                                    case '_':
471
64
                                        switch(s[7]) {
472
0
                                        default:
473
0
                                            break;
474
32
                                        case 'r':
475
32
                                            if (ossl_likely(strcmp("equests", s + 8) == 0)) {
476
                                                /* OSSL_DRBG_PARAM_RESEED_REQUESTS */
477
32
                                                if (ossl_unlikely(r->reseed_req != 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
32
                                                r->reseed_req = (OSSL_PARAM *)p;
483
32
                                            }
484
32
                                            break;
485
32
                                        case 't':
486
32
                                            if (ossl_likely(strcmp("ime_interval", s + 8) == 0)) {
487
                                                /* OSSL_DRBG_PARAM_RESEED_TIME_INTERVAL */
488
32
                                                if (ossl_unlikely(r->reseed_time != 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
32
                                                r->reseed_time = (OSSL_PARAM *)p;
494
32
                                            }
495
64
                                        }
496
64
                                    }
497
64
                                }
498
64
                            }
499
64
                        }
500
64
                    }
501
64
                }
502
64
                break;
503
64
            case 'u':
504
32
                if (ossl_likely(strcmp("se_derivation_function", s + 1) == 0)) {
505
                    /* OSSL_DRBG_PARAM_USE_DF */
506
32
                    if (ossl_unlikely(r->df != NULL)) {
507
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
508
0
                                       "param %s is repeated", s);
509
0
                        return 0;
510
0
                    }
511
32
                    r->df = (OSSL_PARAM *)p;
512
32
                }
513
160
            }
514
32
    return 1;
515
32
}
516
#endif
517
/* End of machine generated */