2 * Copyright 2019-2022 The OpenSSL Project Authors. All Rights Reserved.
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
10 #ifndef OSSL_INTERNAL_PROVIDER_H
11 # define OSSL_INTERNAL_PROVIDER_H
14 # include <openssl/core.h>
15 # include <openssl/core_dispatch.h>
16 # include "internal/dso.h"
17 # include "internal/symhacks.h"
26 * ossl_provider_ Provider Object internal API
27 * OSSL_PROVIDER Provider Object
30 /* Provider Object finder, constructor and destructor */
31 OSSL_PROVIDER
*ossl_provider_find(OSSL_LIB_CTX
*libctx
, const char *name
,
33 OSSL_PROVIDER
*ossl_provider_new(OSSL_LIB_CTX
*libctx
, const char *name
,
34 OSSL_provider_init_fn
*init_function
,
36 int ossl_provider_up_ref(OSSL_PROVIDER
*prov
);
37 void ossl_provider_free(OSSL_PROVIDER
*prov
);
40 int ossl_provider_set_fallback(OSSL_PROVIDER
*prov
);
41 int ossl_provider_set_module_path(OSSL_PROVIDER
*prov
, const char *module_path
);
42 int ossl_provider_add_parameter(OSSL_PROVIDER
*prov
, const char *name
,
45 int ossl_provider_is_child(const OSSL_PROVIDER
*prov
);
46 int ossl_provider_set_child(OSSL_PROVIDER
*prov
, const OSSL_CORE_HANDLE
*handle
);
47 const OSSL_CORE_HANDLE
*ossl_provider_get_parent(OSSL_PROVIDER
*prov
);
48 int ossl_provider_up_ref_parent(OSSL_PROVIDER
*prov
, int activate
);
49 int ossl_provider_free_parent(OSSL_PROVIDER
*prov
, int deactivate
);
50 int ossl_provider_default_props_update(OSSL_LIB_CTX
*libctx
, const char *props
);
52 /* Disable fallback loading */
53 int ossl_provider_disable_fallback_loading(OSSL_LIB_CTX
*libctx
);
56 * Activate the Provider
57 * If the Provider is a module, the module will be loaded
59 int ossl_provider_activate(OSSL_PROVIDER
*prov
, int upcalls
, int aschild
);
60 int ossl_provider_deactivate(OSSL_PROVIDER
*prov
, int removechildren
);
61 int ossl_provider_add_to_store(OSSL_PROVIDER
*prov
, OSSL_PROVIDER
**actualprov
,
62 int retain_fallbacks
);
64 /* Return pointer to the provider's context */
65 void *ossl_provider_ctx(const OSSL_PROVIDER
*prov
);
67 /* Iterate over all loaded providers */
68 int ossl_provider_doall_activated(OSSL_LIB_CTX
*,
69 int (*cb
)(OSSL_PROVIDER
*provider
,
73 /* Getters for other library functions */
74 const char *ossl_provider_name(const OSSL_PROVIDER
*prov
);
75 const DSO
*ossl_provider_dso(const OSSL_PROVIDER
*prov
);
76 const char *ossl_provider_module_name(const OSSL_PROVIDER
*prov
);
77 const char *ossl_provider_module_path(const OSSL_PROVIDER
*prov
);
78 void *ossl_provider_prov_ctx(const OSSL_PROVIDER
*prov
);
79 const OSSL_DISPATCH
*ossl_provider_get0_dispatch(const OSSL_PROVIDER
*prov
);
80 OSSL_LIB_CTX
*ossl_provider_libctx(const OSSL_PROVIDER
*prov
);
82 /* Thin wrappers around calls to the provider */
83 void ossl_provider_teardown(const OSSL_PROVIDER
*prov
);
84 const OSSL_PARAM
*ossl_provider_gettable_params(const OSSL_PROVIDER
*prov
);
85 int ossl_provider_get_params(const OSSL_PROVIDER
*prov
, OSSL_PARAM params
[]);
86 int ossl_provider_get_capabilities(const OSSL_PROVIDER
*prov
,
87 const char *capability
,
90 int ossl_provider_self_test(const OSSL_PROVIDER
*prov
);
91 const OSSL_ALGORITHM
*ossl_provider_query_operation(const OSSL_PROVIDER
*prov
,
94 void ossl_provider_unquery_operation(const OSSL_PROVIDER
*prov
,
96 const OSSL_ALGORITHM
*algs
);
99 * Cache of bits to see if we already added methods for an operation in
100 * the "permanent" method store.
101 * They should never be called for temporary method stores!
103 int ossl_provider_set_operation_bit(OSSL_PROVIDER
*provider
, size_t bitnum
);
104 int ossl_provider_test_operation_bit(OSSL_PROVIDER
*provider
, size_t bitnum
,
108 void ossl_provider_add_conf_module(void);
110 /* Child providers */
111 int ossl_provider_init_as_child(OSSL_LIB_CTX
*ctx
,
112 const OSSL_CORE_HANDLE
*handle
,
113 const OSSL_DISPATCH
*in
);
114 void ossl_provider_deinit_child(OSSL_LIB_CTX
*ctx
);