Coverage Report

Created: 2025-10-28 06:56

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl/providers/implementations/digests/digestcommon.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 digest_default_get_params_list
14
static const OSSL_PARAM digest_default_get_params_list[] = {
15
    OSSL_PARAM_size_t(OSSL_DIGEST_PARAM_BLOCK_SIZE, NULL),
16
    OSSL_PARAM_size_t(OSSL_DIGEST_PARAM_SIZE, NULL),
17
    OSSL_PARAM_int(OSSL_DIGEST_PARAM_XOF, NULL),
18
    OSSL_PARAM_int(OSSL_DIGEST_PARAM_ALGID_ABSENT, NULL),
19
    OSSL_PARAM_END
20
};
21
#endif
22
23
#ifndef digest_default_get_params_st
24
struct digest_default_get_params_st {
25
    OSSL_PARAM *aldid;
26
    OSSL_PARAM *bsize;
27
    OSSL_PARAM *size;
28
    OSSL_PARAM *xof;
29
};
30
#endif
31
32
#ifndef digest_default_get_params_decoder
33
static int digest_default_get_params_decoder
34
    (const OSSL_PARAM *p, struct digest_default_get_params_st *r)
35
432
{
36
432
    const char *s;
37
38
432
    memset(r, 0, sizeof(*r));
39
432
    if (p != NULL)
40
2.16k
        for (; (s = p->key) != NULL; p++)
41
1.72k
            switch(s[0]) {
42
0
            default:
43
0
                break;
44
432
            case 'a':
45
432
                if (ossl_likely(strcmp("lgid-absent", s + 1) == 0)) {
46
                    /* OSSL_DIGEST_PARAM_ALGID_ABSENT */
47
432
                    if (ossl_unlikely(r->aldid != 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
432
                    r->aldid = (OSSL_PARAM *)p;
53
432
                }
54
432
                break;
55
432
            case 'b':
56
432
                if (ossl_likely(strcmp("locksize", s + 1) == 0)) {
57
                    /* OSSL_DIGEST_PARAM_BLOCK_SIZE */
58
432
                    if (ossl_unlikely(r->bsize != NULL)) {
59
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
60
0
                                       "param %s is repeated", s);
61
0
                        return 0;
62
0
                    }
63
432
                    r->bsize = (OSSL_PARAM *)p;
64
432
                }
65
432
                break;
66
432
            case 's':
67
432
                if (ossl_likely(strcmp("ize", s + 1) == 0)) {
68
                    /* OSSL_DIGEST_PARAM_SIZE */
69
432
                    if (ossl_unlikely(r->size != NULL)) {
70
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
71
0
                                       "param %s is repeated", s);
72
0
                        return 0;
73
0
                    }
74
432
                    r->size = (OSSL_PARAM *)p;
75
432
                }
76
432
                break;
77
432
            case 'x':
78
432
                if (ossl_likely(strcmp("of", s + 1) == 0)) {
79
                    /* OSSL_DIGEST_PARAM_XOF */
80
432
                    if (ossl_unlikely(r->xof != NULL)) {
81
0
                        ERR_raise_data(ERR_LIB_PROV, PROV_R_REPEATED_PARAMETER,
82
0
                                       "param %s is repeated", s);
83
0
                        return 0;
84
0
                    }
85
432
                    r->xof = (OSSL_PARAM *)p;
86
432
                }
87
1.72k
            }
88
432
    return 1;
89
432
}
90
#endif
91
/* End of machine generated */