1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- /*
- * Copyright 1995-2016 The OpenSSL Project Authors. All Rights Reserved.
- *
- * Licensed under the OpenSSL license (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
- * https://www.openssl.org/source/license.html
- */
- #ifndef HEADER_PACKETED_BIO
- #define HEADER_PACKETED_BIO
- #include <openssl/base.h>
- #include <openssl/bio.h>
- #if defined(OPENSSL_SYS_WINDOWS)
- OPENSSL_MSVC_PRAGMA(warning(push, 3))
- #include <winsock2.h>
- 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. It internally maintains a clock and honors
- // |BIO_CTRL_DGRAM_SET_NEXT_TIMEOUT| based on it.
- //
- // 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
|