libheif is a HEIF and AVIF file format decoder and encoder. Versions 1.21.2 and below contain a heap buffer overflow in MaskImageCodec::decodemaskimage(). When decoding a HEIF file containing a mask image (mski), the function copies the full iloc extent data into a pixel buffer using memcpy(dst, data.data(), data.size()). The copy length data.size() is determined by the iloc extent in the file (attacker-controlled), while the destination buffer is sized based on the declared image dimensions. Because no upper-bound check exists on the data length, a crafted file whose iloc extent exceeds the pixel buffer allocation overflows the heap. The vulnerable single-memcpy branch is reached when the mskC property specifies bitsperpixel = 8 and the ispe property declares an even width ≥ 64 (so that stride == width), with no changes to default security limits or external codec plugins required. This issue has been fixed in version 1.22.0.
{
"binaries": [
{
"binary_name": "heif-gdk-pixbuf",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "heif-thumbnailer",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-examples",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-plugin-aomdec",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-plugin-aomenc",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-plugin-dav1d",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-plugin-ffmpegdec",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-plugin-j2kdec",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-plugin-j2kenc",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-plugin-jpegdec",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-plugin-jpegenc",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-plugin-libde265",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-plugin-rav1e",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-plugin-svtenc",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif-plugin-x265",
"binary_version": "1.17.6-1ubuntu4.3"
},
{
"binary_name": "libheif1",
"binary_version": "1.17.6-1ubuntu4.3"
}
]
}{
"binaries": [
{
"binary_name": "heif-gdk-pixbuf",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "heif-thumbnailer",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "heif-view",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-examples",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-aomdec",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-aomenc",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-dav1d",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-ffmpegdec",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-j2kdec",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-j2kenc",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-jpegdec",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-jpegenc",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-kvazaar",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-libde265",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-rav1e",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-svtenc",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugin-x265",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif-plugins-all",
"binary_version": "1.20.2-1ubuntu0.3"
},
{
"binary_name": "libheif1",
"binary_version": "1.20.2-1ubuntu0.3"
}
]
}{
"binaries": [
{
"binary_name": "heif-gdk-pixbuf",
"binary_version": "1.21.2-3"
},
{
"binary_name": "heif-thumbnailer",
"binary_version": "1.21.2-3"
},
{
"binary_name": "heif-view",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-examples",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-aomdec",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-aomenc",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-dav1d",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-ffmpegdec",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-j2kdec",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-j2kenc",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-jpegdec",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-jpegenc",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-kvazaar",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-libde265",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-rav1e",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-svtenc",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugin-x265",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif-plugins-all",
"binary_version": "1.21.2-3"
},
{
"binary_name": "libheif1",
"binary_version": "1.21.2-3"
}
]
}{
"binaries": [
{
"binary_name": "heif-gdk-pixbuf",
"binary_version": "1.6.1-1ubuntu0.1~esm2"
},
{
"binary_name": "heif-thumbnailer",
"binary_version": "1.6.1-1ubuntu0.1~esm2"
},
{
"binary_name": "libheif-examples",
"binary_version": "1.6.1-1ubuntu0.1~esm2"
},
{
"binary_name": "libheif1",
"binary_version": "1.6.1-1ubuntu0.1~esm2"
}
]
}{
"binaries": [
{
"binary_name": "heif-gdk-pixbuf",
"binary_version": "1.12.0-2ubuntu0.1~esm2"
},
{
"binary_name": "heif-thumbnailer",
"binary_version": "1.12.0-2ubuntu0.1~esm2"
},
{
"binary_name": "libheif-examples",
"binary_version": "1.12.0-2ubuntu0.1~esm2"
},
{
"binary_name": "libheif1",
"binary_version": "1.12.0-2ubuntu0.1~esm2"
}
]
}