/*
* Implementation of SP 800-90B section 4.4 Approved Continuous Health Tests.
*/
+{-
+use OpenSSL::paramnames qw(produce_param_decoder);
+-}
#include <string.h>
#include <openssl/evp.h>
#include "prov/providercommon.h"
#include "prov/provider_ctx.h"
#include "prov/implementations.h"
+#include "internal/common.h"
#include "internal/cryptlib.h"
#include "crypto/rand_pool.h"
-#include "drbg_local.h"
+#include "prov/drbg.h"
#include "prov/seeding.h"
#include "crypto/context.h"
/*
* Critical values for this test are computed using:
*
- * C = 1 + \left\lceil\frac{-log_2 \alpha}H\right\rceil
+ * C = 1 + \left\lceil\frac{ -log_2 \alpha}H\right\rceil
*
* where alpha = 2^-20 and H is the expected entropy per sample.
*/
CRYPTO_THREAD_unlock(crngt->lock);
}
+{- produce_param_decoder('crng_test_get_ctx_params',
+ (['RAND_PARAM_STATE', 'state', 'int'],
+ ['RAND_PARAM_STRENGTH', 'str', 'uint'],
+ ['RAND_PARAM_MAX_REQUEST', 'maxreq', 'size_t'],
+ ['RAND_PARAM_FIPS_APPROVED_INDICATOR', 'ind', 'int'],
+ )); -}
+
static int crng_test_get_ctx_params(void *vcrngt, OSSL_PARAM params[])
{
CRNG_TEST *crngt = (CRNG_TEST *)vcrngt;
- OSSL_PARAM *p;
+ struct crng_test_get_ctx_params_st p;
+
+ if (crngt == NULL)
+ return 0;
if (crngt->parent != NULL && crngt->parent_get_ctx_params != NULL)
return crngt->parent_get_ctx_params(crngt->parent, params);
/* No parent means we are using call backs for entropy */
- p = OSSL_PARAM_locate(params, OSSL_RAND_PARAM_STATE);
- if (p != NULL && !OSSL_PARAM_set_int(p, crngt->state))
+ if (!crng_test_get_ctx_params_decoder(params, &p))
return 0;
- p = OSSL_PARAM_locate(params, OSSL_RAND_PARAM_STRENGTH);
- if (p != NULL && !OSSL_PARAM_set_int(p, 1024))
+ if (p.state != NULL && !OSSL_PARAM_set_int(p.state, crngt->state))
return 0;
- p = OSSL_PARAM_locate(params, OSSL_RAND_PARAM_MAX_REQUEST);
- if (p != NULL && !OSSL_PARAM_set_size_t(p, 128))
+ if (p.str != NULL && !OSSL_PARAM_set_uint(p.str, 1024))
return 0;
- p = OSSL_PARAM_locate(params, OSSL_RAND_PARAM_FIPS_APPROVED_INDICATOR);
- if (p != NULL && !OSSL_PARAM_set_int(p, 0))
+ if (p.maxreq != NULL && !OSSL_PARAM_set_size_t(p.maxreq, 128))
+ return 0;
+
+ if (p.ind != NULL && !OSSL_PARAM_set_int(p.ind, 0))
return 0;
return 1;
}
void *provctx)
{
CRNG_TEST *crngt = (CRNG_TEST *)vcrngt;
- static const OSSL_PARAM known_gettable_ctx_params[] = {
- OSSL_PARAM_int(OSSL_RAND_PARAM_STATE, NULL),
- OSSL_PARAM_uint(OSSL_RAND_PARAM_STRENGTH, NULL),
- OSSL_PARAM_size_t(OSSL_RAND_PARAM_MAX_REQUEST, NULL),
- OSSL_PARAM_int(OSSL_RAND_PARAM_FIPS_APPROVED_INDICATOR, NULL),
- OSSL_PARAM_END
- };
if (crngt->parent != NULL && crngt->parent_gettable_ctx_params != NULL)
return crngt->parent_gettable_ctx_params(crngt->parent, provctx);
- return known_gettable_ctx_params;
+ return crng_test_get_ctx_params_list;
}
const OSSL_DISPATCH ossl_crng_test_functions[] = {