Coverage Report

Created: 2025-10-28 06:56

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl/providers/implementations/rands/seed_src.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 seed_src_get_ctx_params_list
14
static const OSSL_PARAM seed_src_get_ctx_params_list[] = {
15
    OSSL_PARAM_int(OSSL_RAND_PARAM_STATE, NULL),
16
    OSSL_PARAM_uint(OSSL_RAND_PARAM_STRENGTH, NULL),
17
    OSSL_PARAM_size_t(OSSL_RAND_PARAM_MAX_REQUEST, NULL),
18
    OSSL_PARAM_END
19
};
20
#endif
21
22
#ifndef seed_src_get_ctx_params_st
23
struct seed_src_get_ctx_params_st {
24
    OSSL_PARAM *maxreq;
25
    OSSL_PARAM *state;
26
    OSSL_PARAM *str;
27
};
28
#endif
29
30
#ifndef seed_src_get_ctx_params_decoder
31
static int seed_src_get_ctx_params_decoder
32
    (const OSSL_PARAM *p, struct seed_src_get_ctx_params_st *r)
33
128
{
34
128
    const char *s;
35
36
128
    memset(r, 0, sizeof(*r));
37
128
    if (p != NULL)
38
256
        for (; (s = p->key) != NULL; p++)
39
128
            switch(s[0]) {
40
64
            default:
41
64
                break;
42
64
            case 'm':
43
0
                if (ossl_likely(strcmp("ax_request", s + 1) == 0)) {
44
                    /* OSSL_RAND_PARAM_MAX_REQUEST */
45
0
                    if (ossl_unlikely(r->maxreq != NULL)) {
46
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
47
0
                                       "param %s is repeated", s);
48
0
                        return 0;
49
0
                    }
50
0
                    r->maxreq = (OSSL_PARAM *)p;
51
0
                }
52
0
                break;
53
64
            case 's':
54
64
                switch(s[1]) {
55
0
                default:
56
0
                    break;
57
64
                case 't':
58
64
                    switch(s[2]) {
59
0
                    default:
60
0
                        break;
61
0
                    case 'a':
62
0
                        if (ossl_likely(strcmp("te", s + 3) == 0)) {
63
                            /* OSSL_RAND_PARAM_STATE */
64
0
                            if (ossl_unlikely(r->state != NULL)) {
65
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
66
0
                                               "param %s is repeated", s);
67
0
                                return 0;
68
0
                            }
69
0
                            r->state = (OSSL_PARAM *)p;
70
0
                        }
71
0
                        break;
72
64
                    case 'r':
73
64
                        if (ossl_likely(strcmp("ength", s + 3) == 0)) {
74
                            /* OSSL_RAND_PARAM_STRENGTH */
75
64
                            if (ossl_unlikely(r->str != NULL)) {
76
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
77
0
                                               "param %s is repeated", s);
78
0
                                return 0;
79
0
                            }
80
64
                            r->str = (OSSL_PARAM *)p;
81
64
                        }
82
64
                    }
83
64
                }
84
128
            }
85
128
    return 1;
86
128
}
87
#endif
88
/* End of machine generated */