Blame SOURCES/libarchive-3.3.2-CVE-2019-18408.patch

03181a
From 1abcbf1af5209631ccf4fca4ddcab3c863294c85 Mon Sep 17 00:00:00 2001
03181a
From: =?UTF-8?q?Patrik=20Novotn=C3=BD?= <panovotn@redhat.com>
03181a
Date: Wed, 15 Jan 2020 16:10:04 +0100
03181a
Subject: [PATCH] RAR reader: fix use after free
03181a
03181a
If read_data_compressed() returns ARCHIVE_FAILED, the caller is allowed
03181a
to continue with next archive headers. We need to set rar->start_new_table
03181a
after the ppmd7_context got freed, otherwise it won't be allocated again.
03181a
---
03181a
 libarchive/archive_read_support_format_rar.c | 4 +++-
03181a
 1 file changed, 3 insertions(+), 1 deletion(-)
03181a
03181a
diff --git a/libarchive/archive_read_support_format_rar.c b/libarchive/archive_read_support_format_rar.c
03181a
index cbb14c32..9c26ef97 100644
03181a
--- a/libarchive/archive_read_support_format_rar.c
03181a
+++ b/libarchive/archive_read_support_format_rar.c
03181a
@@ -1037,8 +1037,10 @@ archive_read_format_rar_read_data(struct archive_read *a, const void **buff,
03181a
   case COMPRESS_METHOD_GOOD:
03181a
   case COMPRESS_METHOD_BEST:
03181a
     ret = read_data_compressed(a, buff, size, offset);
03181a
-    if (ret != ARCHIVE_OK && ret != ARCHIVE_WARN)
03181a
+    if (ret != ARCHIVE_OK && ret != ARCHIVE_WARN) {
6d3b0f
       __archive_ppmd7_functions.Ppmd7_Free(&rar->ppmd7_context);
03181a
+      rar->start_new_table = 1;
03181a
+    }
03181a
     break;
03181a
 
03181a
   default:
03181a
-- 
03181a
2.24.1
03181a