/src/openssl/providers/implementations/include/prov/digestcommon.h
Line | Count | Source |
1 | | /* |
2 | | * Copyright 2019-2026 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 | | #ifndef OSSL_PROVIDERS_DIGESTCOMMON_H |
11 | | #define OSSL_PROVIDERS_DIGESTCOMMON_H |
12 | | |
13 | | #include <openssl/core_dispatch.h> |
14 | | #include <openssl/core_names.h> |
15 | | #include <openssl/params.h> |
16 | | #include "prov/providercommon.h" |
17 | | |
18 | | /* Internal flags that can be queried */ |
19 | 132 | #define PROV_DIGEST_FLAG_XOF 0x0001 |
20 | 136 | #define PROV_DIGEST_FLAG_ALGID_ABSENT 0x0002 |
21 | | |
22 | | #ifdef __cplusplus |
23 | | extern "C" { |
24 | | #endif |
25 | | |
26 | | #define PROV_FUNC_DIGEST_GET_PARAM(name, blksize, dgstsize, flags) \ |
27 | | static OSSL_FUNC_digest_get_params_fn name##_get_params; \ |
28 | | static int name##_get_params(OSSL_PARAM params[]) \ |
29 | 120 | { \ |
30 | 120 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ |
31 | 120 | } cshake_prov.c:cshake_128_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
cshake_prov.c:cshake_256_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
md5_prov.c:md5_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
md5_sha1_prov.c:md5_sha1_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
null_prov.c:nullmd_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
ripemd_prov.c:ripemd160_get_params Line | Count | Source | 29 | 7 | { \ | 30 | 7 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 7 | } |
sha2_prov.c:sha1_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha2_prov.c:sha224_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha2_prov.c:sha256_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha2_prov.c:sha256_192_internal_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha2_prov.c:sha384_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha2_prov.c:sha512_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha2_prov.c:sha512_224_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha2_prov.c:sha512_256_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha3_prov.c:sha3_224_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha3_prov.c:sha3_256_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha3_prov.c:sha3_384_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha3_prov.c:sha3_512_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha3_prov.c:keccak_224_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha3_prov.c:keccak_256_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha3_prov.c:keccak_384_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha3_prov.c:keccak_512_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha3_prov.c:shake_128_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha3_prov.c:shake_256_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha3_prov.c:cshake_keccak_128_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sha3_prov.c:cshake_keccak_256_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
sm3_prov.c:sm3_get_params Line | Count | Source | 29 | 4 | { \ | 30 | 4 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 4 | } |
md4_prov.c:md4_get_params Line | Count | Source | 29 | 3 | { \ | 30 | 3 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 3 | } |
mdc2_prov.c:mdc2_get_params Line | Count | Source | 29 | 3 | { \ | 30 | 3 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 3 | } |
Line | Count | Source | 29 | 3 | { \ | 30 | 3 | return ossl_digest_default_get_params(params, blksize, dgstsize, flags); \ | 31 | 3 | } |
|
32 | | |
33 | | #define PROV_DISPATCH_FUNC_DIGEST_GET_PARAMS(name) \ |
34 | | { OSSL_FUNC_DIGEST_GET_PARAMS, (void (*)(void))name##_get_params }, \ |
35 | | { \ |
36 | | OSSL_FUNC_DIGEST_GETTABLE_PARAMS, \ |
37 | | (void (*)(void))ossl_digest_default_gettable_params \ |
38 | | } |
39 | | |
40 | | #define PROV_FUNC_DIGEST_FINAL(name, dgstsize, fin) \ |
41 | | static OSSL_FUNC_digest_final_fn name##_internal_final; \ |
42 | | static int name##_internal_final(void *ctx, unsigned char *out, size_t *outl, \ |
43 | | size_t outsz) \ |
44 | 17.4k | { \ |
45 | 17.4k | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ |
46 | 17.4k | *outl = dgstsize; \ |
47 | 17.4k | return 1; \ |
48 | 17.4k | } \ |
49 | 17.4k | return 0; \ |
50 | 17.4k | } md5_prov.c:md5_internal_final Line | Count | Source | 44 | 58 | { \ | 45 | 58 | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 58 | *outl = dgstsize; \ | 47 | 58 | return 1; \ | 48 | 58 | } \ | 49 | 58 | return 0; \ | 50 | 58 | } |
md5_sha1_prov.c:md5_sha1_internal_final Line | Count | Source | 44 | 20 | { \ | 45 | 20 | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 20 | *outl = dgstsize; \ | 47 | 20 | return 1; \ | 48 | 20 | } \ | 49 | 20 | return 0; \ | 50 | 20 | } |
ripemd_prov.c:ripemd160_internal_final Line | Count | Source | 44 | 51 | { \ | 45 | 51 | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 51 | *outl = dgstsize; \ | 47 | 51 | return 1; \ | 48 | 51 | } \ | 49 | 51 | return 0; \ | 50 | 51 | } |
sha2_prov.c:sha1_internal_final Line | Count | Source | 44 | 66 | { \ | 45 | 66 | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 66 | *outl = dgstsize; \ | 47 | 66 | return 1; \ | 48 | 66 | } \ | 49 | 66 | return 0; \ | 50 | 66 | } |
sha2_prov.c:sha224_internal_final Line | Count | Source | 44 | 31 | { \ | 45 | 31 | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 31 | *outl = dgstsize; \ | 47 | 31 | return 1; \ | 48 | 31 | } \ | 49 | 31 | return 0; \ | 50 | 31 | } |
sha2_prov.c:sha256_internal_final Line | Count | Source | 44 | 13.7k | { \ | 45 | 13.7k | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 13.7k | *outl = dgstsize; \ | 47 | 13.7k | return 1; \ | 48 | 13.7k | } \ | 49 | 13.7k | return 0; \ | 50 | 13.7k | } |
sha2_prov.c:sha256_192_internal_internal_final Line | Count | Source | 44 | 1 | { \ | 45 | 1 | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 1 | *outl = dgstsize; \ | 47 | 1 | return 1; \ | 48 | 1 | } \ | 49 | 1 | return 0; \ | 50 | 1 | } |
sha2_prov.c:sha384_internal_final Line | Count | Source | 44 | 9 | { \ | 45 | 9 | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 9 | *outl = dgstsize; \ | 47 | 9 | return 1; \ | 48 | 9 | } \ | 49 | 9 | return 0; \ | 50 | 9 | } |
sha2_prov.c:sha512_internal_final Line | Count | Source | 44 | 3.28k | { \ | 45 | 3.28k | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 3.28k | *outl = dgstsize; \ | 47 | 3.28k | return 1; \ | 48 | 3.28k | } \ | 49 | 3.28k | return 0; \ | 50 | 3.28k | } |
sha2_prov.c:sha512_224_internal_final Line | Count | Source | 44 | 1 | { \ | 45 | 1 | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 1 | *outl = dgstsize; \ | 47 | 1 | return 1; \ | 48 | 1 | } \ | 49 | 1 | return 0; \ | 50 | 1 | } |
sha2_prov.c:sha512_256_internal_final Line | Count | Source | 44 | 1 | { \ | 45 | 1 | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 1 | *outl = dgstsize; \ | 47 | 1 | return 1; \ | 48 | 1 | } \ | 49 | 1 | return 0; \ | 50 | 1 | } |
sm3_prov.c:sm3_internal_final Line | Count | Source | 44 | 85 | { \ | 45 | 85 | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 85 | *outl = dgstsize; \ | 47 | 85 | return 1; \ | 48 | 85 | } \ | 49 | 85 | return 0; \ | 50 | 85 | } |
md4_prov.c:md4_internal_final Line | Count | Source | 44 | 50 | { \ | 45 | 50 | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 50 | *outl = dgstsize; \ | 47 | 50 | return 1; \ | 48 | 50 | } \ | 49 | 50 | return 0; \ | 50 | 50 | } |
mdc2_prov.c:mdc2_internal_final Line | Count | Source | 44 | 23 | { \ | 45 | 23 | if (ossl_prov_is_running() && outsz >= dgstsize && fin(out, ctx)) { \ | 46 | 23 | *outl = dgstsize; \ | 47 | 23 | return 1; \ | 48 | 23 | } \ | 49 | 23 | return 0; \ | 50 | 23 | } |
Unexecuted instantiation: wp_prov.c:wp_internal_final |
51 | | |
52 | | #if defined(FIPS_MODULE) |
53 | | #include "internal/fips.h" |
54 | | #include "prov/provider_ctx.h" |
55 | | #define DIGEST_PROV_CHECK(provctx, name) \ |
56 | | if (!ossl_prov_is_running()) \ |
57 | | return NULL; \ |
58 | | if (!ossl_deferred_self_test(PROV_LIBCTX_OF(provctx), \ |
59 | | ST_ID_DIGEST_##name)) \ |
60 | | return NULL |
61 | | #else |
62 | | #define DIGEST_PROV_CHECK(_provctx, _name) \ |
63 | 17.8k | if (!ossl_prov_is_running()) \ |
64 | 17.8k | return NULL |
65 | | #endif /* FIPS_MODULE && DIGEST_IS_FIPS */ |
66 | | |
67 | | #define PROV_DISPATCH_FUNC_DIGEST_CONSTRUCT_START( \ |
68 | | name, CTX, blksize, dgstsize, flags, upd, fin) \ |
69 | | static OSSL_FUNC_digest_newctx_fn name##_newctx; \ |
70 | | static OSSL_FUNC_digest_freectx_fn name##_freectx; \ |
71 | | static OSSL_FUNC_digest_dupctx_fn name##_dupctx; \ |
72 | | static void *name##_newctx(void *prov_ctx) \ |
73 | 17.8k | { \ |
74 | 17.8k | DIGEST_PROV_CHECK(prov_ctx, name); \ |
75 | 17.8k | return OPENSSL_zalloc(sizeof(CTX)); \ |
76 | 17.8k | } \ |
77 | | static void name##_freectx(void *vctx) \ |
78 | 17.8k | { \ |
79 | 17.8k | CTX *ctx = (CTX *)vctx; \ |
80 | 17.8k | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ |
81 | 17.8k | } \ Line | Count | Source | 78 | 58 | { \ | 79 | 58 | CTX *ctx = (CTX *)vctx; \ | 80 | 58 | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 58 | } \ |
md5_sha1_prov.c:md5_sha1_freectx Line | Count | Source | 78 | 20 | { \ | 79 | 20 | CTX *ctx = (CTX *)vctx; \ | 80 | 20 | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 20 | } \ |
Unexecuted instantiation: null_prov.c:nullmd_freectx ripemd_prov.c:ripemd160_freectx Line | Count | Source | 78 | 51 | { \ | 79 | 51 | CTX *ctx = (CTX *)vctx; \ | 80 | 51 | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 51 | } \ |
Line | Count | Source | 78 | 66 | { \ | 79 | 66 | CTX *ctx = (CTX *)vctx; \ | 80 | 66 | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 66 | } \ |
sha2_prov.c:sha224_freectx Line | Count | Source | 78 | 31 | { \ | 79 | 31 | CTX *ctx = (CTX *)vctx; \ | 80 | 31 | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 31 | } \ |
sha2_prov.c:sha256_freectx Line | Count | Source | 78 | 14.1k | { \ | 79 | 14.1k | CTX *ctx = (CTX *)vctx; \ | 80 | 14.1k | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 14.1k | } \ |
sha2_prov.c:sha256_192_internal_freectx Line | Count | Source | 78 | 1 | { \ | 79 | 1 | CTX *ctx = (CTX *)vctx; \ | 80 | 1 | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 1 | } \ |
sha2_prov.c:sha384_freectx Line | Count | Source | 78 | 9 | { \ | 79 | 9 | CTX *ctx = (CTX *)vctx; \ | 80 | 9 | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 9 | } \ |
sha2_prov.c:sha512_freectx Line | Count | Source | 78 | 3.28k | { \ | 79 | 3.28k | CTX *ctx = (CTX *)vctx; \ | 80 | 3.28k | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 3.28k | } \ |
sha2_prov.c:sha512_224_freectx Line | Count | Source | 78 | 1 | { \ | 79 | 1 | CTX *ctx = (CTX *)vctx; \ | 80 | 1 | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 1 | } \ |
sha2_prov.c:sha512_256_freectx Line | Count | Source | 78 | 1 | { \ | 79 | 1 | CTX *ctx = (CTX *)vctx; \ | 80 | 1 | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 1 | } \ |
Line | Count | Source | 78 | 85 | { \ | 79 | 85 | CTX *ctx = (CTX *)vctx; \ | 80 | 85 | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 85 | } \ |
Line | Count | Source | 78 | 50 | { \ | 79 | 50 | CTX *ctx = (CTX *)vctx; \ | 80 | 50 | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 50 | } \ |
Line | Count | Source | 78 | 23 | { \ | 79 | 23 | CTX *ctx = (CTX *)vctx; \ | 80 | 23 | OPENSSL_clear_free(ctx, sizeof(*ctx)); \ | 81 | 23 | } \ |
Unexecuted instantiation: wp_prov.c:wp_freectx |
82 | | static void *name##_dupctx(void *ctx) \ |
83 | 0 | { \ |
84 | 0 | CTX *in = (CTX *)ctx; \ |
85 | 0 | CTX *ret = ossl_prov_is_running() ? OPENSSL_malloc(sizeof(*ret)) : NULL; \ |
86 | 0 | if (ret != NULL) \ |
87 | 0 | *ret = *in; \ |
88 | 0 | return ret; \ |
89 | 0 | } \ |
90 | | static void name##_copyctx(void *voutctx, void *vinctx) \ |
91 | 0 | { \ |
92 | 0 | CTX *outctx = (CTX *)voutctx; \ |
93 | 0 | CTX *inctx = (CTX *)vinctx; \ |
94 | 0 | *outctx = *inctx; \ |
95 | 0 | } \ Unexecuted instantiation: md5_prov.c:md5_copyctx Unexecuted instantiation: md5_sha1_prov.c:md5_sha1_copyctx Unexecuted instantiation: null_prov.c:nullmd_copyctx Unexecuted instantiation: ripemd_prov.c:ripemd160_copyctx Unexecuted instantiation: sha2_prov.c:sha1_copyctx Unexecuted instantiation: sha2_prov.c:sha224_copyctx Unexecuted instantiation: sha2_prov.c:sha256_copyctx Unexecuted instantiation: sha2_prov.c:sha256_192_internal_copyctx Unexecuted instantiation: sha2_prov.c:sha384_copyctx Unexecuted instantiation: sha2_prov.c:sha512_copyctx Unexecuted instantiation: sha2_prov.c:sha512_224_copyctx Unexecuted instantiation: sha2_prov.c:sha512_256_copyctx Unexecuted instantiation: sm3_prov.c:sm3_copyctx Unexecuted instantiation: md4_prov.c:md4_copyctx Unexecuted instantiation: mdc2_prov.c:mdc2_copyctx Unexecuted instantiation: wp_prov.c:wp_copyctx |
96 | | PROV_FUNC_DIGEST_FINAL(name, dgstsize, fin) \ |
97 | | PROV_FUNC_DIGEST_GET_PARAM(name, blksize, dgstsize, flags) \ |
98 | | const OSSL_DISPATCH ossl_##name##_functions[] = { \ |
99 | | { OSSL_FUNC_DIGEST_NEWCTX, (void (*)(void))name##_newctx }, \ |
100 | | { OSSL_FUNC_DIGEST_UPDATE, (void (*)(void))upd }, \ |
101 | | { OSSL_FUNC_DIGEST_FINAL, (void (*)(void))name##_internal_final }, \ |
102 | | { OSSL_FUNC_DIGEST_FREECTX, (void (*)(void))name##_freectx }, \ |
103 | | { OSSL_FUNC_DIGEST_DUPCTX, (void (*)(void))name##_dupctx }, \ |
104 | | { OSSL_FUNC_DIGEST_COPYCTX, (void (*)(void))name##_copyctx }, \ |
105 | | PROV_DISPATCH_FUNC_DIGEST_GET_PARAMS(name) |
106 | | |
107 | | #define PROV_DISPATCH_FUNC_DIGEST_CONSTRUCT_END \ |
108 | | { \ |
109 | | 0, NULL \ |
110 | | } \ |
111 | | } \ |
112 | | ; |
113 | | |
114 | | #define IMPLEMENT_digest_functions( \ |
115 | | name, CTX, blksize, dgstsize, flags, init, upd, fin) \ |
116 | | static OSSL_FUNC_digest_init_fn name##_internal_init; \ |
117 | | static int name##_internal_init(void *ctx, \ |
118 | | ossl_unused const OSSL_PARAM params[]) \ |
119 | 488 | { \ |
120 | 488 | return ossl_prov_is_running() && init(ctx); \ |
121 | 488 | } \ md5_prov.c:md5_internal_init Line | Count | Source | 119 | 116 | { \ | 120 | 116 | return ossl_prov_is_running() && init(ctx); \ | 121 | 116 | } \ |
Unexecuted instantiation: null_prov.c:nullmd_internal_init ripemd_prov.c:ripemd160_internal_init Line | Count | Source | 119 | 102 | { \ | 120 | 102 | return ossl_prov_is_running() && init(ctx); \ | 121 | 102 | } \ |
sm3_prov.c:sm3_internal_init Line | Count | Source | 119 | 170 | { \ | 120 | 170 | return ossl_prov_is_running() && init(ctx); \ | 121 | 170 | } \ |
md4_prov.c:md4_internal_init Line | Count | Source | 119 | 100 | { \ | 120 | 100 | return ossl_prov_is_running() && init(ctx); \ | 121 | 100 | } \ |
Unexecuted instantiation: wp_prov.c:wp_internal_init |
122 | | PROV_DISPATCH_FUNC_DIGEST_CONSTRUCT_START(name, CTX, blksize, dgstsize, flags, \ |
123 | | upd, fin), \ |
124 | | { OSSL_FUNC_DIGEST_INIT, (void (*)(void))name##_internal_init }, \ |
125 | | PROV_DISPATCH_FUNC_DIGEST_CONSTRUCT_END |
126 | | |
127 | | #define IMPLEMENT_digest_functions_with_settable_ctx( \ |
128 | | name, CTX, blksize, dgstsize, flags, init, upd, fin, \ |
129 | | settable_ctx_params, set_ctx_params) \ |
130 | | static OSSL_FUNC_digest_init_fn name##_internal_init; \ |
131 | | static int name##_internal_init(void *ctx, const OSSL_PARAM params[]) \ |
132 | 218 | { \ |
133 | 218 | return ossl_prov_is_running() \ |
134 | 218 | && init(ctx) \ |
135 | 218 | && set_ctx_params(ctx, params); \ |
136 | 218 | } \ md5_sha1_prov.c:md5_sha1_internal_init Line | Count | Source | 132 | 40 | { \ | 133 | 40 | return ossl_prov_is_running() \ | 134 | 40 | && init(ctx) \ | 135 | 40 | && set_ctx_params(ctx, params); \ | 136 | 40 | } \ |
sha2_prov.c:sha1_internal_init Line | Count | Source | 132 | 132 | { \ | 133 | 132 | return ossl_prov_is_running() \ | 134 | 132 | && init(ctx) \ | 135 | 132 | && set_ctx_params(ctx, params); \ | 136 | 132 | } \ |
mdc2_prov.c:mdc2_internal_init Line | Count | Source | 132 | 46 | { \ | 133 | 46 | return ossl_prov_is_running() \ | 134 | 46 | && init(ctx) \ | 135 | 46 | && set_ctx_params(ctx, params); \ | 136 | 46 | } \ |
|
137 | | PROV_DISPATCH_FUNC_DIGEST_CONSTRUCT_START(name, CTX, blksize, dgstsize, flags, \ |
138 | | upd, fin), \ |
139 | | { OSSL_FUNC_DIGEST_INIT, (void (*)(void))name##_internal_init }, \ |
140 | | { OSSL_FUNC_DIGEST_SETTABLE_CTX_PARAMS, (void (*)(void))settable_ctx_params }, \ |
141 | | { OSSL_FUNC_DIGEST_SET_CTX_PARAMS, (void (*)(void))set_ctx_params }, \ |
142 | | PROV_DISPATCH_FUNC_DIGEST_CONSTRUCT_END |
143 | | |
144 | | #define IMPLEMENT_digest_functions_with_serialize( \ |
145 | | name, CTX, blksize, dgstsize, flags, init, upd, fin, \ |
146 | | serialize, deserialize) \ |
147 | | static OSSL_FUNC_digest_init_fn name##_internal_init; \ |
148 | | static int name##_internal_init(void *ctx, const OSSL_PARAM params[]) \ |
149 | 34.5k | { \ |
150 | 34.5k | return ossl_prov_is_running() && init(ctx); \ |
151 | 34.5k | } \ sha2_prov.c:sha224_internal_init Line | Count | Source | 149 | 62 | { \ | 150 | 62 | return ossl_prov_is_running() && init(ctx); \ | 151 | 62 | } \ |
sha2_prov.c:sha256_internal_init Line | Count | Source | 149 | 27.9k | { \ | 150 | 27.9k | return ossl_prov_is_running() && init(ctx); \ | 151 | 27.9k | } \ |
sha2_prov.c:sha256_192_internal_internal_init Line | Count | Source | 149 | 2 | { \ | 150 | 2 | return ossl_prov_is_running() && init(ctx); \ | 151 | 2 | } \ |
sha2_prov.c:sha384_internal_init Line | Count | Source | 149 | 18 | { \ | 150 | 18 | return ossl_prov_is_running() && init(ctx); \ | 151 | 18 | } \ |
sha2_prov.c:sha512_internal_init Line | Count | Source | 149 | 6.57k | { \ | 150 | 6.57k | return ossl_prov_is_running() && init(ctx); \ | 151 | 6.57k | } \ |
sha2_prov.c:sha512_224_internal_init Line | Count | Source | 149 | 2 | { \ | 150 | 2 | return ossl_prov_is_running() && init(ctx); \ | 151 | 2 | } \ |
sha2_prov.c:sha512_256_internal_init Line | Count | Source | 149 | 2 | { \ | 150 | 2 | return ossl_prov_is_running() && init(ctx); \ | 151 | 2 | } \ |
|
152 | | PROV_DISPATCH_FUNC_DIGEST_CONSTRUCT_START(name, CTX, blksize, dgstsize, flags, \ |
153 | | upd, fin), \ |
154 | | { OSSL_FUNC_DIGEST_INIT, (void (*)(void))name##_internal_init }, \ |
155 | | { OSSL_FUNC_DIGEST_SERIALIZE, (void (*)(void))serialize }, \ |
156 | | { OSSL_FUNC_DIGEST_DESERIALIZE, (void (*)(void))deserialize }, \ |
157 | | PROV_DISPATCH_FUNC_DIGEST_CONSTRUCT_END |
158 | | |
159 | | const OSSL_PARAM *ossl_digest_default_gettable_params(void *provctx); |
160 | | int ossl_digest_default_get_params(OSSL_PARAM params[], size_t blksz, |
161 | | size_t paramsz, unsigned long flags); |
162 | | |
163 | | #ifdef __cplusplus |
164 | | } |
165 | | #endif |
166 | | |
167 | | #endif /* OSSL_PROVIDERS_DIGESTCOMMON_H */ |