Coverage Report

Created: 2026-05-20 07:05

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