mirror of
https://github.com/openssl/openssl.git
synced 2024-12-27 06:21:43 +08:00
e8d0819d52
We were excluding more code than we needed to in the OCSP/HTTP code in the event of no-sock. We should also not assume that a BIO passed to our API is socket based. This fixes the no-sock build Reviewed-by: Matt Caswell <matt@openssl.org> Reviewed-by: David von Oheimb <david.von.oheimb@siemens.com> (Merged from https://github.com/openssl/openssl/pull/11134)
59 lines
1.8 KiB
Plaintext
59 lines
1.8 KiB
Plaintext
=pod
|
|
|
|
=head1 NAME
|
|
|
|
BIO_socket_wait,
|
|
BIO_wait,
|
|
BIO_connect_retry
|
|
- BIO socket utility functions
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
#include <openssl/bio.h>
|
|
|
|
#ifndef OPENSSL_NO_SOCK
|
|
int BIO_socket_wait(int fd, int for_read, time_t max_time);
|
|
#endif
|
|
int BIO_wait(BIO *bio, time_t max_time, unsigned int milliseconds);
|
|
int BIO_connect_retry(BIO *bio, long timeout);
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
BIO_socket_wait() waits on the socket B<fd> for reading if B<for_read> is not 0,
|
|
else for writing, at most until B<max_time>.
|
|
It succeeds immediately if B<max_time> == 0 (which means no timeout given).
|
|
|
|
BIO_wait() waits at most until B<max_time> on the given B<bio>,
|
|
which is typically socket-based,
|
|
for reading if B<bio> is supposed to read, else for writing.
|
|
It succeeds immediately if B<max_time> == 0 (which means no timeout given).
|
|
If sockets are not available it succeeds after waiting at most given
|
|
B<milliseconds> in order to help avoiding a tight busy loop at the caller.
|
|
|
|
BIO_connect_retry() connects via the given B<bio>, retrying BIO_do_connect()
|
|
until success or a timeout or error condition is reached.
|
|
If the B<timeout> parameter is > 0 this indicates the maximum number of seconds
|
|
to wait until the connection is established. A value of 0 enables waiting
|
|
indefinitely, while a value < 0 immediately leads to a timeout condition.
|
|
|
|
=head1 RETURN VALUES
|
|
|
|
BIO_socket_wait(), BIO_wait(), and BIO_connect_retry()
|
|
return -1 on error, 0 on timeout, and 1 on success.
|
|
|
|
=head1 HISTORY
|
|
|
|
BIO_socket_wait(), BIO_wait(), and BIO_connect_retry()
|
|
were added in OpenSSL 3.0.
|
|
|
|
=head1 COPYRIGHT
|
|
|
|
Copyright 2019-2020 The OpenSSL Project Authors. All Rights Reserved.
|
|
|
|
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
|