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