Coverage Report

Created: 2026-05-30 06:06

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl/providers/implementations/ciphers/cipher_aes_ocb.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 aes_ocb_set_ctx_params_list
19
static const OSSL_PARAM aes_ocb_set_ctx_params_list[] = {
20
    OSSL_PARAM_size_t(OSSL_CIPHER_PARAM_KEYLEN, NULL),
21
    OSSL_PARAM_size_t(OSSL_CIPHER_PARAM_AEAD_IVLEN, NULL),
22
    OSSL_PARAM_octet_string(OSSL_CIPHER_PARAM_AEAD_TAG, NULL, 0),
23
    OSSL_PARAM_END
24
};
25
#endif
26
27
#ifndef aes_ocb_set_ctx_params_st
28
struct aes_ocb_set_ctx_params_st {
29
    OSSL_PARAM *ivlen;
30
    OSSL_PARAM *keylen;
31
    OSSL_PARAM *tag;
32
};
33
#endif
34
35
#ifndef aes_ocb_set_ctx_params_decoder
36
static int aes_ocb_set_ctx_params_decoder
37
    (const OSSL_PARAM *p, struct aes_ocb_set_ctx_params_st *r)
38
0
{
39
0
    const char *s;
40
41
0
    memset(r, 0, sizeof(*r));
42
0
    if (p != NULL)
43
0
        for (; (s = p->key) != NULL; p++)
44
0
            switch(s[0]) {
45
0
            default:
46
0
                break;
47
0
            case 'i':
48
0
                if (ossl_likely(strcmp("vlen", s + 1) == 0)) {
49
                    /* OSSL_CIPHER_PARAM_AEAD_IVLEN */
50
0
                    if (ossl_unlikely(r->ivlen != NULL)) {
51
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
52
0
                                       "param %s is repeated", s);
53
0
                        return 0;
54
0
                    }
55
0
                    r->ivlen = (OSSL_PARAM *)p;
56
0
                }
57
0
                break;
58
0
            case 'k':
59
0
                if (ossl_likely(strcmp("eylen", s + 1) == 0)) {
60
                    /* OSSL_CIPHER_PARAM_KEYLEN */
61
0
                    if (ossl_unlikely(r->keylen != NULL)) {
62
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
63
0
                                       "param %s is repeated", s);
64
0
                        return 0;
65
0
                    }
66
0
                    r->keylen = (OSSL_PARAM *)p;
67
0
                }
68
0
                break;
69
0
            case 't':
70
0
                if (ossl_likely(strcmp("ag", s + 1) == 0)) {
71
                    /* OSSL_CIPHER_PARAM_AEAD_TAG */
72
0
                    if (ossl_unlikely(r->tag != NULL)) {
73
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
74
0
                                       "param %s is repeated", s);
75
0
                        return 0;
76
0
                    }
77
0
                    r->tag = (OSSL_PARAM *)p;
78
0
                }
79
0
            }
80
0
    return 1;
81
0
}
82
#endif
83
/* End of machine generated */
84
85
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
86
#include <string.h>
87
#include <openssl/params.h>
88
#include "internal/common.h"
89
#include "prov/proverr.h"
90
91
#ifndef aes_ocb_get_ctx_params_list
92
static const OSSL_PARAM aes_ocb_get_ctx_params_list[] = {
93
    OSSL_PARAM_size_t(OSSL_CIPHER_PARAM_KEYLEN, NULL),
94
    OSSL_PARAM_size_t(OSSL_CIPHER_PARAM_IVLEN, NULL),
95
    OSSL_PARAM_size_t(OSSL_CIPHER_PARAM_AEAD_TAGLEN, NULL),
96
    OSSL_PARAM_octet_string(OSSL_CIPHER_PARAM_IV, NULL, 0),
97
    OSSL_PARAM_octet_string(OSSL_CIPHER_PARAM_UPDATED_IV, NULL, 0),
98
    OSSL_PARAM_octet_string(OSSL_CIPHER_PARAM_AEAD_TAG, NULL, 0),
99
    OSSL_PARAM_END
100
};
101
#endif
102
103
#ifndef aes_ocb_get_ctx_params_st
104
struct aes_ocb_get_ctx_params_st {
105
    OSSL_PARAM *iv;
106
    OSSL_PARAM *ivlen;
107
    OSSL_PARAM *keylen;
108
    OSSL_PARAM *tag;
109
    OSSL_PARAM *taglen;
110
    OSSL_PARAM *upd_iv;
111
};
112
#endif
113
114
#ifndef aes_ocb_get_ctx_params_decoder
115
static int aes_ocb_get_ctx_params_decoder
116
    (const OSSL_PARAM *p, struct aes_ocb_get_ctx_params_st *r)
