Bug 1891933 (CVE-2020-25675)

Summary: CVE-2020-25675 ImageMagick: outside the range of representable values of type 'long' and integer overflow at MagickCore/transform.c and MagickCore/image.c
Product: [Other] Security Response Reporter: Guilherme de Almeida Suckevicz <gsuckevi>
Component: vulnerabilityAssignee: Red Hat Product Security <security-response-team>
Status: CLOSED WONTFIX QA Contact:
Severity: medium Docs Contact:
Priority: medium    
Version: unspecifiedCC: fedora, jhorak, mike, pahan, rhel8-maint, security-response-team, stransky
Target Milestone: ---Keywords: Security
Target Release: ---   
Hardware: All   
OS: Linux   
Whiteboard:
Fixed In Version: ImageMagick 7.0.9-0 Doc Type: If docs needed, set a value
Doc Text:
A flaw was found in ImageMagick. Rounding calculations performed on unconstrained pixel offsets causes undefined behavior in the form of integer overflow and out-of-range values. Such issues could cause a negative impact to application availability or other problems related to undefined behavior, in cases where ImageMagick processes untrusted input data. The highest threat from this vulnerability is to system availability.
Story Points: ---
Clone Of: Environment:
Last Closed: 2020-11-24 23:34:11 UTC Type: ---
Regression: --- Mount Type: ---
Documentation: --- CRM:
Verified Versions: Category: ---
oVirt Team: --- RHEL 7.3 requirements from Atomic Host:
Cloudforms Team: --- Target Upstream Version:
Embargoed:
Bug Depends On: 1901236, 1901237, 1910559    
Bug Blocks: 1891602    

Description Guilherme de Almeida Suckevicz 2020-10-27 17:34:53 UTC
In ImageMagick 7.0.8-68 there are 6 outside the range of representable values of type 'long' and 2 integer overflow at MagickCore/transform.c,image.c.

Reference:
https://github.com/ImageMagick/ImageMagick/issues/1731

Upstream patch:
https://github.com/ImageMagick/ImageMagick/commit/64dc80b2e1907f7f20bf34d4df9483f938b0de71

Comment 1 Todd Cullum 2020-10-28 22:28:56 UTC
Flaw summary:

In the CropImage() and CropImageToTiles() routines of MagickCore/transform.c, rounding calculations performed on unconstrained pixel offsets was causing undefined behavior in the form of integer overflow and out-of-range values as reported by UndefinedBehaviorSanitizer. Such issues could cause a negative impact to application availability or other problems related to undefined behavior, in cases where ImageMagick processes untrusted input data. The upstream patch introduces functionality to constrain the pixel offsets and prevent these issues.

Comment 2 Todd Cullum 2020-10-28 22:40:45 UTC
Acknowledgments:

Name: Suhwan Song (Seoul National University)

Comment 4 Guilherme de Almeida Suckevicz 2020-11-24 19:05:38 UTC
Created ImageMagick tracking bugs for this issue:

Affects: epel-8 [bug 1901236]
Affects: fedora-all [bug 1901237]

Comment 5 Product Security DevOps Team 2020-11-24 23:34:11 UTC
This bug is now closed. Further updates for individual products will be reflected on the CVE page(s):

https://access.redhat.com/security/cve/cve-2020-25675

Comment 7 Eric Christensen 2021-02-11 19:04:20 UTC
Statement:

This flaw is out of support scope for Red Hat Enterprise Linux 5, 6, and 7. Inkscape is not affected because it no longer uses a bundled ImageMagick in Red Hat Enterprise Linux 8. For more information regarding support scopes, please see https://access.redhat.com/support/policy/updates/errata.