ImageMagick is free and open-source software used for editing and manipulating digital images. ImageMagick versions lower than 14.8.2 include insecure functions: SeekBlob(), which permits advancing the stream offset beyond the current end without increasing capacity, and WriteBlob(), which then expands by quantum + length (amortized) instead of offset + length, and copies to data + offset. When offset ≫ extent, the copy targets memory beyond the allocation, producing a deterministic heap write on 64-bit builds. No 2⁶⁴ arithmetic wrap, external delegates, or policy settings are required. This is fixed in version 14.8.2.
A heap overflow condition is a buffer overflow, where the buffer that can be overwritten is allocated in the heap portion of memory, generally meaning that the buffer was allocated using a routine such as malloc().
Name | Vendor | Start Version | End Version |
---|---|---|---|
Imagemagick | Imagemagick | * | 6.9.13-29 (excluding) |
Imagemagick | Imagemagick | 7.0.0-0 (including) | 7.1.2-3 (excluding) |
Imagemagick | Ubuntu | devel | * |
Imagemagick | Ubuntu | esm-apps/focal | * |
Imagemagick | Ubuntu | esm-apps/jammy | * |
Imagemagick | Ubuntu | esm-apps/noble | * |
Imagemagick | Ubuntu | esm-infra-legacy/trusty | * |
Imagemagick | Ubuntu | esm-infra/bionic | * |
Imagemagick | Ubuntu | esm-infra/xenial | * |
Imagemagick | Ubuntu | jammy | * |
Imagemagick | Ubuntu | noble | * |
Imagemagick | Ubuntu | plucky | * |
Imagemagick | Ubuntu | questing | * |
Imagemagick | Ubuntu | upstream | * |