SAIL is a cross-platform library for loading and saving images with support for animation, metadata, and ICC profiles. All versions are vulnerable to Heap-based Buffer Overflow through the XWD parser's use of the bytesperline value. The value os read directly from the file as the read size in io->strictread(), and is never compared to the actual size of the destination buffer. An attacker can provide an XWD file with an arbitrarily large bytesper_line, causing a massive write operation beyond the buffer heap allocated for the image pixels. The issue did not have a fix at the time of publication.
{
"binaries": [
{
"binary_name": "libsail-c++-dev",
"binary_version": "0.9.0+repack-2.1build1"
},
{
"binary_name": "libsail-c++0t64",
"binary_version": "0.9.0+repack-2.1build1"
},
{
"binary_name": "libsail-common-dev",
"binary_version": "0.9.0+repack-2.1build1"
},
{
"binary_name": "libsail-common0t64",
"binary_version": "0.9.0+repack-2.1build1"
},
{
"binary_name": "libsail-dev",
"binary_version": "0.9.0+repack-2.1build1"
},
{
"binary_name": "libsail-manip-dev",
"binary_version": "0.9.0+repack-2.1build1"
},
{
"binary_name": "libsail-manip0t64",
"binary_version": "0.9.0+repack-2.1build1"
},
{
"binary_name": "libsail0t64",
"binary_version": "0.9.0+repack-2.1build1"
},
{
"binary_name": "sail-codecs",
"binary_version": "0.9.0+repack-2.1build1"
}
]
}
{
"binaries": [
{
"binary_name": "libsail-c++-dev",
"binary_version": "0.9.9-1"
},
{
"binary_name": "libsail-c++0t64",
"binary_version": "0.9.9-1"
},
{
"binary_name": "libsail-common-dev",
"binary_version": "0.9.9-1"
},
{
"binary_name": "libsail-common0t64",
"binary_version": "0.9.9-1"
},
{
"binary_name": "libsail-dev",
"binary_version": "0.9.9-1"
},
{
"binary_name": "libsail-manip-dev",
"binary_version": "0.9.9-1"
},
{
"binary_name": "libsail-manip0t64",
"binary_version": "0.9.9-1"
},
{
"binary_name": "libsail0t64",
"binary_version": "0.9.9-1"
},
{
"binary_name": "sail-codecs",
"binary_version": "0.9.9-1"
}
]
}