11c82895d7
The DTLS stack has two very different APIs for handling timeouts. In non-blocking mode, timeouts are driven externally by the caller with DTLSv1_get_timeout. In blocking mode, timeouts are driven by the BIO by calling a BIO_ctrl with BIO_CTRL_DGRAM_SET_NEXT_TIMEOUT. The latter is never used by consumers, so remove support for it. BIO_CTRL_DGRAM_SET_NEXT_TIMEOUT implicitly depends on struct timeval being used for timestamps, which we would like to remove. Without this, the only public API which relies on this is the testing-only SSL_CTX_set_current_time_cb which is BoringSSL-only and we can change at our leisure. BUG=155 Change-Id: Ic68fa70afab2fa9e6286b84d010eac8ddc9d2ef4 Reviewed-on: https://boringssl-review.googlesource.com/13945 Reviewed-by: David Benjamin <davidben@google.com> Commit-Queue: David Benjamin <davidben@google.com> CQ-Verified: CQ bot account: commit-bot@chromium.org <commit-bot@chromium.org>
44 lines
1.6 KiB
C
44 lines
1.6 KiB
C
/* Copyright (c) 2014, Google Inc.
|
|
*
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
|
|
* SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
|
|
* OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
|
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */
|
|
|
|
#ifndef HEADER_PACKETED_BIO
|
|
#define HEADER_PACKETED_BIO
|
|
|
|
#include <openssl/base.h>
|
|
#include <openssl/bio.h>
|
|
|
|
#if defined(OPENSSL_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 uses the value of |*clock| as the clock.
|
|
//
|
|
// During a |BIO_read|, the peer may signal the filter BIO to simulate a
|
|
// timeout. The operation will fail immediately. The caller must then call
|
|
// |PacketedBioAdvanceClock| before retrying |BIO_read|.
|
|
bssl::UniquePtr<BIO> PacketedBioCreate(timeval *clock);
|
|
|
|
// PacketedBioAdvanceClock advances |bio|'s clock and returns true if there is a
|
|
// pending timeout. Otherwise, it returns false.
|
|
bool PacketedBioAdvanceClock(BIO *bio);
|
|
|
|
|
|
#endif // HEADER_PACKETED_BIO
|