Coverage Report

Created: 2026-02-22 06:11

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