Coverage Report

Created: 2025-10-28 06:56

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl/providers/implementations/ciphers/ciphercommon_ccm.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 ossl_cipher_ccm_set_ctx_params_list
14
static const OSSL_PARAM ossl_cipher_ccm_set_ctx_params_list[] = {
15
    OSSL_PARAM_size_t(OSSL_CIPHER_PARAM_AEAD_IVLEN, NULL),
16
    OSSL_PARAM_octet_string(OSSL_CIPHER_PARAM_AEAD_TAG, NULL, 0),
17
    OSSL_PARAM_octet_string(OSSL_CIPHER_PARAM_AEAD_TLS1_AAD, NULL, 0),
18
    OSSL_PARAM_octet_string(OSSL_CIPHER_PARAM_AEAD_TLS1_IV_FIXED, NULL, 0),
19
    OSSL_PARAM_END
20
};
21
#endif
22
23
#ifndef ossl_cipher_ccm_set_ctx_params_st
24
struct ossl_cipher_ccm_set_ctx_params_st {
25
    OSSL_PARAM *aad;
26
    OSSL_PARAM *fixed;
27
    OSSL_PARAM *ivlen;
28
    OSSL_PARAM *tag;
29
};
30
#endif
31
32
#ifndef ossl_cipher_ccm_set_ctx_params_decoder
33
static int ossl_cipher_ccm_set_ctx_params_decoder
34
    (const OSSL_PARAM *p, struct ossl_cipher_ccm_set_ctx_params_st *r)
35
0
{
36
0
    const char *s;
37
38
0
    memset(r, 0, sizeof(*r));
39
0
    if (p != NULL)
40
0
        for (; (s = p->key) != NULL; p++)
41
0
            switch(s[0]) {
42
0
            default:
43
0
                break;
44
0
            case 'i':
45
0
                if (ossl_likely(strcmp("vlen", s + 1) == 0)) {
46
                    /* OSSL_CIPHER_PARAM_AEAD_IVLEN */
47
0
                    if (ossl_unlikely(r->ivlen != NULL)) {
48
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
49
0
                                       "param %s is repeated", s);
50
0
                        return 0;
51
0
                    }
52
0
                    r->ivlen = (OSSL_PARAM *)p;
53
0
                }
54
0
                break;
55
0
            case 't':
56
0
                switch(s[1]) {
57
0
                default:
58
0
                    break;
59
0
                case 'a':
60
0
                    if (ossl_likely(strcmp("g", s + 2) == 0)) {
61
                        /* OSSL_CIPHER_PARAM_AEAD_TAG */
62
0
                        if (ossl_unlikely(r->tag != NULL)) {
63
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
64
0
                                           "param %s is repeated", s);
65
0
                            return 0;
66
0
                        }
67
0
                        r->tag = (OSSL_PARAM *)p;
68
0
                    }
69
0
                    break;
70
0
                case 'l':
71
0
                    switch(s[2]) {
72
0
                    default:
73
0
                        break;
74
0
                    case 's':
75
0
                        switch(s[3]) {
76
0
                        default:
77
0
                            break;
78
0
                        case 'a':
79
0
                            if (ossl_likely(strcmp("ad", s + 4) == 0)) {
80
                                /* OSSL_CIPHER_PARAM_AEAD_TLS1_AAD */
81
0
                                if (ossl_unlikely(r->aad != NULL)) {
82
0
                                    ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
83
0
                                                   "param %s is repeated", s);
84
0
                                    return 0;
85
0
                                }
86
0
                                r->aad = (OSSL_PARAM *)p;
87
0
                            }
88
0
                            break;
89
0
                        case 'i':
90
0
                            if (ossl_likely(strcmp("vfixed", s + 4) == 0)) {
91
                                /* OSSL_CIPHER_PARAM_AEAD_TLS1_IV_FIXED */
92
0
                                if (ossl_unlikely(r->fixed != NULL)) {
93
0
                                    ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
94
0
                                                   "param %s is repeated", s);
95
0
                                    return 0;
96
0
                                }
97
0
                                r->fixed = (OSSL_PARAM *)p;
98
0
                            }
99
0
                        }
100
0
                    }
101
0
                }
102
0
            }
103
0
    return 1;
