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