Coverage Report

Created: 2026-05-20 07:05

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