From: Matt Caswell Date: Mon, 6 Nov 2017 16:52:06 +0000 (+0000) Subject: Mark a zero length record as read X-Git-Tag: OpenSSL_1_1_0h~198 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=2df7971728ddd388a77de56acc01e4bab37796bb;p=oweals%2Fopenssl.git Mark a zero length record as read If SSL_read() is called with a zero length buffer, and we read a zero length record then we should mark that record as read. Reviewed-by: Rich Salz (Merged from https://github.com/openssl/openssl/pull/4686) --- diff --git a/ssl/record/rec_layer_s3.c b/ssl/record/rec_layer_s3.c index 5945d18748..95026c6e57 100644 --- a/ssl/record/rec_layer_s3.c +++ b/ssl/record/rec_layer_s3.c @@ -1133,8 +1133,16 @@ int ssl3_read_bytes(SSL *s, int type, int *recvd_type, unsigned char *buf, if (recvd_type != NULL) *recvd_type = SSL3_RECORD_get_type(rr); - if (len <= 0) - return (len); + if (len <= 0) { + /* + * Mark a zero length record as read. This ensures multiple calls to + * SSL_read() with a zero length buffer will eventually cause + * SSL_pending() to report data as being available. + */ + if (SSL3_RECORD_get_length(rr) == 0) + SSL3_RECORD_set_read(rr); + return len; + } read_bytes = 0; do {