DO NOT MERGE: Initialize the ZipArchive to zero before parsing
The fields of the ZipArchive on the stack are not initialized before we
call libminzip to parse the zip file. As a result, some random memory
location is freed unintentionally when we close the ZipArchive upon
parsing failures.
Bug: 35385357
Test: recompile and run the poc with asan.
Change-Id: I7e7f8ab4816c84a158af7389e1a889f8fc65f079
diff --git a/install.cpp b/install.cpp
index d30890a..05209cd 100644
--- a/install.cpp
+++ b/install.cpp
@@ -481,7 +481,7 @@
}
// Try to open the package.
- ZipArchive zip;
+ ZipArchive zip = {};
int err = mzOpenZipArchive(map.addr, map.length, &zip);
if (err != 0) {
LOGE("Can't open %s\n(%s)\n", path, err != -1 ? strerror(err) : "bad");