]> git.ipfire.org Git - thirdparty/openssl.git/blame - include/openssl/self_test.h
Update util/analyze-contention-log.sh
[thirdparty/openssl.git] / include / openssl / self_test.h
CommitLineData
36fc5fc6 1/*
0c679f55 2 * Copyright 2019-2025 The OpenSSL Project Authors. All Rights Reserved.
36fc5fc6 3 *
a6ed19dc 4 * Licensed under the Apache License 2.0 (the "License"). You may not use
36fc5fc6
SL
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 OPENSSL_SELF_TEST_H
11# define OPENSSL_SELF_TEST_H
d59068bd 12# pragma once
36fc5fc6
SL
13
14# include <openssl/core.h> /* OSSL_CALLBACK */
15
16# ifdef __cplusplus
17extern "C" {
18# endif
19
20/* The test event phases */
21# define OSSL_SELF_TEST_PHASE_NONE "None"
22# define OSSL_SELF_TEST_PHASE_START "Start"
23# define OSSL_SELF_TEST_PHASE_CORRUPT "Corrupt"
24# define OSSL_SELF_TEST_PHASE_PASS "Pass"
25# define OSSL_SELF_TEST_PHASE_FAIL "Fail"
26
27/* Test event categories */
28# define OSSL_SELF_TEST_TYPE_NONE "None"
29# define OSSL_SELF_TEST_TYPE_MODULE_INTEGRITY "Module_Integrity"
30# define OSSL_SELF_TEST_TYPE_INSTALL_INTEGRITY "Install_Integrity"
35e6ea3b 31# define OSSL_SELF_TEST_TYPE_CRNG "Continuous_RNG_Test"
55950587 32# define OSSL_SELF_TEST_TYPE_PCT "Conditional_PCT"
a11064c8
P
33# define OSSL_SELF_TEST_TYPE_PCT_KAT "Conditional_KAT"
34# define OSSL_SELF_TEST_TYPE_KAT_INTEGRITY "KAT_Integrity"
36fc5fc6 35# define OSSL_SELF_TEST_TYPE_KAT_CIPHER "KAT_Cipher"
4343a418 36# define OSSL_SELF_TEST_TYPE_KAT_ASYM_CIPHER "KAT_AsymmetricCipher"
756527b8 37# define OSSL_SELF_TEST_TYPE_KAT_ASYM_KEYGEN "KAT_AsymmetricKeyGeneration"
7057138f 38# define OSSL_SELF_TEST_TYPE_KAT_KEM "KAT_KEM"
36fc5fc6
SL
39# define OSSL_SELF_TEST_TYPE_KAT_DIGEST "KAT_Digest"
40# define OSSL_SELF_TEST_TYPE_KAT_SIGNATURE "KAT_Signature"
55950587 41# define OSSL_SELF_TEST_TYPE_PCT_SIGNATURE "PCT_Signature"
36fc5fc6
SL
42# define OSSL_SELF_TEST_TYPE_KAT_KDF "KAT_KDF"
43# define OSSL_SELF_TEST_TYPE_KAT_KA "KAT_KA"
44# define OSSL_SELF_TEST_TYPE_DRBG "DRBG"
45
46/* Test event sub categories */
47# define OSSL_SELF_TEST_DESC_NONE "None"
48# define OSSL_SELF_TEST_DESC_INTEGRITY_HMAC "HMAC"
6c39d21a 49# define OSSL_SELF_TEST_DESC_PCT_RSA "RSA"
36fc5fc6
SL
50# define OSSL_SELF_TEST_DESC_PCT_RSA_PKCS1 "RSA"
51# define OSSL_SELF_TEST_DESC_PCT_ECDSA "ECDSA"
fbce6ebf 52# define OSSL_SELF_TEST_DESC_PCT_EDDSA "EDDSA"
36fc5fc6 53# define OSSL_SELF_TEST_DESC_PCT_DSA "DSA"
51981460 54# define OSSL_SELF_TEST_DESC_PCT_ML_DSA "ML-DSA"
073b9f2b 55# define OSSL_SELF_TEST_DESC_PCT_ML_KEM "ML-KEM"
92a54f4d 56# define OSSL_SELF_TEST_DESC_PCT_SLH_DSA "SLH-DSA"
3b1978e4 57# define OSSL_SELF_TEST_DESC_CIPHER_AES_GCM "AES_GCM"
3fed2718 58# define OSSL_SELF_TEST_DESC_CIPHER_AES_ECB "AES_ECB_Decrypt"
36fc5fc6 59# define OSSL_SELF_TEST_DESC_CIPHER_TDES "TDES"
4343a418
SL
60# define OSSL_SELF_TEST_DESC_ASYM_RSA_ENC "RSA_Encrypt"
61# define OSSL_SELF_TEST_DESC_ASYM_RSA_DEC "RSA_Decrypt"
36fc5fc6
SL
62# define OSSL_SELF_TEST_DESC_MD_SHA1 "SHA1"
63# define OSSL_SELF_TEST_DESC_MD_SHA2 "SHA2"
64# define OSSL_SELF_TEST_DESC_MD_SHA3 "SHA3"
65# define OSSL_SELF_TEST_DESC_SIGN_DSA "DSA"
66# define OSSL_SELF_TEST_DESC_SIGN_RSA "RSA"
67# define OSSL_SELF_TEST_DESC_SIGN_ECDSA "ECDSA"
5f04124a 68# define OSSL_SELF_TEST_DESC_SIGN_EDDSA "EDDSA"
2b6dd886 69# define OSSL_SELF_TEST_DESC_SIGN_ML_DSA "ML-DSA"
92a54f4d 70# define OSSL_SELF_TEST_DESC_SIGN_SLH_DSA "SLH-DSA"
7057138f 71# define OSSL_SELF_TEST_DESC_KEM "KEM"
36fc5fc6
SL
72# define OSSL_SELF_TEST_DESC_DRBG_CTR "CTR"
73# define OSSL_SELF_TEST_DESC_DRBG_HASH "HASH"
74# define OSSL_SELF_TEST_DESC_DRBG_HMAC "HMAC"
ec4d1b8f 75# define OSSL_SELF_TEST_DESC_KA_DH "DH"
36fc5fc6 76# define OSSL_SELF_TEST_DESC_KA_ECDH "ECDH"
36fc5fc6 77# define OSSL_SELF_TEST_DESC_KDF_HKDF "HKDF"
ec4d1b8f 78# define OSSL_SELF_TEST_DESC_KDF_SSKDF "SSKDF"
acd3e548
SL
79# define OSSL_SELF_TEST_DESC_KDF_X963KDF "X963KDF"
80# define OSSL_SELF_TEST_DESC_KDF_X942KDF "X942KDF"
81# define OSSL_SELF_TEST_DESC_KDF_PBKDF2 "PBKDF2"
82# define OSSL_SELF_TEST_DESC_KDF_SSHKDF "SSHKDF"
83# define OSSL_SELF_TEST_DESC_KDF_TLS12_PRF "TLS12_PRF"
84# define OSSL_SELF_TEST_DESC_KDF_KBKDF "KBKDF"
3cb07553 85# define OSSL_SELF_TEST_DESC_KDF_KBKDF_KMAC "KBKDF_KMAC"
bf7c9011
P
86# define OSSL_SELF_TEST_DESC_KDF_TLS13_EXTRACT "TLS13_KDF_EXTRACT"
87# define OSSL_SELF_TEST_DESC_KDF_TLS13_EXPAND "TLS13_KDF_EXPAND"
7f9e7440 88# define OSSL_SELF_TEST_DESC_RNG "RNG"
756527b8 89# define OSSL_SELF_TEST_DESC_KEYGEN_ML_DSA "ML-DSA"
a5cc141b 90# define OSSL_SELF_TEST_DESC_KEYGEN_ML_KEM "ML-KEM"
92a54f4d 91# define OSSL_SELF_TEST_DESC_KEYGEN_SLH_DSA "SLH-DSA"
073b9f2b
P
92# define OSSL_SELF_TEST_DESC_ENCAP_KEM "KEM_Encap"
93# define OSSL_SELF_TEST_DESC_DECAP_KEM "KEM_Decap"
94# define OSSL_SELF_TEST_DESC_DECAP_KEM_FAIL "KEM_Decap_Reject"
36fc5fc6 95
b4250010 96void OSSL_SELF_TEST_set_callback(OSSL_LIB_CTX *libctx, OSSL_CALLBACK *cb,
36fc5fc6 97 void *cbarg);
b4250010 98void OSSL_SELF_TEST_get_callback(OSSL_LIB_CTX *libctx, OSSL_CALLBACK **cb,
36fc5fc6
SL
99 void **cbarg);
100
47c239c6
SL
101OSSL_SELF_TEST *OSSL_SELF_TEST_new(OSSL_CALLBACK *cb, void *cbarg);
102void OSSL_SELF_TEST_free(OSSL_SELF_TEST *st);
103
104void OSSL_SELF_TEST_onbegin(OSSL_SELF_TEST *st, const char *type,
105 const char *desc);
7f9e7440 106int OSSL_SELF_TEST_oncorrupt_byte(OSSL_SELF_TEST *st, unsigned char *bytes);
47c239c6
SL
107void OSSL_SELF_TEST_onend(OSSL_SELF_TEST *st, int ret);
108
1bfd20f0
P
109# ifdef __cplusplus
110}
111# endif
36fc5fc6 112#endif /* OPENSSL_SELF_TEST_H */