Coverage Report

Created: 2026-05-20 07:05

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl/providers/implementations/asymciphers/rsa_enc.inc
Line
Count
Source
1
/*
2
 * Copyright 2025-2026 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 rsa_get_ctx_params_list
19
static const OSSL_PARAM rsa_get_ctx_params_list[] = {
20
    OSSL_PARAM_utf8_string(OSSL_ASYM_CIPHER_PARAM_OAEP_DIGEST, NULL, 0),
21
    OSSL_PARAM_utf8_string(OSSL_ASYM_CIPHER_PARAM_PAD_MODE, NULL, 0),
22
    OSSL_PARAM_int(OSSL_ASYM_CIPHER_PARAM_PAD_MODE, NULL),
23
    OSSL_PARAM_utf8_string(OSSL_ASYM_CIPHER_PARAM_MGF1_DIGEST, NULL, 0),
24
    OSSL_PARAM_octet_ptr(OSSL_ASYM_CIPHER_PARAM_OAEP_LABEL, NULL, 0),
25
    OSSL_PARAM_uint(OSSL_ASYM_CIPHER_PARAM_TLS_CLIENT_VERSION, NULL),
26
    OSSL_PARAM_uint(OSSL_ASYM_CIPHER_PARAM_TLS_NEGOTIATED_VERSION, NULL),
27
    OSSL_PARAM_uint(OSSL_ASYM_CIPHER_PARAM_IMPLICIT_REJECTION, NULL),
28
# if defined(FIPS_MODULE)
29
    OSSL_PARAM_int(OSSL_ASYM_CIPHER_PARAM_FIPS_APPROVED_INDICATOR, NULL),
30
# endif
31
    OSSL_PARAM_END
32
};
33
#endif
34
35
#ifndef rsa_get_ctx_params_st
36
struct rsa_get_ctx_params_st {
37
    OSSL_PARAM *imrej;
38
# if defined(FIPS_MODULE)
39
    OSSL_PARAM *ind;
40
# endif
41
    OSSL_PARAM *label;
42
    OSSL_PARAM *mgf1;
43
    OSSL_PARAM *negver;
44
    OSSL_PARAM *oaep;
45
    OSSL_PARAM *pad;
46
    OSSL_PARAM *tlsver;
47
};
48
#endif
49
50
#ifndef rsa_get_ctx_params_decoder
51
static int rsa_get_ctx_params_decoder
52
    (const OSSL_PARAM *p, struct rsa_get_ctx_params_st *r)
53
0
{
54
0
    const char *s;
55
56
0
    memset(r, 0, sizeof(*r));
57
0
    if (p != NULL)
58
0
        for (; (s = p->key) != NULL; p++)
59
0
            switch(s[0]) {
60
0
            default:
61
0
                break;
62
0
            case 'd':
63
0
                if (ossl_likely(strcmp("igest", s + 1) == 0)) {
64
                    /* OSSL_ASYM_CIPHER_PARAM_OAEP_DIGEST */
65
0
                    if (ossl_unlikely(r->oaep != NULL)) {
66
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
67
0
                                       "param %s is repeated", s);
68
0
                        return 0;
69
0
                    }
70
0
                    r->oaep = (OSSL_PARAM *)p;
71
0
                }
72
0
                break;
73
0
            case 'f':
74
# if defined(FIPS_MODULE)
75
                if (ossl_likely(strcmp("ips-indicator", s + 1) == 0)) {
76
                    /* OSSL_ASYM_CIPHER_PARAM_FIPS_APPROVED_INDICATOR */
77
                    if (ossl_unlikely(r->ind != NULL)) {
78
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
79
                                       "param %s is repeated", s);
80
                        return 0;
81
                    }
82
                    r->ind = (OSSL_PARAM *)p;
83
                }
84
# endif
85
0
                break;
86
0
            case 'i':
87
0
                if (ossl_likely(strcmp("mplicit-rejection", s + 1) == 0)) {
88
                    /* OSSL_ASYM_CIPHER_PARAM_IMPLICIT_REJECTION */
89
0
                    if (ossl_unlikely(r->imrej != NULL)) {
90
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
91
0
                                       "param %s is repeated", s);
92
0
                        return 0;
93
0
                    }
94
0
                    r->imrej = (OSSL_PARAM *)p;
95
0
                }
96
0
                break;
97
0
            case 'm':
98
0
                if (ossl_likely(strcmp("gf1-digest", s + 1) == 0)) {
99
                    /* OSSL_ASYM_CIPHER_PARAM_MGF1_DIGEST */
100
0
                    if (ossl_unlikely(r->mgf1 != NULL)) {
101
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
102
0
                                       "param %s is repeated", s);
103
0
                        return 0;
104
0
                    }
