5dee6fb
From 5815730864a2010872840bae24797983e892eb90 Mon Sep 17 00:00:00 2001
5dee6fb
From: Daniel Stenberg <daniel@haxx.se>
5dee6fb
Date: Sat, 24 Mar 2018 23:47:41 +0100
5dee6fb
Subject: [PATCH 1/2] http: restore buffer pointer when bad response-line is
5dee6fb
 parsed
5dee6fb
5dee6fb
... leaving the k->str could lead to buffer over-reads later on.
5dee6fb
5dee6fb
CVE: CVE-2018-1000301
5dee6fb
Assisted-by: Max Dymond
5dee6fb
5dee6fb
Detected by OSS-Fuzz.
5dee6fb
Bug: https://curl.haxx.se/docs/adv_2018-b138.html
5dee6fb
Bug: https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=7105
5dee6fb
5dee6fb
Upstream-commit: 8c7b3737d29ed5c0575bf592063de8a51450812d
5dee6fb
Signed-off-by: Kamil Dudka <kdudka@redhat.com>
5dee6fb
---
5dee6fb
 lib/http.c | 6 +++++-
5dee6fb
 1 file changed, 5 insertions(+), 1 deletion(-)
5dee6fb
5dee6fb
diff --git a/lib/http.c b/lib/http.c
5dee6fb
index 841f6cc..dc10f5f 100644
5dee6fb
--- a/lib/http.c
5dee6fb
+++ b/lib/http.c
5dee6fb
@@ -2966,6 +2966,8 @@ CURLcode Curl_http_readwrite_headers(struct Curl_easy *data,
5dee6fb
 {
5dee6fb
   CURLcode result;
5dee6fb
   struct SingleRequest *k = &data->req;
5dee6fb
+  ssize_t onread = *nread;
5dee6fb
+  char *ostr = k->str;
5dee6fb
 
5dee6fb
   /* header line within buffer loop */
5dee6fb
   do {
5dee6fb
@@ -3030,7 +3032,9 @@ CURLcode Curl_http_readwrite_headers(struct Curl_easy *data,
5dee6fb
         else {
5dee6fb
           /* this was all we read so it's all a bad header */
5dee6fb
           k->badheader = HEADER_ALLBAD;
5dee6fb
-          *nread = (ssize_t)rest_length;
5dee6fb
+          *nread = onread;
5dee6fb
+          k->str = ostr;
5dee6fb
+          return CURLE_OK;
5dee6fb
         }
5dee6fb
         break;
5dee6fb
       }
5dee6fb
-- 
5dee6fb
2.14.3
5dee6fb