From: Matt Caswell Date: Mon, 9 May 2016 14:04:11 +0000 (+0100) Subject: Fix BIO_eof() for BIO pairs X-Git-Tag: OpenSSL_1_1_0-pre6~892 X-Git-Url: https://git.openssl.org/?p=openssl.git;a=commitdiff_plain;h=3105d695358d86c0f2a404b2b74a1870b941ce5e;hp=2e66d3d674d3a54593e0cbb4ff1f6039fd965d66 Fix BIO_eof() for BIO pairs BIO_eof() was always returning true when using a BIO pair. It should only be true if the peer BIO is empty and has been shutdown. RT#1215 Reviewed-by: Richard Levitte --- diff --git a/crypto/bio/bss_bio.c b/crypto/bio/bss_bio.c index 2991c3afed..820cf8cf6a 100644 --- a/crypto/bio/bss_bio.c +++ b/crypto/bio/bss_bio.c @@ -627,16 +627,15 @@ static long bio_ctrl(BIO *bio, int cmd, long num, void *ptr) break; case BIO_CTRL_EOF: - { - BIO *other_bio = ptr; - - if (other_bio) { - struct bio_bio_st *other_b = other_bio->ptr; + if (b->peer != NULL) { + struct bio_bio_st *peer_b = b->peer->ptr; - assert(other_b != NULL); - ret = other_b->len == 0 && other_b->closed; - } else + if (peer_b->len == 0 && peer_b->closed) ret = 1; + else + ret = 0; + } else { + ret = 1; } break; diff --git a/doc/crypto/BIO_s_bio.pod b/doc/crypto/BIO_s_bio.pod index 438b5dd8f3..e6d5c4967c 100644 --- a/doc/crypto/BIO_s_bio.pod +++ b/doc/crypto/BIO_s_bio.pod @@ -120,6 +120,9 @@ the application then waits for data to be available on the underlying transport before flushing the write buffer it will never succeed because the request was never sent! +BIO_eof() is true if no data is in the peer BIO and the peer BIO has been +shutdown. + =head1 RETURN VALUES BIO_new_bio_pair() returns 1 on success, with the new BIOs available in