CVE Vulnerabilities

CVE-2019-13310

Missing Release of Memory after Effective Lifetime

Published: Jul 05, 2019 | Modified: Nov 21, 2024
CVSS 3.x
6.5
MEDIUM
Source:
NVD
CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:U/C:N/I:N/A:H
CVSS 2.x
4.3 MEDIUM
AV:N/AC:M/Au:N/C:N/I:N/A:P
RedHat/V2
RedHat/V3
5.3 LOW
CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L
Ubuntu
LOW
root.io logo minimus.io logo echo.ai logo

ImageMagick 7.0.8-50 Q16 has memory leaks at AcquireMagickMemory because of an error in MagickWand/mogrify.c.

Weakness

The product does not sufficiently track and release allocated memory after it has been used, making the memory unavailable for reallocation and reuse.

Affected Software

NameVendorStart VersionEnd Version
ImagemagickImagemagick7.0.8-50-q16 (including)7.0.8-50-q16 (including)
Red Hat Enterprise Linux 7RedHatautotrace-0:0.31.1-38.el7*
Red Hat Enterprise Linux 7RedHatemacs-1:24.3-23.el7*
Red Hat Enterprise Linux 7RedHatImageMagick-0:6.9.10.68-3.el7*
Red Hat Enterprise Linux 7RedHatinkscape-0:0.92.2-3.el7*
ImagemagickUbuntubionic*
ImagemagickUbuntucosmic*
ImagemagickUbuntudevel*
ImagemagickUbuntudisco*
ImagemagickUbuntueoan*
ImagemagickUbuntuesm-apps/focal*
ImagemagickUbuntuesm-apps/jammy*
ImagemagickUbuntuesm-apps/noble*
ImagemagickUbuntuesm-infra-legacy/trusty*
ImagemagickUbuntuesm-infra/bionic*
ImagemagickUbuntuesm-infra/xenial*
ImagemagickUbuntufocal*
ImagemagickUbuntujammy*
ImagemagickUbuntukinetic*
ImagemagickUbuntulunar*
ImagemagickUbuntumantic*
ImagemagickUbuntunoble*
ImagemagickUbuntuoracular*
ImagemagickUbuntutrusty*
ImagemagickUbuntutrusty/esm*
ImagemagickUbuntuupstream*
ImagemagickUbuntuxenial*

Potential Mitigations

  • Choose a language or tool that provides automatic memory management, or makes manual memory management less error-prone.
  • For example, glibc in Linux provides protection against free of invalid pointers.
  • When using Xcode to target OS X or iOS, enable automatic reference counting (ARC) [REF-391].
  • To help correctly and consistently manage memory when programming in C++, consider using a smart pointer class such as std::auto_ptr (defined by ISO/IEC ISO/IEC 14882:2003), std::shared_ptr and std::unique_ptr (specified by an upcoming revision of the C++ standard, informally referred to as C++ 1x), or equivalent solutions such as Boost.

References