summaryrefslogtreecommitdiffstats
path: root/install.c
diff options
context:
space:
mode:
authorDoug Zongker <dougz@android.com>2010-09-15 03:06:55 +0200
committerDoug Zongker <dougz@android.com>2010-09-15 06:26:38 +0200
commit8e5e4dada713609c9b2c45ea9cf4572bb89ef761 (patch)
treeb1dd9d0f6408811e71dade4f1ccbc52f18114a5e /install.c
parentadd the ability to seek to a raw location while reading MTD partition (diff)
downloadandroid_bootable_recovery-8e5e4dada713609c9b2c45ea9cf4572bb89ef761.tar
android_bootable_recovery-8e5e4dada713609c9b2c45ea9cf4572bb89ef761.tar.gz
android_bootable_recovery-8e5e4dada713609c9b2c45ea9cf4572bb89ef761.tar.bz2
android_bootable_recovery-8e5e4dada713609c9b2c45ea9cf4572bb89ef761.tar.lz
android_bootable_recovery-8e5e4dada713609c9b2c45ea9cf4572bb89ef761.tar.xz
android_bootable_recovery-8e5e4dada713609c9b2c45ea9cf4572bb89ef761.tar.zst
android_bootable_recovery-8e5e4dada713609c9b2c45ea9cf4572bb89ef761.zip
Diffstat (limited to '')
-rw-r--r--install.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/install.c b/install.c
index 35ba6ca70..40f182d77 100644
--- a/install.c
+++ b/install.c
@@ -42,6 +42,7 @@ try_update_binary(const char *path, ZipArchive *zip) {
const ZipEntry* binary_entry =
mzFindZipEntry(zip, ASSUMED_UPDATE_BINARY_NAME);
if (binary_entry == NULL) {
+ mzCloseZipArchive(zip);
return INSTALL_CORRUPT;
}
@@ -49,11 +50,13 @@ try_update_binary(const char *path, ZipArchive *zip) {
unlink(binary);
int fd = creat(binary, 0755);
if (fd < 0) {
+ mzCloseZipArchive(zip);
LOGE("Can't make %s\n", binary);
return 1;
}
bool ok = mzExtractZipEntryToFile(zip, binary_entry, fd);
close(fd);
+ mzCloseZipArchive(zip);
if (!ok) {
LOGE("Can't copy %s\n", ASSUMED_UPDATE_BINARY_NAME);
@@ -298,6 +301,5 @@ install_package(const char *root_path)
/* Verify and install the contents of the package.
*/
int status = handle_update_package(path, &zip);
- mzCloseZipArchive(&zip);
return status;
}