From 31f584a499af01a7be60d29ea5273da1f783fe01 Mon Sep 17 00:00:00 2001 From: Nikos Mavrogiannopoulos Date: Fri, 15 Sep 2017 16:34:02 +0200 Subject: parse_handshake_header: allow 1-byte sized fragments Signed-off-by: Nikos Mavrogiannopoulos --- lib/gnutls_buffers.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/lib/gnutls_buffers.c b/lib/gnutls_buffers.c index 8750863120..3d9e061eaf 100644 --- a/lib/gnutls_buffers.c +++ b/lib/gnutls_buffers.c @@ -935,12 +935,13 @@ parse_handshake_header(gnutls_session_t session, mbuffer_st * bufel, return gnutls_assert_val(GNUTLS_E_UNEXPECTED_PACKET_LENGTH); - if (hsk->length > 0 && (hsk->start_offset >= hsk->end_offset || + if (hsk->length > 0 && (hsk->start_offset > hsk->end_offset || hsk->end_offset - hsk->start_offset >= data_size - || hsk->end_offset >= hsk->length)) + || hsk->end_offset >= hsk->length)) { return gnutls_assert_val(GNUTLS_E_UNEXPECTED_PACKET_LENGTH); + } else if (hsk->length == 0 && hsk->end_offset != 0 && hsk->start_offset != 0) return -- cgit v1.2.1