Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

zlib v1.2.12 causes java.util.zip.ZipException #613

Closed
rx80 opened this issue Mar 29, 2022 · 11 comments
Closed

zlib v1.2.12 causes java.util.zip.ZipException #613

rx80 opened this issue Mar 29, 2022 · 11 comments

Comments

@rx80
Copy link

rx80 commented Mar 29, 2022

The one way i can reliably reproduce this is as follows:

npm install google-closure-compiler
npm exec google-closure-compiler

With previous (working) version of zlib-1.2.11 it runs fine.

Upgrading to zlib-1.2.12 causes this error:

java.util.zip.ZipException: invalid entry CRC (expected 0x4e1f14a4 but got 0xb1e0eb5b)
        at java.util.zip.ZipInputStream.readEnd(ZipInputStream.java:410)
        at java.util.zip.ZipInputStream.read(ZipInputStream.java:199)
        at java.util.zip.ZipInputStream.closeEntry(ZipInputStream.java:143)
        at java.util.zip.ZipInputStream.getNextEntry(ZipInputStream.java:121)
        at com.google.javascript.jscomp.AbstractCommandLineRunner.getBuiltinExterns(AbstractCommandLineRunner.java:481)
        at com.google.javascript.jscomp.CommandLineRunner.createExterns(CommandLineRunner.java:2083)
        at com.google.javascript.jscomp.AbstractCommandLineRunner.doRun(AbstractCommandLineRunner.java:1168)
        at com.google.javascript.jscomp.AbstractCommandLineRunner.run(AbstractCommandLineRunner.java:532)
        at com.google.javascript.jscomp.CommandLineRunner.main(CommandLineRunner.java:2241)

Downgrading to 1.2.11 fixes it.

This was compiled on Gentoo with GCC 11.2.1, no special CFLAGS.

Gentoo bug: https://bugs.gentoo.org/836370

@jpalus
Copy link

jpalus commented Mar 30, 2022

Experiencing the same issue in different Linux distribution but sadly it seems to be random or at least so far I was not able to create deterministic reproducer.

@jpalus
Copy link

jpalus commented Mar 30, 2022

So far I was able to trigger error in jar:

java.io.IOException: Push back buffer is full
	at java.base/java.io.PushbackInputStream.unread(PushbackInputStream.java:229)
	at java.base/java.util.zip.ZipInputStream.readEnd(ZipInputStream.java:361)
	at java.base/java.util.zip.ZipInputStream.read(ZipInputStream.java:199)
	at java.base/java.util.zip.ZipInputStream.closeEntry(ZipInputStream.java:143)
	at jdk.jartool/sun.tools.jar.Main.extractFile(Main.java:1456)
	at jdk.jartool/sun.tools.jar.Main.extract(Main.java:1363)
	at jdk.jartool/sun.tools.jar.Main.run(Main.java:409)
	at jdk.jartool/sun.tools.jar.Main.main(Main.java:1680)

Bisected to f8719f5:

commit f8719f5ae5acdc31d3794ddfea8ac963359de41e (HEAD)
Author: Mark Adler <[email protected]>
Date:   Tue Dec 11 01:11:38 2018 -0800

    Speed up software CRC-32 computation by a factor of 1.5 to 3.

The problem seems to be in zip creation -- jar with this commit produces zip that cannot be extracted by either 1.2.11 or 1.2.12.

Attaching broken sample (created on linux x86-64).
unoloader.zip

@jpalus
Copy link

jpalus commented Mar 30, 2022

Note that above issue is only reproducible on x86-64. Also tried x86 32-bit, arm 32-bit and arm 64-bit but all seem to work fine.

@jpalus
Copy link

jpalus commented Mar 30, 2022

unzip on attached zip reports bad CRC:

$ unzip unoloader.zip 
Archive:  /home/users/jan/unoloader.zip
   creating: META-INF/
  inflating: META-INF/MANIFEST.MF     bad CRC 53958e9f  (should be 48958ad5)
  inflating: module-info.class       
   creating: com/
   creating: com/sun/
   creating: com/sun/star/
   creating: com/sun/star/lib/
   creating: com/sun/star/lib/unoloader/
  inflating: com/sun/star/lib/unoloader/UnoLoader$1.class  
  inflating: com/sun/star/lib/unoloader/UnoLoader.class  
  inflating: com/sun/star/lib/unoloader/UnoClassLoader.class  

@jpalus
Copy link

jpalus commented Mar 30, 2022

Issue appears to be related to change in treatment of higher order bytes of crc parameter to crc32() function. Given following code:

#include <stdio.h>
#include <zlib.h>

int main() {
	printf("%lx\n", crc32(0xe3d73c3c, "a", 1));
	printf("%lx\n", crc32(0xffffffffe3d73c3c, "a", 1));
	return 0;
}

zlib 1.2.11 prints same result twice:

c73b15f8
c73b15f8

while zlib 1.2.12 gives two different values:

c73b15f8
ffffff383b15f8

This affects java since it uses smaller unsigned int that affects higher order bytes.

pld-gitsync pushed a commit to pld-linux/zlib that referenced this issue Mar 30, 2022
@jpalus
Copy link

jpalus commented Mar 30, 2022

As a workaround applied:

diff --git a/crc32.c b/crc32.c
index a1bdce5..748b7ba 100644
--- a/crc32.c
+++ b/crc32.c
@@ -19,6 +19,7 @@
   MAKECRCH can be #defined to write out crc32.h. A main() routine is also
   produced, so that this one source file can be compiled to an executable.
  */
