← voltar
CVE-2025-57812

[BIGSLEEP-434612419] CUPS-Filters has heap-buffer-overflow write in `cfImageLut()`

CVSS 3.7 LOWEPSS 0.4%CWE-125CWE-787
Em resumo

Uma falha no software de impressão CUPS permite que um arquivo TIFF malicioso cause estouro de memória durante o processamento de impressão. Um atacante pode explorar isso enviando um trabalho de impressão especialmente preparado, causando possível travamento ou mau funcionamento do serviço de impressão.

Detalhe técnico

CVE-2025-57812 é um estouro de buffer heap na função `cfImageLut()` do CUPS-Filters ao processar imagens TIFF (versões ≤1.28.17 e libcupsfilters 2.0.0–2.1.1). A vulnerabilidade ocorre quando o buffer de pixels é alocado com um cálculo de bytes-por-pixel, mas processado com um multiplicador diferente (3x), causando acesso à memória fora dos limites quando um TIFF manipulado é enviado com opções que definem bytes-por-pixel como 1. A exploração requer que o filtro `imagetoraster` ou `cfFilterImageToRaster()` seja invocado no pipeline de processamento da impressora.

Resumo gerado e traduzido por IA a partir da descrição oficial.
CUPS is a standards-based, open-source printing system, and `libcupsfilters` contains the code of the filters of the former `cups-filters` package as library functions to be used for the data format conversion tasks needed in Printer Applications. In CUPS-Filters versions up to and including 1.28.17 and libscupsfilters versions 2.0.0 through 2.1.1, CUPS-Filters's `imagetoraster` filter has an out of bounds read/write vulnerability in the processing of TIFF image files. While the pixel buffer is allocated with the number of pixels times a pre-calculated bytes-per-pixel value, the function which processes these pixels is called with a size of the number of pixels times 3. When suitable inputs are passed, the bytes-per-pixel value can be set to 1 and bytes outside of the buffer bounds get processed. In order to trigger the bug, an attacker must issue a print job with a crafted TIFF file, and pass appropriate print job options to control the bytes-per-pixel value of the output format. They must choose a printer configuration under which the `imagetoraster` filter or its C-function equivalent `cfFilterImageToRaster()` gets invoked. The vulnerability exists in both CUPS-Filters 1.x and the successor library libcupsfilters (CUPS-Filters 2.x). In CUPS-Filters 2.x, the vulnerable function is `_cfImageReadTIFF() in libcupsfilters`. When this function is invoked as part of `cfFilterImageToRaster()`, the caller passes a look-up-table during whose processing the out of bounds memory access happens. In CUPS-Filters 1.x, the equivalent functions are all found in the cups-filters repository, which is not split into subprojects yet, and the vulnerable code is in `_cupsImageReadTIFF()`, which is called through `cupsImageOpen()` from the `imagetoraster` tool. A patch is available in commit b69dfacec7f176281782e2f7ac44f04bf9633cfa.
CVSS:3.1/AV:A/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:N

Quer saber se a sua infraestrutura está exposta a isto?

Falar com a TrueHacking →