104
0
}
105
#endif
106
/* End of machine generated */
107
108
/* Machine generated by util/perl/OpenSSL/paramnames.pm */
109
#ifndef ossl_cipher_ccm_get_ctx_params_list
110
static const OSSL_PARAM ossl_cipher_ccm_get_ctx_params_list[] = {
111
    OSSL_PARAM_size_t(OSSL_CIPHER_PARAM_KEYLEN, NULL),
112
    OSSL_PARAM_size_t(OSSL_CIPHER_PARAM_IVLEN, NULL),
113
    OSSL_PARAM_size_t(OSSL_CIPHER_PARAM_AEAD_TAGLEN, NULL),
114
    OSSL_PARAM_octet_string(OSSL_CIPHER_PARAM_IV, NULL, 0),
115
    OSSL_PARAM_octet_string(OSSL_CIPHER_PARAM_UPDATED_IV, NULL, 0),
116
    OSSL_PARAM_octet_string(OSSL_CIPHER_PARAM_AEAD_TAG, NULL, 0),
117
    OSSL_PARAM_size_t(OSSL_CIPHER_PARAM_AEAD_TLS1_AAD_PAD, NULL),
118
    OSSL_PARAM_END
119
};
120
#endif
121
122
#ifndef ossl_cipher_ccm_get_ctx_params_st
123
struct ossl_cipher_ccm_get_ctx_params_st {
124
    OSSL_PARAM *iv;
125
    OSSL_PARAM *ivlen;
126
    OSSL_PARAM *keylen;
127
    OSSL_PARAM *pad;
128
    OSSL_PARAM *tag;
129
    OSSL_PARAM *taglen;
130
    OSSL_PARAM *updiv;
131
};
132
#endif
133
134
#ifndef ossl_cipher_ccm_get_ctx_params_decoder
135
static int ossl_cipher_ccm_get_ctx_params_decoder
136
    (const OSSL_PARAM *p, struct ossl_cipher_ccm_get_ctx_params_st *r)
137
0
{
138
0
    const char *s;
139
140
0
    memset(r, 0, sizeof(*r));
141
0
    if (p != NULL)
142
0
        for (; (s = p->key) != NULL; p++)
143
0
            switch(s[0]) {
144
0
            default:
145
0
                break;
146
0
            case 'i':
147
0
                switch(s[1]) {
148
0
                default:
149
0
                    break;
150
0
                case 'v':
151
0
                    switch(s[2]) {
152
0
                    default:
153
0
                        break;
154
0
                    case 'l':
155
0
                        if (ossl_likely(strcmp("en", s + 3) == 0)) {
156
                            /* OSSL_CIPHER_PARAM_IVLEN */
157
0
                            if (ossl_unlikely(r->ivlen != NULL)) {
158
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
159
0
                                               "param %s is repeated", s);
160
0
                                return 0;
161
0
                            }
162
0
                            r->ivlen = (OSSL_PARAM *)p;
163
0
                        }
164
0
                        break;
165
0
                    case '\0':
166
0
                        if (ossl_unlikely(r->iv != 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->iv = (OSSL_PARAM *)p;
172
0
                    }
173
0
                }
174
0
                break;
175
0
            case 'k':
176
0
                if (ossl_likely(strcmp("eylen", s + 1) == 0)) {
177
                    /* OSSL_CIPHER_PARAM_KEYLEN */
178
0
                    if (ossl_unlikely(r->keylen != NULL)) {
179
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
180
0
                                       "param %s is repeated", s);
181
0
                        return 0;
182
0
                    }
183
0
                    r->keylen = (OSSL_PARAM *)p;
184
0
                }
185
0
                break;
186
0
            case 't':
187
0
                switch(s[1]) {
188
0
                default:
189
0
                    break;
190
0
                case 'a':
191
0
                    switch(s[2]) {
192
0
                    default:
193
0
                        break;
194
0
                    case 'g':
195
0
                        switch(s[3]) {
196
0
                        default:
197
0
                            break;
198
0
                        case 'l':
199
0
                            if (ossl_likely(strcmp("en", s + 4) == 0)) {
200
                                /* OSSL_CIPHER_PARAM_AEAD_TAGLEN */
201
0
                                if (ossl_unlikely(r->taglen != NULL)) {
202
0
                                    ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
203
0
                                                   "param %s is repeated", s);
204
0
                                    return 0;
205
0
                                }
206
0
                                r->taglen = (OSSL_PARAM *)p;
207
0
                            }
208
0
                            break;
209
0
                        case '\0':
210
0
                            if (ossl_unlikely(r->tag != NULL)) {
211
0
                                ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
212
0
                                               "param %s is repeated", s);
213
0
                                return 0;
214
0
                            }
215
0
                            r->tag = (OSSL_PARAM *)p;
216
0
                        }
217
0
                    }
218
0
                    break;
219
0
                case 'l':
220
0
                    if (ossl_likely(strcmp("saadpad", s + 2) == 0)) {
221
                        /* OSSL_CIPHER_PARAM_AEAD_TLS1_AAD_PAD */
222
0
                        if (ossl_unlikely(r->pad != NULL)) {
223
0
                            ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
224
0
                                           "param %s is repeated", s);
225
0
                            return 0;
226
0
                        }
227
0
                        r->pad = (OSSL_PARAM *)p;
228
0
                    }
229
0
                }
230
0
                break;
231
0
            case 'u':
232
0
                if (ossl_likely(strcmp("pdated-iv", s + 1) == 0)) {
233
                    /* OSSL_CIPHER_PARAM_UPDATED_IV */
234
0
                    if (ossl_unlikely(r->updiv != NULL)) {
235
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
236
0
                                       "param %s is repeated", s);
237
0
                        return 0;
238
0
                    }
239
0
                    r->updiv = (OSSL_PARAM *)p;
240
0
                }
241
0
            }
242
0
    return 1;
243
0
}
244
#endif
245
/* End of machine generated */