117
0
{
118
0
    const char *s;
119
120
0
    memset(r, 0, sizeof(*r));
121
0
    if (p != NULL)
122
0
        for (; (s = p->key) != NULL; p++)
123
0
            switch(s[0]) {
124
0
            default:
125
0
                break;
126
0
            case 'i':
127
0
                switch(s[1]) {
128
0
                default:
129
0
                    break;
130
0
                case 'v':
131
0
                    switch(s[2]) {
132
0
                    default:
133
0
                        break;
134
0
                    case 'l':
135
0
                        if (ossl_likely(strcmp("en", s + 3) == 0)) {
136
                            /* OSSL_CIPHER_PARAM_IVLEN */
137
0
                            if (ossl_unlikely(r->ivlen != 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->ivlen = (OSSL_PARAM *)p;
143
0
                        }
144
0
                        break;
145
0
                    case '\0':
146
0
                        if (ossl_unlikely(r->iv != NULL)) {
147
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
148
0
                                           "param %s is repeated", s);
149
0
                            return 0;
150
0
                        }
151
0
                        r->iv = (OSSL_PARAM *)p;
152
0
                    }
153
0
                }
154
0
                break;
155
0
            case 'k':
156
0
                if (ossl_likely(strcmp("eylen", s + 1) == 0)) {
157
                    /* OSSL_CIPHER_PARAM_KEYLEN */
158
0
                    if (ossl_unlikely(r->keylen != NULL)) {
159
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
160
0
                                       "param %s is repeated", s);
161
0
                        return 0;
162
0
                    }
163
0
                    r->keylen = (OSSL_PARAM *)p;
164
0
                }
165
0
                break;
166
0
            case 't':
167
0
                switch(s[1]) {
168
0
                default:
169
0
                    break;
170
0
                case 'a':
171
0
                    switch(s[2]) {
172
0
                    default:
173
0
                        break;
174
0
                    case 'g':
175
0
                        switch(s[3]) {
176
0
                        default:
177
0
                            break;
178
0
                        case 'l':
179
0
                            if (ossl_likely(strcmp("en", s + 4) == 0)) {
180
                                /* OSSL_CIPHER_PARAM_AEAD_TAGLEN */
181
0
                                if (ossl_unlikely(r->taglen != NULL)) {
182
0
                                    ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
183
0
                                                   "param %s is repeated", s);
184
0
                                    return 0;
185
0
                                }
186
0
                                r->taglen = (OSSL_PARAM *)p;
187
0
                            }
188
0
                            break;
189
0
                        case '\0':
190
0
                            if (ossl_unlikely(r->tag != NULL)) {
191
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
192
0
                                               "param %s is repeated", s);
193
0
                                return 0;
194
0
                            }
195
0
                            r->tag = (OSSL_PARAM *)p;
196
0
                        }
197
0
                    }
198
0
                }
199
0
                break;
200
0
            case 'u':
201
0
                if (ossl_likely(strcmp("pdated-iv", s + 1) == 0)) {
202
                    /* OSSL_CIPHER_PARAM_UPDATED_IV */
203
0
                    if (ossl_unlikely(r->upd_iv != NULL)) {
204
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
205
0
                                       "param %s is repeated", s);
206
0
                        return 0;
207
0
                    }
208
0
                    r->upd_iv = (OSSL_PARAM *)p;
209
0
                }
210
0
            }
211
0
    return 1;
212
0
}
213
#endif
214
/* End of machine generated */