shithub: riscv

Download patch

ref: 6baaf0a7735a875d5d5384362e535ce127996926
parent: 5eec707368a91687c5e8ff7941ab6df5bf9e7fa3
author: cinap_lenrek <[email protected]>
date: Sun Aug 5 22:25:22 EDT 2012

unzip/zipfs: skip over variable length comment in end of table of content record

--- a/sys/src/cmd/gzip/unzip.c
+++ b/sys/src/cmd/gzip/unzip.c
@@ -529,7 +529,7 @@
 findCDir(Biobuf *bin, char *file)
 {
 	vlong ecoff;
-	long off, size, m;
+	long off, size;
 	int entries, zclen, dn, ds, de;
 
 	ecoff = Bseek(bin, -ZECHeadSize, 2);
@@ -540,11 +540,16 @@
 	}
 	if(setjmp(zjmp))
 		return -1;
-
-	if((m=get4(bin)) != ZECHeader){
-		fprint(2, "unzip: bad magic number for table of contents of %s: %#.8lx\n", file, m);
-		longjmp(seekjmp, 1);
-		return -1;
+	off = 0;
+	while(get4(bin) != ZECHeader){
+		if(ecoff <= 0 || off >= 1024){
+			fprint(2, "unzip: cannot find end of table of contents in %s\n", file);
+			longjmp(seekjmp, 1);
+			return -1;
+		}
+		off++;
+		ecoff--;
+		Bseek(bin, ecoff, 0);
 	}
 	dn = get2(bin);
 	ds = get2(bin);
--- a/sys/src/cmd/tapefs/zipfs.c
+++ b/sys/src/cmd/tapefs/zipfs.c
@@ -189,10 +189,14 @@
 	ecoff = Bseek(bin, -ZECHeadSize, 2);
 	if(ecoff < 0)
 		sysfatal("can't seek to header");
-
-	if(get4(bin) != ZECHeader)
-		sysfatal("bad magic number on directory");
-
+	off = 0;
+	while(get4(bin) != ZECHeader){
+		if(ecoff <= 0 || off >= 1024)
+			sysfatal("bad magic number");
+		off++;
+		ecoff--;
+		Bseek(bin, ecoff, 0);
+	}
 	get2(bin);
 	get2(bin);
 	get2(bin);