+#include <limits.h>
 
 #ifdef MAKECRCH
 #  include <stdio.h>
@@ -1065,7 +1066,12 @@ unsigned long ZEXPORT crc32(crc, buf, len)
     const unsigned char FAR *buf;
     uInt len;
 {
+/* if sizeof(unsigned long) > 4 */
+#if ULONG_MAX > 0xffffffffUL
+    return crc32_z(crc & 0xffffffffUL, buf, len);
+#else
     return crc32_z(crc, buf, len);
+#endif
 }
 
 /* ========================================================================= */

@ydroneaud
Copy link

is crc32() returning sign extended CRC32 values ?

@madler
Copy link
Owner

madler commented Mar 30, 2022

This does not appear to be a CRC output problem, but rather a CRC input problem. It looks like if crc32() is being given an incorrect initial value, it now gives an incorrect result. Whereas, before, the bug in the application was hidden by zlib. I will look into this immediately, since the previous behavior should be retained, despite the bug in the application.

@madler
Copy link
Owner

madler commented Mar 30, 2022

Let me know if this commit remedies the issue: ec3df00 .

@jpalus
Copy link

jpalus commented Mar 30, 2022

@madler confirmed ec3df00 fixes jar.

@madler
Copy link
Owner

madler commented Mar 30, 2022

Thank you!

@madler madler closed this as completed Mar 30, 2022
bob-beck pushed a commit to openbsd/src that referenced this issue May 8, 2022
…tions

on some older hardware, see madler/zlib#613

Pointed out by tj and sthen

commit ec3df00224d4b396e2ac6586ab5d25f673caa4c2
Author: Mark Adler <[email protected]>
Date:   Wed Mar 30 11:14:53 2022 -0700

    Correct incorrect inputs provided to the CRC functions.

    The previous releases of zlib were not sensitive to incorrect CRC
    inputs with bits set above the low 32. This commit restores that
    behavior, so that applications with such bugs will continue to
    operate as before.
bob-beck pushed a commit to openbsd/src that referenced this issue May 8, 2022
…tions

on some older hardware, see madler/zlib#613

Pointed out by tj and sthen

commit ec3df00224d4b396e2ac6586ab5d25f673caa4c2
Author: Mark Adler <[email protected]>
Date:   Wed Mar 30 11:14:53 2022 -0700

    Correct incorrect inputs provided to the CRC functions.

    The previous releases of zlib were not sensitive to incorrect CRC
    inputs with bits set above the low 32. This commit restores that
    behavior, so that applications with such bugs will continue to
    operate as before.
syncmage pushed a commit to sourcemage/grimoire that referenced this issue Jun 23, 2022
PATCHLEVEL++
Apply 0002-fix-crc32.patch
2.12 breaks CRC32 for programs like java
See madler/zlib#613
zeroshade added a commit to apache/arrow that referenced this issue Aug 15, 2022
Downgrading to `zlib=1.2.11` fixes the existing issue as reported in madler/zlib#613 until the patch is released.

Authored-by: Matt Topol <[email protected]>
Signed-off-by: Matt Topol <[email protected]>
ksuarez1423 pushed a commit to ksuarez1423/arrow that referenced this issue Aug 15, 2022
…#13885)

Downgrading to `zlib=1.2.11` fixes the existing issue as reported in madler/zlib#613 until the patch is released.

Authored-by: Matt Topol <[email protected]>
Signed-off-by: Matt Topol <[email protected]>
ksuarez1423 pushed a commit to ksuarez1423/arrow that referenced this issue Aug 15, 2022
…#13885)

Downgrading to `zlib=1.2.11` fixes the existing issue as reported in madler/zlib#613 until the patch is released.

Authored-by: Matt Topol <[email protected]>
Signed-off-by: Matt Topol <[email protected]>
lidavidm added a commit to lidavidm/zlib-feedstock that referenced this issue Sep 12, 2022
This backports the patch for madler/zlib#613, which was causing
issues for the Closure compiler in particular.
lidavidm added a commit to lidavidm/zlib-feedstock that referenced this issue Sep 12, 2022
This backports the patch for madler/zlib#613, which was causing
issues for the Closure compiler in particular.
zagto pushed a commit to zagto/arrow that referenced this issue Oct 7, 2022
…#13885)

Downgrading to `zlib=1.2.11` fixes the existing issue as reported in madler/zlib#613 until the patch is released.

Authored-by: Matt Topol <[email protected]>
Signed-off-by: Matt Topol <[email protected]>
mfrw added a commit to microsoft/azurelinux that referenced this issue Apr 27, 2023
mfrw added a commit to microsoft/azurelinux that referenced this issue Apr 28, 2023
The releases of zlib < 1.2.13 are not sensitive to incorrect CRC
inputs with bits set above the low 32. Bump version to 1.2.13 to
fix this issue.

Reference: madler/zlib#613
Signed-off-by: Muhammad Falak R Wani <[email protected]>
joebonrichie pushed a commit to solus-packages/zlib that referenced this issue Aug 15, 2023
Summary: Fixes a CPU-dependent issue that breaks Maven builds (Zlib issue: madler/zlib#613)

Test Plan:
- Rebuilt a few revdeps
- Tested to see if build error was still present (I encountered the linked issue) and it wasn't

Reviewers: #triage_team, Girtablulu

Reviewed By: #triage_team, Girtablulu

Subscribers: Girtablulu

Differential Revision: https://dev.getsol.us/D13176
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants