diff options
| author | jsing <> | 2019-02-23 15:00:44 +0000 |
|---|---|---|
| committer | jsing <> | 2019-02-23 15:00:44 +0000 |
| commit | 756cd22bbe03db540ba4cd81d23f6d66af89a6a6 (patch) | |
| tree | 25a9c887b7811d28c3008bd7cef5fdbbae0dc050 /src | |
| parent | 375349e3dab4ad23aaba1771a89b29b9525e2c0c (diff) | |
| download | openbsd-756cd22bbe03db540ba4cd81d23f6d66af89a6a6.tar.gz openbsd-756cd22bbe03db540ba4cd81d23f6d66af89a6a6.tar.bz2 openbsd-756cd22bbe03db540ba4cd81d23f6d66af89a6a6.zip | |
Set BIO retry on TLS13_IO_WANT_POLLIN/TLS13_IO_WANT_POLLOUT.
In most cases a TLS13_IO_WANT_POLLIN or TLS13_IO_WANT_POLLOUT will have
bubbled up from the wire callbacks, in which case the BIO retry flag will
already be set. However, if we return TLS13_IO_WANT_POLLIN or
TLS13_IO_WANT_POLLOUT from a higher layer the BIO retry flag will not be
set and that will cause SSL_get_error() to return SSL_ERROR_SYSCALL rather
than the intended SSL_ERROR_WANT_READ/SSL_ERROR_WANT_WRITE.
ok beck@ tb@
Diffstat (limited to '')
| -rw-r--r-- | src/lib/libssl/tls13_lib.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/src/lib/libssl/tls13_lib.c b/src/lib/libssl/tls13_lib.c index f9505fa438..d8a22c8fc7 100644 --- a/src/lib/libssl/tls13_lib.c +++ b/src/lib/libssl/tls13_lib.c | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | /* $OpenBSD: tls13_lib.c,v 1.4 2019/02/21 17:15:00 jsing Exp $ */ | 1 | /* $OpenBSD: tls13_lib.c,v 1.5 2019/02/23 15:00:44 jsing Exp $ */ |
| 2 | /* | 2 | /* |
| 3 | * Copyright (c) 2018, 2019 Joel Sing <jsing@openbsd.org> | 3 | * Copyright (c) 2018, 2019 Joel Sing <jsing@openbsd.org> |
| 4 | * | 4 | * |
| @@ -219,10 +219,12 @@ tls13_legacy_return_code(SSL *ssl, ssize_t ret) | |||
| 219 | return -1; | 219 | return -1; |
| 220 | 220 | ||
| 221 | case TLS13_IO_WANT_POLLIN: | 221 | case TLS13_IO_WANT_POLLIN: |
| 222 | BIO_set_retry_read(ssl->rbio); | ||
| 222 | ssl->internal->rwstate = SSL_READING; | 223 | ssl->internal->rwstate = SSL_READING; |
| 223 | return -1; | 224 | return -1; |
| 224 | 225 | ||
| 225 | case TLS13_IO_WANT_POLLOUT: | 226 | case TLS13_IO_WANT_POLLOUT: |
| 227 | BIO_set_retry_write(ssl->wbio); | ||
| 226 | ssl->internal->rwstate = SSL_WRITING; | 228 | ssl->internal->rwstate = SSL_WRITING; |
| 227 | return -1; | 229 | return -1; |
| 228 | } | 230 | } |
