Coverage Report

Created: 2025-11-07 06:58

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