cups-filters contains backends, filters, and other software required to get the cups printing service working on operating systems other than macos. In cups-filters prior to 1.28.18, by crafting a PDF file with a large MediaBox value, an attacker can cause CUPS-Filter 1.x’s pdftoraster tool to write beyond the bounds of an array. First, a PDF with a large MediaBox width value causes header.cupsWidth to become large. Next, the calculation of bytesPerLine = (header.cupsBitsPerPixel * header.cupsWidth + 7) / 8 overflows, resulting in a small value. Then, lineBuf is allocated with the small bytesPerLine size. Finally, convertLineChunked calls writePixel8, which attempts to write to lineBuf outside of its buffer size (out of bounds write). In libcupsfilters, the maintainers found the same bytesPerLine multiplication without overflow check, but the provided test case does not cause an overflow there, because the values are different. Commit 50d94ca0f2fa6177613c97c59791bde568631865 contains a patch, which is incorporated into cups-filters version 1.28.18.
{
"binaries": [
{
"binary_version": "1.28.15-0ubuntu1.5",
"binary_name": "cups-browsed"
},
{
"binary_version": "1.28.15-0ubuntu1.5",
"binary_name": "cups-filters"
},
{
"binary_version": "1.28.15-0ubuntu1.5",
"binary_name": "cups-filters-core-drivers"
},
{
"binary_version": "1.28.15-0ubuntu1.5",
"binary_name": "libcupsfilters-dev"
},
{
"binary_version": "1.28.15-0ubuntu1.5",
"binary_name": "libcupsfilters1"
},
{
"binary_version": "1.28.15-0ubuntu1.5",
"binary_name": "libfontembed-dev"
},
{
"binary_version": "1.28.15-0ubuntu1.5",
"binary_name": "libfontembed1"
}
],
"availability": "No subscription required"
}{
"binaries": [
{
"binary_version": "2.0.0-0ubuntu7.2",
"binary_name": "libcupsfilters-dev"
},
{
"binary_version": "2.0.0-0ubuntu7.2",
"binary_name": "libcupsfilters-tests"
},
{
"binary_version": "2.0.0-0ubuntu7.2",
"binary_name": "libcupsfilters2-common"
},
{
"binary_version": "2.0.0-0ubuntu7.2",
"binary_name": "libcupsfilters2t64"
}
],
"availability": "No subscription required"
}{
"binaries": [
{
"binary_version": "2.1.1-0ubuntu2.1",
"binary_name": "libcupsfilters-dev"
},
{
"binary_version": "2.1.1-0ubuntu2.1",
"binary_name": "libcupsfilters-tests"
},
{
"binary_version": "2.1.1-0ubuntu2.1",
"binary_name": "libcupsfilters2-common"
},
{
"binary_version": "2.1.1-0ubuntu2.1",
"binary_name": "libcupsfilters2t64"
}
],
"availability": "No subscription required"
}{
"binaries": [
{
"binary_version": "2.1.1-0ubuntu3.1",
"binary_name": "libcupsfilters-dev"
},
{
"binary_version": "2.1.1-0ubuntu3.1",
"binary_name": "libcupsfilters-tests"
},
{
"binary_version": "2.1.1-0ubuntu3.1",
"binary_name": "libcupsfilters2-common"
},
{
"binary_version": "2.1.1-0ubuntu3.1",
"binary_name": "libcupsfilters2t64"
}
],
"availability": "No subscription required"
}{
"binaries": [
{
"binary_version": "1.8.3-2ubuntu3.5+esm3",
"binary_name": "cups-browsed"
},
{
"binary_version": "1.8.3-2ubuntu3.5+esm3",
"binary_name": "cups-filters"
},
{
"binary_version": "1.8.3-2ubuntu3.5+esm3",
"binary_name": "cups-filters-core-drivers"
},
{
"binary_version": "1.8.3-2ubuntu3.5+esm3",
"binary_name": "libcupsfilters-dev"
},
{
"binary_version": "1.8.3-2ubuntu3.5+esm3",
"binary_name": "libcupsfilters1"
},
{
"binary_version": "1.8.3-2ubuntu3.5+esm3",
"binary_name": "libfontembed-dev"
},
{
"binary_version": "1.8.3-2ubuntu3.5+esm3",
"binary_name": "libfontembed1"
}
],
"availability": "Available with Ubuntu Pro (Infra-only): https://ubuntu.com/pro"
}{
"binaries": [
{
"binary_version": "1.20.2-0ubuntu3.3+esm2",
"binary_name": "cups-browsed"
},
{
"binary_version": "1.20.2-0ubuntu3.3+esm2",
"binary_name": "cups-filters"
},
{
"binary_version": "1.20.2-0ubuntu3.3+esm2",
"binary_name": "cups-filters-core-drivers"
},
{
"binary_version": "1.20.2-0ubuntu3.3+esm2",
"binary_name": "libcupsfilters-dev"
},
{
"binary_version": "1.20.2-0ubuntu3.3+esm2",
"binary_name": "libcupsfilters1"
},
{
"binary_version": "1.20.2-0ubuntu3.3+esm2",
"binary_name": "libfontembed-dev"
},
{
"binary_version": "1.20.2-0ubuntu3.3+esm2",
"binary_name": "libfontembed1"
}
],
"availability": "Available with Ubuntu Pro (Infra-only): https://ubuntu.com/pro"
}{
"binaries": [
{
"binary_version": "1.27.4-1ubuntu0.4+esm1",
"binary_name": "cups-browsed"
},
{
"binary_version": "1.27.4-1ubuntu0.4+esm1",
"binary_name": "cups-filters"
},
{
"binary_version": "1.27.4-1ubuntu0.4+esm1",
"binary_name": "cups-filters-core-drivers"
},
{
"binary_version": "1.27.4-1ubuntu0.4+esm1",
"binary_name": "libcupsfilters-dev"
},
{
"binary_version": "1.27.4-1ubuntu0.4+esm1",
"binary_name": "libcupsfilters1"
},
{
"binary_version": "1.27.4-1ubuntu0.4+esm1",
"binary_name": "libfontembed-dev"
},
{
"binary_version": "1.27.4-1ubuntu0.4+esm1",
"binary_name": "libfontembed1"
}
],
"availability": "Available with Ubuntu Pro (Infra-only): https://ubuntu.com/pro"
}