2019-08-19 07:18:33 +08:00
|
|
|
/*
|
2020-04-23 20:55:52 +08:00
|
|
|
* Copyright 2019-2020 The OpenSSL Project Authors. All Rights Reserved.
|
2019-08-19 07:18:33 +08:00
|
|
|
*
|
2020-04-27 12:59:50 +08:00
|
|
|
* Licensed under the Apache License 2.0 (the "License"). You may not use
|
2019-08-19 07:18:33 +08:00
|
|
|
* this file except in compliance with the License. You can obtain a copy
|
|
|
|
* in the file LICENSE in the source distribution or at
|
|
|
|
* https://www.openssl.org/source/license.html
|
|
|
|
*/
|
|
|
|
|
2020-06-21 07:21:19 +08:00
|
|
|
#include <openssl/core_dispatch.h>
|
2019-09-28 06:45:46 +08:00
|
|
|
#include <openssl/types.h>
|
2020-01-15 08:48:01 +08:00
|
|
|
#include <openssl/self_test.h>
|
2019-08-19 07:18:33 +08:00
|
|
|
|
|
|
|
typedef struct self_test_post_params_st {
|
|
|
|
/* FIPS module integrity check parameters */
|
|
|
|
const char *module_filename; /* Module file to perform MAC on */
|
|
|
|
const char *module_checksum_data; /* Expected module MAC integrity */
|
|
|
|
|
|
|
|
/* Used for KAT install indicator integrity check */
|
|
|
|
const char *indicator_version; /* version - for future proofing */
|
|
|
|
const char *indicator_data; /* data to perform MAC on */
|
|
|
|
const char *indicator_checksum_data; /* Expected MAC integrity value */
|
|
|
|
|
|
|
|
/* BIO callbacks supplied to the FIPS provider */
|
2020-06-21 07:19:16 +08:00
|
|
|
OSSL_FUNC_BIO_new_file_fn *bio_new_file_cb;
|
|
|
|
OSSL_FUNC_BIO_new_membuf_fn *bio_new_buffer_cb;
|
|
|
|
OSSL_FUNC_BIO_read_ex_fn *bio_read_ex_cb;
|
|
|
|
OSSL_FUNC_BIO_free_fn *bio_free_cb;
|
2020-01-15 08:48:01 +08:00
|
|
|
OSSL_CALLBACK *cb;
|
|
|
|
void *cb_arg;
|
2020-03-03 12:02:36 +08:00
|
|
|
OPENSSL_CTX *libctx;
|
2020-01-15 08:48:01 +08:00
|
|
|
|
2020-03-03 12:02:36 +08:00
|
|
|
} SELF_TEST_POST_PARAMS;
|
2020-01-15 08:48:01 +08:00
|
|
|
|
2019-09-19 00:27:10 +08:00
|
|
|
int SELF_TEST_post(SELF_TEST_POST_PARAMS *st, int on_demand_test);
|
2020-03-03 12:02:36 +08:00
|
|
|
int SELF_TEST_kats(OSSL_SELF_TEST *event, OPENSSL_CTX *libctx);
|