Home

Description

When decoding an OpenEXR file that uses DWAA or DWAB compression, there's an implicit assumption that the height and width are divisible by 8. If the height or width of the image is not divisible by 8, the copy loops at [0] and [1] will continue to write until the next multiple of 8. The buffer td->uncompressed_data is allocated in decode_block based on the precise height and width of the image, so the "rounded-up" multiple of 8 in the copy loop can exceed the buffer bounds, and the write block starting at [2] can corrupt following heap memory. We recommend upgrading to version 8.0 or beyond.

PUBLISHED Reserved 2025-09-19 | Published 2025-10-06 | Updated 2025-10-08 | Assigner Google




HIGH: 8.7CVSS:4.0/AV:A/AC:H/AT:N/PR:N/UI:P/VC:H/VI:H/VA:N/SC:H/SI:H/SA:N

Problem types

CWE-787 Out-of-bounds Write

Product status

Default status
unaffected

9a32b863074ed4140141e0d3613905c6f1fe61c5 before 8.0
affected

7.1.1 before 8.0
affected

Credits

Google Big Sleep finder

References

b.corp.google.com/issues/436510316

cve.org (CVE-2025-59732)

nvd.nist.gov (CVE-2025-59732)

Download JSON