Coverage Report

Created: 2025-12-08 06:22

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl/providers/implementations/kdfs/tls1_prf.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 tls1prf_set_ctx_params_list
14
static const OSSL_PARAM tls1prf_set_ctx_params_list[] = {
15
    OSSL_PARAM_utf8_string(OSSL_KDF_PARAM_PROPERTIES, NULL, 0),
16
    OSSL_PARAM_utf8_string(OSSL_KDF_PARAM_DIGEST, NULL, 0),
17
    OSSL_PARAM_octet_string(OSSL_KDF_PARAM_SECRET, NULL, 0),
18
    OSSL_PARAM_octet_string(OSSL_KDF_PARAM_SEED, NULL, 0),
19
# if defined(FIPS_MODULE)
20
    OSSL_PARAM_int(OSSL_KDF_PARAM_FIPS_EMS_CHECK, NULL),
21
# endif
22
# if defined(FIPS_MODULE)
23
    OSSL_PARAM_int(OSSL_KDF_PARAM_FIPS_DIGEST_CHECK, NULL),
24
# endif
25
# if defined(FIPS_MODULE)
26
    OSSL_PARAM_int(OSSL_KDF_PARAM_FIPS_KEY_CHECK, NULL),
27
# endif
28
    OSSL_PARAM_END
29
};
30
#endif
31
32
#ifndef tls1prf_set_ctx_params_st
33
struct tls1prf_set_ctx_params_st {
34
    OSSL_PARAM *digest;
35
# if defined(FIPS_MODULE)
36
    OSSL_PARAM *ind_d;
37
# endif
38
# if defined(FIPS_MODULE)
39
    OSSL_PARAM *ind_e;
40
# endif
41
# if defined(FIPS_MODULE)
42
    OSSL_PARAM *ind_k;
43
# endif
44
    OSSL_PARAM *propq;
45
    OSSL_PARAM *secret;
46
    OSSL_PARAM *seed[TLSPRF_MAX_SEEDS];
47
    int num_seed;
48
};
49
#endif
50
51
#ifndef tls1prf_set_ctx_params_decoder
52
static int tls1prf_set_ctx_params_decoder
53
    (const OSSL_PARAM *p, struct tls1prf_set_ctx_params_st *r)
54
0
{
55
0
    const char *s;
56
57
0
    memset(r, 0, sizeof(*r));
58
0
    if (p != NULL)
59
0
        for (; (s = p->key) != NULL; p++)
60
0
            switch(s[0]) {
61
0
            default:
62
0
                break;
63
0
            case 'd':
64
0
                switch(s[1]) {
65
0
                default:
66
0
                    break;
67
0
                case 'i':
68
0
                    switch(s[2]) {
69
0
                    default:
70
0
                        break;
71
0
                    case 'g':
72
0
                        switch(s[3]) {
73
0
                        default:
74
0
                            break;
75
0
                        case 'e':
76
0
                            switch(s[4]) {
77
0
                            default:
78
0
                                break;
79
0
                            case 's':
80
0
                                switch(s[5]) {
81
0
                                default:
82
0
                                    break;
83
0
                                case 't':
84
0
                                    switch(s[6]) {
85
0
                                    default:
86
0
                                        break;
87
0
                                    case '-':
88
# if defined(FIPS_MODULE)
89
                                        if (ossl_likely(strcmp("check", s + 7) == 0)) {
90
                                            /* OSSL_KDF_PARAM_FIPS_DIGEST_CHECK */
91
                                            if (ossl_unlikely(r->ind_d != NULL)) {
92
                                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
93
                                                               "param %s is repeated", s);
94
                                                return 0;
95
                                            }
96
                                            r->ind_d = (OSSL_PARAM *)p;
97
                                        }
98
# endif
99
0
                                        break;
100
0
                                    case '\0':
101
0
                                        if (ossl_unlikely(r->digest != NULL)) {
102
0
                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
103
0
                                                           "param %s is repeated", s);
104
0
                                            return 0;
105
0
                                        }
106
0
                                        r->digest = (OSSL_PARAM *)p;
107
0
                                    }
108
0
                                }
109
0
                            }
110
0
                        }
111
0
                    }
112
0
                }
113
0
                break;
114
0
            case 'e':
115
# if defined(FIPS_MODULE)
116
                if (ossl_likely(strcmp("ms_check", s + 1) == 0)) {
117
                    /* OSSL_KDF_PARAM_FIPS_EMS_CHECK */
118
                    if (ossl_unlikely(r->ind_e != NULL)) {
119
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
120
                                       "param %s is repeated", s);
121
                        return 0;
122
                    }
123
                    r->ind_e = (OSSL_PARAM *)p;
124
                }
125
# endif
126
0
                break;
127
0
            case 'k':
