summaryrefslogtreecommitdiffstats
path: root/updater/install.cpp
diff options
context:
space:
mode:
authorKelvin Zhang <zhangkelvin@google.com>2020-09-19 09:04:48 +0200
committerAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>2020-09-19 09:04:48 +0200
commita5c4d3c016f09d2470a9231d97925cb4322005eb (patch)
tree6a1b77b1e1a62e27ea23f0940266b7557dec8382 /updater/install.cpp
parent[automerger skipped] Merge "Merge mainline-release 6664920 to master - DO NOT MERGE" am: 7a899bb461 am: d3865b7a63 -s ours am: c4eabe78c5 -s ours (diff)
parentMerge "Check for overflow before allocating memory fore decompression." am: c1d2c15785 am: 115a017218 (diff)
downloadandroid_bootable_recovery-a5c4d3c016f09d2470a9231d97925cb4322005eb.tar
android_bootable_recovery-a5c4d3c016f09d2470a9231d97925cb4322005eb.tar.gz
android_bootable_recovery-a5c4d3c016f09d2470a9231d97925cb4322005eb.tar.bz2
android_bootable_recovery-a5c4d3c016f09d2470a9231d97925cb4322005eb.tar.lz
android_bootable_recovery-a5c4d3c016f09d2470a9231d97925cb4322005eb.tar.xz
android_bootable_recovery-a5c4d3c016f09d2470a9231d97925cb4322005eb.tar.zst
android_bootable_recovery-a5c4d3c016f09d2470a9231d97925cb4322005eb.zip
Diffstat (limited to 'updater/install.cpp')
-rw-r--r--updater/install.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/updater/install.cpp b/updater/install.cpp
index cfa4d9d82..295965047 100644
--- a/updater/install.cpp
+++ b/updater/install.cpp
@@ -35,6 +35,7 @@
#include <unistd.h>
#include <utime.h>
+#include <limits>
#include <memory>
#include <string>
#include <vector>
@@ -172,6 +173,11 @@ Value* PackageExtractFileFn(const char* name, State* state,
}
std::string buffer;
+ if (entry.uncompressed_length > std::numeric_limits<size_t>::max()) {
+ return ErrorAbort(state, kPackageExtractFileFailure,
+ "%s(): Entry `%s` Uncompressed size exceeds size of address space.", name,
+ zip_path.c_str());
+ }
buffer.resize(entry.uncompressed_length);
int32_t ret =