summaryrefslogtreecommitdiffstats
path: root/minzip/Zip.c
diff options
context:
space:
mode:
authorElliott Hughes <enh@google.com>2015-04-30 06:44:20 +0200
committerAndroid Git Automerger <android-git-automerger@android.com>2015-04-30 06:44:20 +0200
commitb2007b70cafac781565ab20c299353cfb0415f71 (patch)
treee2c357667b0e76e6fa5a43c7a7951c872c373e9c /minzip/Zip.c
parentam 15a2e46b: am f7466f9f: Stop using adb_strtok, and check argument validity. (diff)
parentam 34d3a3d0: am 34c7731a: Merge "Check all lseek calls succeed." (diff)
downloadandroid_bootable_recovery-b2007b70cafac781565ab20c299353cfb0415f71.tar
android_bootable_recovery-b2007b70cafac781565ab20c299353cfb0415f71.tar.gz
android_bootable_recovery-b2007b70cafac781565ab20c299353cfb0415f71.tar.bz2
android_bootable_recovery-b2007b70cafac781565ab20c299353cfb0415f71.tar.lz
android_bootable_recovery-b2007b70cafac781565ab20c299353cfb0415f71.tar.xz
android_bootable_recovery-b2007b70cafac781565ab20c299353cfb0415f71.tar.zst
android_bootable_recovery-b2007b70cafac781565ab20c299353cfb0415f71.zip
Diffstat (limited to 'minzip/Zip.c')
-rw-r--r--minzip/Zip.c6
1 files changed, 2 insertions, 4 deletions
diff --git a/minzip/Zip.c b/minzip/Zip.c
index d3ff79be6..40712e03a 100644
--- a/minzip/Zip.c
+++ b/minzip/Zip.c
@@ -675,13 +675,11 @@ static bool writeProcessFunction(const unsigned char *data, int dataLen,
}
ssize_t soFar = 0;
while (true) {
- ssize_t n = write(fd, data+soFar, dataLen-soFar);
+ ssize_t n = TEMP_FAILURE_RETRY(write(fd, data+soFar, dataLen-soFar));
if (n <= 0) {
LOGE("Error writing %zd bytes from zip file from %p: %s\n",
dataLen-soFar, data+soFar, strerror(errno));
- if (errno != EINTR) {
- return false;
- }
+ return false;
} else if (n > 0) {
soFar += n;
if (soFar == dataLen) return true;