105
0
                    r->mgf1 = (OSSL_PARAM *)p;
106
0
                }
107
0
                break;
108
0
            case 'o':
109
0
                if (ossl_likely(strcmp("aep-label", s + 1) == 0)) {
110
                    /* OSSL_ASYM_CIPHER_PARAM_OAEP_LABEL */
111
0
                    if (ossl_unlikely(r->label != NULL)) {
112
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
113
0
                                       "param %s is repeated", s);
114
0
                        return 0;
115
0
                    }
116
0
                    r->label = (OSSL_PARAM *)p;
117
0
                }
118
0
                break;
119
0
            case 'p':
120
0
                if (ossl_likely(strcmp("ad-mode", s + 1) == 0)) {
121
                    /* OSSL_ASYM_CIPHER_PARAM_PAD_MODE */
122
0
                    if (ossl_unlikely(r->pad != NULL)) {
123
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
124
0
                                       "param %s is repeated", s);
125
0
                        return 0;
126
0
                    }
127
0
                    r->pad = (OSSL_PARAM *)p;
128
0
                }
129
0
                break;
130
0
            case 't':
131
0
                switch(s[1]) {
132
0
                default:
133
0
                    break;
134
0
                case 'l':
135
0
                    switch(s[2]) {
136
0
                    default:
137
0
                        break;
138
0
                    case 's':
139
0
                        switch(s[3]) {
140
0
                        default:
141
0
                            break;
142
0
                        case '-':
143
0
                            switch(s[4]) {
144
0
                            default:
145
0
                                break;
146
0
                            case 'c':
147
0
                                if (ossl_likely(strcmp("lient-version", s + 5) == 0)) {
148
                                    /* OSSL_ASYM_CIPHER_PARAM_TLS_CLIENT_VERSION */
149
0
                                    if (ossl_unlikely(r->tlsver != NULL)) {
150
0
                                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
151
0
                                                       "param %s is repeated", s);
152
0
                                        return 0;
153
0
                                    }
154
0
                                    r->tlsver = (OSSL_PARAM *)p;
155
0
                                }
156
0
                                break;
157
0
                            case 'n':
158
0
                                if (ossl_likely(strcmp("egotiated-version", s + 5) == 0)) {
159
                                    /* OSSL_ASYM_CIPHER_PARAM_TLS_NEGOTIATED_VERSION */
160
0
                                    if (ossl_unlikely(r->negver != NULL)) {
161
0
                                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
162
0
                                                       "param %s is repeated", s);
163
0
                                        return 0;
164
0
                                    }
165
0
                                    r->negver = (OSSL_PARAM *)p;
166
0
                                }
167
0
                            }
168
0
                        }
169
0
                    }
170
0
                }
171
0
            }
172
0
    return 1;
173
0
}
174
#endif
175
/* End of machine generated */
176
177
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
178
#include <string.h>
179
#include <openssl/params.h>
180
#include "internal/common.h"
181
#include "prov/proverr.h"
182
183
#ifndef rsa_set_ctx_params_list
184
static const OSSL_PARAM rsa_set_ctx_params_list[] = {
185
    OSSL_PARAM_utf8_string(OSSL_ASYM_CIPHER_PARAM_OAEP_DIGEST, NULL, 0),
186
    OSSL_PARAM_utf8_string(OSSL_ASYM_CIPHER_PARAM_OAEP_DIGEST_PROPS, NULL, 0),
187
    OSSL_PARAM_utf8_string(OSSL_ASYM_CIPHER_PARAM_PAD_MODE, NULL, 0),
188
    OSSL_PARAM_int(OSSL_ASYM_CIPHER_PARAM_PAD_MODE, NULL),
189
    OSSL_PARAM_utf8_string(OSSL_ASYM_CIPHER_PARAM_MGF1_DIGEST, NULL, 0),
190
    OSSL_PARAM_utf8_string(OSSL_ASYM_CIPHER_PARAM_MGF1_DIGEST_PROPS, NULL, 0),
191
    OSSL_PARAM_octet_string(OSSL_ASYM_CIPHER_PARAM_OAEP_LABEL, NULL, 0),
192
    OSSL_PARAM_uint(OSSL_ASYM_CIPHER_PARAM_TLS_CLIENT_VERSION, NULL),
193
    OSSL_PARAM_uint(OSSL_ASYM_CIPHER_PARAM_TLS_NEGOTIATED_VERSION, NULL),
194
    OSSL_PARAM_uint(OSSL_ASYM_CIPHER_PARAM_IMPLICIT_REJECTION, NULL),
195
# if defined(FIPS_MODULE)
196
    OSSL_PARAM_int(OSSL_ASYM_CIPHER_PARAM_FIPS_KEY_CHECK, NULL),
197
# endif
198
# if defined(FIPS_MODULE)
199
    OSSL_PARAM_int(OSSL_ASYM_CIPHER_PARAM_FIPS_RSA_PKCS15_PAD_DISABLED, NULL),
200
# endif
201
    OSSL_PARAM_END
202
};
203
#endif
204
205
#ifndef rsa_set_ctx_params_st
206
struct rsa_set_ctx_params_st {
207
    OSSL_PARAM *imrej;
208
# if defined(FIPS_MODULE)
209
    OSSL_PARAM *ind_k;
210
# endif
211
# if defined(FIPS_MODULE)
212
    OSSL_PARAM *ind_pad;
213
# endif
214
    OSSL_PARAM *label;
215
    OSSL_PARAM *mgf1;
216
    OSSL_PARAM *mgf1_pq;
217
    OSSL_PARAM *negver;
218
    OSSL_PARAM *oaep;
219
    OSSL_PARAM *oaep_pq;
220
    OSSL_PARAM *pad;
221
    OSSL_PARAM *tlsver;
222
};
223
#endif
224
225
#ifndef rsa_set_ctx_params_decoder
226
static int rsa_set_ctx_params_decoder
227
    (const OSSL_PARAM *p, struct rsa_set_ctx_params_st *r, int *count)
