Out-of-bounds Read
CVE-2024-36114
Summary
Aircompressor is a library with ports of the Snappy, LZO, LZ4, and Zstandard compression algorithms to Java. All decompressor implementations of Aircompressor (LZ4, LZO, Snappy, Zstandard) can crash the JVM for certain inputs, and in some cases also leak the content of other memory of the Java process (which could contain sensitive information). When decompressing certain data, the decompressors try to access memory outside the bounds of the given byte arrays or byte buffers. Because Aircompressor uses the JDK class `sun.misc.Unsafe` to speed up memory access, no additional bounds checks are performed, and this has similar security consequences as out-of-bounds access in C or C++, namely it can lead to non-deterministic behavior or crash the JVM. Users should update to the Aircompressor patched version, where these issues have been fixed. When decompressing data from untrusted users, this can be exploited for a Denial-of-service (DoS) attack by crashing the JVM or leaking other sensitive information from the Java process. There are no known workarounds for this issue. This issue affects io.airlift:aircompressor versions prior to 0.27.
- LOW
- NETWORK
- LOW
- UNCHANGED
- NONE
- NONE
- LOW
- HIGH
CWE-125 - Out-of-Bounds Read
Out-of-bounds read is a vulnerability that allows access to memory beyond the authorized accessible location. Such a vulnerability compromises the confidentiality of the trusted environment in the application and enables an attacker to launch further attacks by leveraging the exposed information.
References
Advisory Timeline
- Published