128
# if defined(FIPS_MODULE)
129
                if (ossl_likely(strcmp("ey-check", s + 1) == 0)) {
130
                    /* OSSL_KDF_PARAM_FIPS_KEY_CHECK */
131
                    if (ossl_unlikely(r->ind_k != NULL)) {
132
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
133
                                       "param %s is repeated", s);
134
                        return 0;
135
                    }
136
                    r->ind_k = (OSSL_PARAM *)p;
137
                }
138
# endif
139
0
                break;
140
0
            case 'p':
141
0
                if (ossl_likely(strcmp("roperties", s + 1) == 0)) {
142
                    /* OSSL_KDF_PARAM_PROPERTIES */
143
0
                    if (ossl_unlikely(r->propq != NULL)) {
144
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
145
0
                                       "param %s is repeated", s);
146
0
                        return 0;
147
0
                    }
148
0
                    r->propq = (OSSL_PARAM *)p;
149
0
                }
150
0
                break;
151
0
            case 's':
152
0
                switch(s[1]) {
153
0
                default:
154
0
                    break;
155
0
                case 'e':
156
0
                    switch(s[2]) {
157
0
                    default:
158
0
                        break;
159
0
                    case 'c':
160
0
                        if (ossl_likely(strcmp("ret", s + 3) == 0)) {
161
                            /* OSSL_KDF_PARAM_SECRET */
162
0
                            if (ossl_unlikely(r->secret != NULL)) {
163
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
164
0
                                               "param %s is repeated", s);
165
0
                                return 0;
166
0
                            }
167
0
                            r->secret = (OSSL_PARAM *)p;
168
0
                        }
169
0
                        break;
170
0
                    case 'e':
171
0
                        if (ossl_likely(strcmp("d", s + 3) == 0)) {
172
                            /* OSSL_KDF_PARAM_SEED */
173
0
                            if (ossl_unlikely(r->num_seed >= TLSPRF_MAX_SEEDS)) {
174
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_TOO_MANY_RECORDS,
175
0
                                               "param %s present >%d times", s, TLSPRF_MAX_SEEDS);
176
0
                                return 0;
177
0
                            }
178
0
                            r->seed[r->num_seed++] = (OSSL_PARAM *)p;
179
0
                        }
180
0
                    }
181
0
                }
182
0
            }
183
0
    return 1;
184
0
}
185
#endif
186
/* End of machine generated */
187
188
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
189
#ifndef tls1prf_get_ctx_params_list
190
static const OSSL_PARAM tls1prf_get_ctx_params_list[] = {
191
    OSSL_PARAM_size_t(OSSL_KDF_PARAM_SIZE, NULL),
192
# if defined(FIPS_MODULE)
193
    OSSL_PARAM_int(OSSL_KDF_PARAM_FIPS_APPROVED_INDICATOR, NULL),
194
# endif
195
    OSSL_PARAM_END
196
};
197
#endif
198
199
#ifndef tls1prf_get_ctx_params_st
200
struct tls1prf_get_ctx_params_st {
201
# if defined(FIPS_MODULE)
202
    OSSL_PARAM *ind;
203
# endif
204
    OSSL_PARAM *size;
205
};
206
#endif
207
208
#ifndef tls1prf_get_ctx_params_decoder
209
static int tls1prf_get_ctx_params_decoder
210
    (const OSSL_PARAM *p, struct tls1prf_get_ctx_params_st *r)
211
0
{
212
0
    const char *s;
213
214
0
    memset(r, 0, sizeof(*r));
215
0
    if (p != NULL)
216
0
        for (; (s = p->key) != NULL; p++)
217
0
            switch(s[0]) {
218
0
            default:
219
0
                break;
220
0
            case 'f':
221
# if defined(FIPS_MODULE)
222
                if (ossl_likely(strcmp("ips-indicator", s + 1) == 0)) {
223
                    /* OSSL_KDF_PARAM_FIPS_APPROVED_INDICATOR */
224
                    if (ossl_unlikely(r->ind != NULL)) {
225
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
226
                                       "param %s is repeated", s);
227
                        return 0;
228
                    }
229
                    r->ind = (OSSL_PARAM *)p;
230
                }
231
# endif
232
0
                break;
233
0
            case 's':
234
0
                if (ossl_likely(strcmp("ize", s + 1) == 0)) {
235
                    /* OSSL_KDF_PARAM_SIZE */
236
0
                    if (ossl_unlikely(r->size != NULL)) {
237
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
238
0
                                       "param %s is repeated", s);
239
0
                        return 0;
240
0
                    }
241
0
                    r->size = (OSSL_PARAM *)p;
242
0
                }
243
0
            }
244
0
    return 1;
245
0
}
246
#endif
247
/* End of machine generated */