228
0
{
229
0
    const char *s;
230
231
0
    *count = 0;
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 'd':
239
0
                switch(s[1]) {
240
0
                default:
241
0
                    break;
242
0
                case 'i':
243
0
                    switch(s[2]) {
244
0
                    default:
245
0
                        break;
246
0
                    case 'g':
247
0
                        switch(s[3]) {
248
0
                        default:
249
0
                            break;
250
0
                        case 'e':
251
0
                            switch(s[4]) {
252
0
                            default:
253
0
                                break;
254
0
                            case 's':
255
0
                                switch(s[5]) {
256
0
                                default:
257
0
                                    break;
258
0
                                case 't':
259
0
                                    switch(s[6]) {
260
0
                                    default:
261
0
                                        break;
262
0
                                    case '-':
263
0
                                        if (ossl_likely(strcmp("props", s + 7) == 0)) {
264
                                            /* OSSL_ASYM_CIPHER_PARAM_OAEP_DIGEST_PROPS */
265
0
                                            if (ossl_unlikely(r->oaep_pq != NULL)) {
266
0
                                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
267
0
                                                               "param %s is repeated", s);
268
0
                                                return 0;
269
0
                                            }
270
0
                                            ++*count;
271
0
                                            r->oaep_pq = (OSSL_PARAM *)p;
272
0
                                        }
273
0
                                        break;
274
0
                                    case '\0':
275
0
                                        if (ossl_unlikely(r->oaep != NULL)) {
276
0
                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
277
0
                                                           "param %s is repeated", s);
278
0
                                            return 0;
279
0
                                        }
280
0
                                        ++*count;
281
0
                                        r->oaep = (OSSL_PARAM *)p;
282
0
                                    }
283
0
                                }
284
0
                            }
285
0
                        }
286
0
                    }
287
0
                }
288
0
                break;
289
0
            case 'i':
290
0
                if (ossl_likely(strcmp("mplicit-rejection", s + 1) == 0)) {
291
                    /* OSSL_ASYM_CIPHER_PARAM_IMPLICIT_REJECTION */
292
0
                    if (ossl_unlikely(r->imrej != NULL)) {
293
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
294
0
                                       "param %s is repeated", s);
295
0
                        return 0;
296
0
                    }
297
0
                    ++*count;
298
0
                    r->imrej = (OSSL_PARAM *)p;
299
0
                }
300
0
                break;
301
0
            case 'k':
302
# if defined(FIPS_MODULE)
303
                if (ossl_likely(strcmp("ey-check", s + 1) == 0)) {
304
                    /* OSSL_ASYM_CIPHER_PARAM_FIPS_KEY_CHECK */
305
                    if (ossl_unlikely(r->ind_k != NULL)) {
306
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
307
                                       "param %s is repeated", s);
308
                        return 0;
309
                    }
310
                    ++*count;
311
                    r->ind_k = (OSSL_PARAM *)p;
312
                }
313
# endif
314
0
                break;
315
0
            case 'm':
