2017-06-23 02:00:06 +08:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
|
|
|
OPENSSL_fork_prepare,
|
|
|
|
OPENSSL_fork_parent,
|
|
|
|
OPENSSL_fork_child
|
|
|
|
- OpenSSL fork handlers
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
#include <openssl/crypto.h>
|
|
|
|
|
2021-12-02 19:33:49 +08:00
|
|
|
The following functions have been deprecated since OpenSSL 3.0, and can be
|
|
|
|
hidden entirely by defining B<OPENSSL_API_COMPAT> with a suitable version value,
|
|
|
|
see L<openssl_user_macros(7)>:
|
2020-10-29 23:17:25 +08:00
|
|
|
|
2017-06-23 02:00:06 +08:00
|
|
|
void OPENSSL_fork_prepare(void);
|
|
|
|
void OPENSSL_fork_parent(void);
|
|
|
|
void OPENSSL_fork_child(void);
|
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
2020-10-29 23:17:25 +08:00
|
|
|
These methods are currently unused, and as such, no replacement methods are
|
|
|
|
required or planned.
|
|
|
|
|
2017-06-23 02:00:06 +08:00
|
|
|
OpenSSL has state that should be reset when a process forks. For example,
|
|
|
|
the entropy pool used to generate random numbers (and therefore encryption
|
|
|
|
keys) should not be shared across multiple programs.
|
|
|
|
The OPENSSL_fork_prepare(), OPENSSL_fork_parent(), and OPENSSL_fork_child()
|
|
|
|
functions are used to reset this internal state.
|
|
|
|
|
|
|
|
Platforms without fork(2) will probably not need to use these functions.
|
2019-05-31 15:06:28 +08:00
|
|
|
Platforms with fork(2) but without pthread_atfork(3) will probably need
|
2017-06-23 02:00:06 +08:00
|
|
|
to call them manually, as described in the following paragraph. Platforms
|
|
|
|
such as Linux that have both functions will normally not need to call these
|
|
|
|
functions as the OpenSSL library will do so automatically.
|
|
|
|
|
2017-08-01 06:58:40 +08:00
|
|
|
L<OPENSSL_init_crypto(3)> will register these functions with the appropriate
|
2018-03-30 04:10:26 +08:00
|
|
|
handler, when the B<OPENSSL_INIT_ATFORK> flag is used. For other
|
2017-06-23 02:00:06 +08:00
|
|
|
applications, these functions can be called directly. They should be used
|
2019-05-31 15:06:28 +08:00
|
|
|
according to the calling sequence described by the pthread_atfork(3)
|
2017-06-23 02:00:06 +08:00
|
|
|
documentation, which is summarized here. OPENSSL_fork_prepare() should
|
|
|
|
be called before a fork() is done. After the fork() returns, the parent
|
|
|
|
process should call OPENSSL_fork_parent() and the child process should
|
|
|
|
call OPENSSL_fork_child().
|
|
|
|
|
2017-12-25 17:50:39 +08:00
|
|
|
=head1 RETURN VALUES
|
|
|
|
|
|
|
|
OPENSSL_fork_prepare(), OPENSSL_fork_parent() and OPENSSL_fork_child() do not
|
|
|
|
return values.
|
|
|
|
|
2017-06-23 02:00:06 +08:00
|
|
|
=head1 SEE ALSO
|
|
|
|
|
|
|
|
L<OPENSSL_init_crypto(3)>
|
|
|
|
|
|
|
|
=head1 HISTORY
|
|
|
|
|
|
|
|
These functions were added in OpenSSL 1.1.1.
|
|
|
|
|
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
2020-10-29 23:17:25 +08:00
|
|
|
Copyright 2017-2020 The OpenSSL Project Authors. All Rights Reserved.
|
2017-06-23 02:00:06 +08:00
|
|
|
|
2018-12-06 21:04:44 +08:00
|
|
|
Licensed under the Apache License 2.0 (the "License"). You may not use
|
2017-06-23 02:00:06 +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
|
|
|
|
L<https://www.openssl.org/source/license.html>.
|
|
|
|
|
|
|
|
=cut
|