1 /* 2 * Copyright 2019-2020 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 #include <openssl/core_dispatch.h> 11 #include <openssl/types.h> 12 #include <openssl/self_test.h> 13 14 typedef struct self_test_post_params_st { 15 /* FIPS module integrity check parameters */ 16 const char *module_filename; /* Module file to perform MAC on */ 17 const char *module_checksum_data; /* Expected module MAC integrity */ 18 19 /* Used for KAT install indicator integrity check */ 20 const char *indicator_version; /* version - for future proofing */ 21 const char *indicator_data; /* data to perform MAC on */ 22 const char *indicator_checksum_data; /* Expected MAC integrity value */ 23 24 /* Used for continuous tests */ 25 const char *conditional_error_check; 26 27 /* BIO callbacks supplied to the FIPS provider */ 28 OSSL_FUNC_BIO_new_file_fn *bio_new_file_cb; 29 OSSL_FUNC_BIO_new_membuf_fn *bio_new_buffer_cb; 30 OSSL_FUNC_BIO_read_ex_fn *bio_read_ex_cb; 31 OSSL_FUNC_BIO_free_fn *bio_free_cb; 32 OSSL_CALLBACK *cb; 33 void *cb_arg; 34 OSSL_LIB_CTX *libctx; 35 36 } SELF_TEST_POST_PARAMS; 37 38 int SELF_TEST_post(SELF_TEST_POST_PARAMS *st, int on_demand_test); 39 int SELF_TEST_kats(OSSL_SELF_TEST *event, OSSL_LIB_CTX *libctx); 40 41 void SELF_TEST_disable_conditional_error_state(void); 42