316
0
                switch(s[1]) {
317
0
                default:
318
0
                    break;
319
0
                case 'g':
320
0
                    switch(s[2]) {
321
0
                    default:
322
0
                        break;
323
0
                    case 'f':
324
0
                        switch(s[3]) {
325
0
                        default:
326
0
                            break;
327
0
                        case '1':
328
0
                            switch(s[4]) {
329
0
                            default:
330
0
                                break;
331
0
                            case '-':
332
0
                                switch(s[5]) {
333
0
                                default:
334
0
                                    break;
335
0
                                case 'd':
336
0
                                    if (ossl_likely(strcmp("igest", s + 6) == 0)) {
337
                                        /* OSSL_ASYM_CIPHER_PARAM_MGF1_DIGEST */
338
0
                                        if (ossl_unlikely(r->mgf1 != NULL)) {
339
0
                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
340
0
                                                           "param %s is repeated", s);
341
0
                                            return 0;
342
0
                                        }
343
0
                                        ++*count;
344
0
                                        r->mgf1 = (OSSL_PARAM *)p;
345
0
                                    }
346
0
                                    break;
347
0
                                case 'p':
348
0
                                    if (ossl_likely(strcmp("roperties", s + 6) == 0)) {
349
                                        /* OSSL_ASYM_CIPHER_PARAM_MGF1_DIGEST_PROPS */
350
0
                                        if (ossl_unlikely(r->mgf1_pq != NULL)) {
351
0
                                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
352
0
                                                           "param %s is repeated", s);
353
0
                                            return 0;
354
0
                                        }
355
0
                                        ++*count;
356
0
                                        r->mgf1_pq = (OSSL_PARAM *)p;
357
0
                                    }
358
0
                                }
359
0
                            }
360
0
                        }
361
0
                    }
362
0
                }
363
0
                break;
364
0
            case 'o':
365
0
                if (ossl_likely(strcmp("aep-label", s + 1) == 0)) {
366
                    /* OSSL_ASYM_CIPHER_PARAM_OAEP_LABEL */
367
0
                    if (ossl_unlikely(r->label != NULL)) {
368
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
369
0
                                       "param %s is repeated", s);
370
0
                        return 0;
371
0
                    }
372
0
                    ++*count;
373
0
                    r->label = (OSSL_PARAM *)p;
374
0
                }
375
0
                break;
376
0
            case 'p':
377
0
                if (ossl_likely(strcmp("ad-mode", s + 1) == 0)) {
378
                    /* OSSL_ASYM_CIPHER_PARAM_PAD_MODE */
379
0
                    if (ossl_unlikely(r->pad != NULL)) {
380
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
381
0
                                       "param %s is repeated", s);
382
0
                        return 0;
383
0
                    }
384
0
                    ++*count;
385
0
                    r->pad = (OSSL_PARAM *)p;
386
0
                }
387
0
                break;
388
0
            case 'r':
389
# if defined(FIPS_MODULE)
390
                if (ossl_likely(strcmp("sa-pkcs15-pad-disabled", s + 1) == 0)) {
391
                    /* OSSL_ASYM_CIPHER_PARAM_FIPS_RSA_PKCS15_PAD_DISABLED */
392
                    if (ossl_unlikely(r->ind_pad != NULL)) {
393
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
394
                                       "param %s is repeated", s);
395
                        return 0;
396
                    }
397
                    ++*count;
398
                    r->ind_pad = (OSSL_PARAM *)p;
399
                }
400
# endif
401
0
                break;
402
0
            case 't':
403
0
                switch(s[1]) {
404
0
                default:
405
0
                    break;
406
0
                case 'l':
407
0
                    switch(s[2]) {
408
0
                    default:
409
0
                        break;
410
0
                    case 's':
411
0
                        switch(s[3]) {
412
0
                        default:
413
0
                            break;
414
0
                        case '-':
415
0
                            switch(s[4]) {
416
0
                            default:
417
0
                                break;
418
0
                            case 'c':
419
0
                                if (ossl_likely(strcmp("lient-version", s + 5) == 0)) {
420
                                    /* OSSL_ASYM_CIPHER_PARAM_TLS_CLIENT_VERSION */
421
0
                                    if (ossl_unlikely(r->tlsver != NULL)) {
422
0
                                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
423
0
                                                       "param %s is repeated", s);
424
0
                                        return 0;
425
0
                                    }
426
0
                                    ++*count;
427
0
                                    r->tlsver = (OSSL_PARAM *)p;
428
0
                                }
429
0
                                break;
430
0
                            case 'n':
431
0
                                if (ossl_likely(strcmp("egotiated-version", s + 5) == 0)) {
432
                                    /* OSSL_ASYM_CIPHER_PARAM_TLS_NEGOTIATED_VERSION */
433
0
                                    if (ossl_unlikely(r->negver != NULL)) {
434
0
                                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
435
0
                                                       "param %s is repeated", s);
436
0
                                        return 0;
437
0
                                    }
438
0
                                    ++*count;
439
0
                                    r->negver = (OSSL_PARAM *)p;
440
0
                                }
441
0
                            }
442
0
                        }
443
0
                    }
444
0
                }
445
0
            }
446
0
    return 1;
447
0
}
448
#endif
449
/* End of machine generated */