2019-02-25 08:59:02 +08:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
|
|
|
OSSL_METHOD_CONSTRUCT_METHOD, ossl_method_construct
|
|
|
|
- generic method constructor
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
#include "internal/core.h"
|
|
|
|
|
|
|
|
struct ossl_method_construct_method_st {
|
2021-09-03 15:09:54 +08:00
|
|
|
/* Get a temporary store */
|
|
|
|
void *(*get_tmp_store)(void *data);
|
2019-02-25 08:59:02 +08:00
|
|
|
/* Get an already existing method from a store */
|
2021-10-04 21:33:37 +08:00
|
|
|
void *(*get)(void *store, const OSSL_PROVIDER *prov, void *data);
|
2019-02-25 08:59:02 +08:00
|
|
|
/* Store a method in a store */
|
2021-10-04 21:33:37 +08:00
|
|
|
int (*put)(void *store, void *method, const OSSL_PROVIDER *prov,
|
|
|
|
const char *name, const char *propdef, void *data);
|
2019-02-25 08:59:02 +08:00
|
|
|
/* Construct a new method */
|
2021-10-04 21:33:37 +08:00
|
|
|
void *(*construct)(const OSSL_ALGORITHM *algodef, OSSL_PROVIDER *prov,
|
|
|
|
void *data);
|
2019-02-25 08:59:02 +08:00
|
|
|
/* Destruct a method */
|
2021-10-04 21:33:37 +08:00
|
|
|
void (*destruct)(void *method, void *data);
|
2019-02-25 08:59:02 +08:00
|
|
|
};
|
|
|
|
typedef struct ossl_method_construct_method OSSL_METHOD_CONSTRUCT_METHOD;
|
|
|
|
|
2020-10-15 17:55:50 +08:00
|
|
|
void *ossl_method_construct(OSSL_LIB_CTX *ctx, int operation_id,
|
2021-09-30 15:32:57 +08:00
|
|
|
OSSL_PROVIDER *prov, int force_cache,
|
2019-02-25 08:59:02 +08:00
|
|
|
OSSL_METHOD_CONSTRUCT_METHOD *mcm, void *mcm_data);
|
|
|
|
|
2019-05-02 21:32:44 +08:00
|
|
|
|
2019-02-25 08:59:02 +08:00
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
2020-07-17 18:31:26 +08:00
|
|
|
All libcrypto subsystems that want to create their own methods based
|
2019-02-25 08:59:02 +08:00
|
|
|
on provider dispatch tables need to do so in exactly the same way.
|
2020-07-17 18:31:26 +08:00
|
|
|
ossl_method_construct() does this while leaving it to the subsystems
|
2019-02-25 08:59:02 +08:00
|
|
|
to define more precisely how the methods are created, stored, etc.
|
|
|
|
|
2019-06-07 17:44:08 +08:00
|
|
|
It's important to keep in mind that a method is identified by three things:
|
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
|
|
|
=item The operation identity
|
|
|
|
|
|
|
|
=item The name of the algorithm
|
|
|
|
|
|
|
|
=item The properties associated with the algorithm implementation
|
|
|
|
|
|
|
|
=back
|
|
|
|
|
2019-02-25 08:59:02 +08:00
|
|
|
=head2 Functions
|
|
|
|
|
|
|
|
ossl_method_construct() creates a method by asking all available
|
In provider implemented methods, save the name number, not the name string
Multiple names per implementation is already supported in the namemap,
but hasn't been used yet. However, as soon as we have multiple names,
we will get an issue with what name should be saved in the method.
The solution is to not save the name itself, but rather the number
it's associated with. This number is supposed to be unique for each
set of names, and we assume that algorithm names are globally unique,
i.e. there can be no name overlap between different algorithm types.
Incidently, it was also found that the 'get' function used by
ossl_construct_method() doesn't need all the parameters it was given;
most of what it needs, it can now get through the data structure given
by the caller of ossl_construct_method(). As a consequence,
ossl_construct_method() itself doesn't need all the parameters it was
given either.
There are some added internal functions that are expected to disappear
as soon as legacy code is removed, such as evp_first_name() and
ossl_namemap_num2name().
Reviewed-by: Matt Caswell <matt@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/9897)
2019-09-14 22:22:19 +08:00
|
|
|
providers for a dispatch table given an I<operation_id>, and then
|
2020-07-17 18:31:26 +08:00
|
|
|
calling the appropriate functions given by the subsystem specific
|
In provider implemented methods, save the name number, not the name string
Multiple names per implementation is already supported in the namemap,
but hasn't been used yet. However, as soon as we have multiple names,
we will get an issue with what name should be saved in the method.
The solution is to not save the name itself, but rather the number
it's associated with. This number is supposed to be unique for each
set of names, and we assume that algorithm names are globally unique,
i.e. there can be no name overlap between different algorithm types.
Incidently, it was also found that the 'get' function used by
ossl_construct_method() doesn't need all the parameters it was given;
most of what it needs, it can now get through the data structure given
by the caller of ossl_construct_method(). As a consequence,
ossl_construct_method() itself doesn't need all the parameters it was
given either.
There are some added internal functions that are expected to disappear
as soon as legacy code is removed, such as evp_first_name() and
ossl_namemap_num2name().
Reviewed-by: Matt Caswell <matt@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/9897)
2019-09-14 22:22:19 +08:00
|
|
|
method creator through I<mcm> and the data in I<mcm_data> (which is
|
|
|
|
passed by ossl_method_construct()).
|
2021-09-30 15:32:57 +08:00
|
|
|
If I<prov> is not NULL, only that provider is considered, which is
|
|
|
|
useful in the case a method must be found in that particular
|
|
|
|
provider.
|
2019-02-25 08:59:02 +08:00
|
|
|
|
2020-07-17 18:31:26 +08:00
|
|
|
This function assumes that the subsystem method creator implements
|
2019-03-15 04:51:50 +08:00
|
|
|
reference counting and acts accordingly (i.e. it will call the
|
2020-07-17 18:31:26 +08:00
|
|
|
subsystem destruct() method to decrement the reference count when
|
2019-03-15 04:51:50 +08:00
|
|
|
appropriate).
|
|
|
|
|
2019-02-25 08:59:02 +08:00
|
|
|
=head2 Structures
|
|
|
|
|
2020-07-17 18:31:26 +08:00
|
|
|
A central part of constructing a subsystem specific method is to give
|
2019-02-25 08:59:02 +08:00
|
|
|
ossl_method_construct a set of functions, all in the
|
2019-06-07 18:30:01 +08:00
|
|
|
B<OSSL_METHOD_CONSTRUCT_METHOD> structure, which holds the following
|
2019-02-25 08:59:02 +08:00
|
|
|
function pointers:
|
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
2021-10-04 21:33:37 +08:00
|
|
|
=item get_tmp_store()
|
2019-02-25 08:59:02 +08:00
|
|
|
|
2019-06-07 18:30:01 +08:00
|
|
|
Create a temporary method store in the scope of the library context I<ctx>.
|
2019-02-25 08:59:02 +08:00
|
|
|
This store is used to temporarily store methods for easier lookup, for
|
|
|
|
when the provider doesn't want its dispatch table stored in a longer
|
|
|
|
term cache.
|
|
|
|
|
|
|
|
=item get()
|
|
|
|
|
2019-05-05 14:42:21 +08:00
|
|
|
Look up an already existing method from a store by name.
|
2019-02-25 08:59:02 +08:00
|
|
|
|
2019-06-07 18:30:01 +08:00
|
|
|
The store may be given with I<store>.
|
2020-07-17 18:31:26 +08:00
|
|
|
NULL is a valid value and means that a subsystem default store
|
2019-02-25 08:59:02 +08:00
|
|
|
must be used.
|
2019-06-07 18:30:01 +08:00
|
|
|
This default store should be stored in the library context I<libctx>.
|
2019-02-25 08:59:02 +08:00
|
|
|
|
In provider implemented methods, save the name number, not the name string
Multiple names per implementation is already supported in the namemap,
but hasn't been used yet. However, as soon as we have multiple names,
we will get an issue with what name should be saved in the method.
The solution is to not save the name itself, but rather the number
it's associated with. This number is supposed to be unique for each
set of names, and we assume that algorithm names are globally unique,
i.e. there can be no name overlap between different algorithm types.
Incidently, it was also found that the 'get' function used by
ossl_construct_method() doesn't need all the parameters it was given;
most of what it needs, it can now get through the data structure given
by the caller of ossl_construct_method(). As a consequence,
ossl_construct_method() itself doesn't need all the parameters it was
given either.
There are some added internal functions that are expected to disappear
as soon as legacy code is removed, such as evp_first_name() and
ossl_namemap_num2name().
Reviewed-by: Matt Caswell <matt@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/9897)
2019-09-14 22:22:19 +08:00
|
|
|
The method to be looked up should be identified with data found in I<data>
|
|
|
|
(which is the I<mcm_data> that was passed to ossl_construct_method()).
|
|
|
|
In other words, the ossl_method_construct() caller is entirely responsible
|
|
|
|
for ensuring the necesssary data is made available.
|
2019-02-25 08:59:02 +08:00
|
|
|
|
2021-10-04 21:33:37 +08:00
|
|
|
Optionally, I<prov> may be given as a search criterion, to narrow down the
|
|
|
|
search of a method belonging to just one provider.
|
|
|
|
|
|
|
|
This function is expected to increment the resulting method's reference count.
|
2019-03-15 04:51:50 +08:00
|
|
|
|
2019-02-25 08:59:02 +08:00
|
|
|
=item put()
|
|
|
|
|
2019-06-07 18:30:01 +08:00
|
|
|
Places the I<method> created by the construct() function (see below)
|
2019-02-25 08:59:02 +08:00
|
|
|
in a store.
|
|
|
|
|
2019-06-07 18:30:01 +08:00
|
|
|
The store may be given with I<store>.
|
2020-07-17 18:31:26 +08:00
|
|
|
NULL is a valid value and means that a subsystem default store
|
2019-02-25 08:59:02 +08:00
|
|
|
must be used.
|
2019-06-07 18:30:01 +08:00
|
|
|
This default store should be stored in the library context I<libctx>.
|
2019-02-25 08:59:02 +08:00
|
|
|
|
2021-10-04 21:33:37 +08:00
|
|
|
The method should be associated with the given provider I<prov>,
|
2019-06-07 18:30:01 +08:00
|
|
|
I<name> and property definition I<propdef> as well as any
|
|
|
|
identification data given through I<data> (which is the I<mcm_data>
|
2019-06-07 17:44:08 +08:00
|
|
|
that was passed to ossl_construct_method()).
|
2019-02-25 08:59:02 +08:00
|
|
|
|
2019-06-07 18:30:01 +08:00
|
|
|
This function is expected to increment the I<method>'s reference count.
|
2019-03-15 04:51:50 +08:00
|
|
|
|
2019-02-25 08:59:02 +08:00
|
|
|
=item construct()
|
|
|
|
|
2020-07-17 18:31:26 +08:00
|
|
|
Constructs a subsystem method for the given I<name> and the given
|
2019-06-07 18:30:01 +08:00
|
|
|
dispatch table I<fns>.
|
2019-02-25 08:59:02 +08:00
|
|
|
|
2019-06-07 18:30:01 +08:00
|
|
|
The associated provider object I<prov> is passed as well, to make
|
2020-07-17 18:31:26 +08:00
|
|
|
it possible for the subsystem constructor to keep a reference, which
|
2019-02-25 08:59:02 +08:00
|
|
|
is recommended.
|
|
|
|
If such a reference is kept, the I<provider object> reference counter
|
2019-07-02 20:57:36 +08:00
|
|
|
must be incremented, using ossl_provider_up_ref().
|
2019-02-25 08:59:02 +08:00
|
|
|
|
2019-03-15 04:51:50 +08:00
|
|
|
This function is expected to set the method's reference count to 1.
|
|
|
|
|
2019-07-02 16:04:04 +08:00
|
|
|
=item destruct()
|
2019-02-25 08:59:02 +08:00
|
|
|
|
2019-06-07 18:30:01 +08:00
|
|
|
Decrement the I<method>'s reference count, and destruct it when
|
2019-03-15 04:51:50 +08:00
|
|
|
the reference count reaches zero.
|
2019-02-25 08:59:02 +08:00
|
|
|
|
|
|
|
=back
|
|
|
|
|
|
|
|
=head1 RETURN VALUES
|
|
|
|
|
|
|
|
ossl_method_construct() returns a constructed method on success, or
|
2019-09-27 19:26:22 +08:00
|
|
|
NULL on error.
|
2019-02-25 08:59:02 +08:00
|
|
|
|
|
|
|
=head1 HISTORY
|
|
|
|
|
2019-05-05 14:42:21 +08:00
|
|
|
This functionality was added to OpenSSL 3.0.
|
2019-02-25 08:59:02 +08:00
|
|
|
|
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
2021-09-07 19:29:33 +08:00
|
|
|
Copyright 2019-2021 The OpenSSL Project Authors. All Rights Reserved.
|
2019-02-25 08:59:02 +08:00
|
|
|
|
|
|
|
Licensed under the Apache License 2.0 (the "License"). You may not use this
|
|
|
|
file except in compliance with the License. You can obtain a copy in the file
|
|
|
|
LICENSE in the source distribution or at
|
|
|
|
L<https://www.openssl.org/source/license.html>.
|
|
|
|
|
|
|
|
=cut
|