diff options
author | Matt Caswell <matt@openssl.org> | 2016-10-12 10:56:29 +0100 |
---|---|---|
committer | Matt Caswell <matt@openssl.org> | 2016-11-04 10:38:54 +0000 |
commit | 7b73b7beda88501b9d6e062a5dbf9a72f791dfda (patch) | |
tree | b543407170dba31204f5afc0015fec5dff1eb163 /test/ossl_shim/packeted_bio.h | |
parent | 8c6c5077b211ea73223c950edff98f0891853dc8 (diff) |
Rebase shim against latest boringssl code
Numerous conflicts resolved. rebase was against commit 490469f850.
Reviewed-by: Richard Levitte <levitte@openssl.org>
Diffstat (limited to 'test/ossl_shim/packeted_bio.h')
-rw-r--r-- | test/ossl_shim/packeted_bio.h | 33 |
1 files changed, 19 insertions, 14 deletions
diff --git a/test/ossl_shim/packeted_bio.h b/test/ossl_shim/packeted_bio.h index df76506105..07930d4708 100644 --- a/test/ossl_shim/packeted_bio.h +++ b/test/ossl_shim/packeted_bio.h @@ -15,30 +15,35 @@ #ifndef HEADER_PACKETED_BIO #define HEADER_PACKETED_BIO -#include <openssl/e_os2.h> +#include <openssl/base.h> #include <openssl/bio.h> -#include "crypto/scoped_types.h" - -#if defined(OPENSSL_SYS_WINDOWS) -#pragma warning(push, 3) +#if defined(OPENSSL_WINDOWS) +OPENSSL_MSVC_PRAGMA(warning(push, 3)) #include <winsock2.h> -#pragma warning(pop) +OPENSSL_MSVC_PRAGMA(warning(pop)) #else #include <sys/time.h> #endif // PacketedBioCreate creates a filter BIO which implements a reliable in-order -// blocking datagram socket. The resulting BIO, on |BIO_read|, may simulate a -// timeout which sets |*out_timeout| to the timeout and fails the read. -// |*out_timeout| must be zero on entry to |BIO_read|; it is an error to not -// apply the timeout before the next |BIO_read|. +// blocking datagram socket. It internally maintains a clock and honors +// |BIO_CTRL_DGRAM_SET_NEXT_TIMEOUT| based on it. // -// Note: The read timeout simulation is intended to be used with the async BIO -// wrapper. It doesn't simulate BIO_CTRL_DGRAM_SET_NEXT_TIMEOUT, used in DTLS's -// blocking mode. -ScopedBIO PacketedBioCreate(timeval *out_timeout); +// During a |BIO_read|, the peer may signal the filter BIO to simulate a +// timeout. If |advance_clock| is true, it automatically advances the clock and +// continues reading, subject to the read deadline. Otherwise, it fails +// immediately. The caller must then call |PacketedBioAdvanceClock| before +// retrying |BIO_read|. +bssl::UniquePtr<BIO> PacketedBioCreate(bool advance_clock); + +// PacketedBioGetClock returns the current time for |bio|. +timeval PacketedBioGetClock(const BIO *bio); + +// PacketedBioAdvanceClock advances |bio|'s internal clock and returns true if +// there is a pending timeout. Otherwise, it returns false. +bool PacketedBioAdvanceClock(BIO *bio); #endif // HEADER_PACKETED_BIO |