From 099bd33920e775eb75f4daee5f09b24f17bc136d Mon Sep 17 00:00:00 2001 From: Richard Levitte Date: Mon, 25 Feb 2019 01:57:28 +0100 Subject: Replumbing: Add support for the provider query_operation function Reviewed-by: Paul Dale (Merged from https://github.com/openssl/openssl/pull/8340) --- crypto/provider_core.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) (limited to 'crypto') diff --git a/crypto/provider_core.c b/crypto/provider_core.c index e7cbee2e43..fb4be55676 100644 --- a/crypto/provider_core.c +++ b/crypto/provider_core.c @@ -39,6 +39,7 @@ struct ossl_provider_st { OSSL_provider_teardown_fn *teardown; OSSL_provider_get_param_types_fn *get_param_types; OSSL_provider_get_params_fn *get_params; + OSSL_provider_query_operation_fn *query_operation; }; DEFINE_STACK_OF(OSSL_PROVIDER) @@ -319,6 +320,10 @@ int ossl_provider_activate(OSSL_PROVIDER *prov) prov->get_params = OSSL_get_provider_get_params(provider_dispatch); break; + case OSSL_FUNC_PROVIDER_QUERY_OPERATION: + prov->query_operation = + OSSL_get_provider_query_operation(provider_dispatch); + break; } } @@ -392,6 +397,14 @@ int ossl_provider_get_params(const OSSL_PROVIDER *prov, return prov->get_params == NULL ? 0 : prov->get_params(prov, params); } + +const OSSL_ALGORITHM *ossl_provider_query_operation(const OSSL_PROVIDER *prov, + int operation_id, + int *no_cache) +{ + return prov->query_operation(prov, operation_id, no_cache); +} + /*- * Core functions for the provider * =============================== -- cgit v1.2.3