PT-2025-29948 · Openzeppelin · Openzeppelin Contracts
Amxx
·
Publicado
2025-07-17
·
Atualizado
2025-07-17
·
CVE-2025-54070
CVSS v4.0
6.9
Média
| Vetor | AV:N/AC:L/AT:N/PR:N/UI:N/VC:N/VI:L/VA:L/SC:N/SI:N/SA:N/E:X/CR:X/IR:X/AR:X/MAV:X/MAC:X/MAT:X/MPR:X/MUI:X/MVC:X/MVI:X/MVA:X/MSC:X/MSI:X/MSA:X/S:X/AU:X/R:X/V:X/RE:X/U:X |
Nome do Software Vulnerável e Versões Afetadas
OpenZeppelin Contracts versões 5.2.0 a 5.3.9
Descrição
A função
lastIndexOf(bytes,byte,uint256) na biblioteca Bytes.sol pode acessar memória não inicializada sob condições específicas. Isso ocorre quando o comprimento do buffer fornecido é zero (buffer.length == 0) e a posição (pos) não é igual ao valor máximo para um inteiro sem sinal de 256 bits (type(uint256).max). O argumento pos pode ser usado para acessar dados fora dos limites pretendidos do buffer, potencialmente levando a erros de out-of-gas ou ao retorno de um índice inválido. A função lê a memória no offset buffer + 0x20 + pos. Se a memória nesse local corresponder ao padrão de busca, a função retorna um índice fora dos limites em vez do valor máximo esperado. Código que depende do retorno de type(uint256).max pela função para buffers vazios ou que utiliza o índice retornado sem verificação de limites pode apresentar comportamento indefinido.Recomendações
OpenZeppelin Contracts versões 5.2.0 a 5.3.9: Atualize para a versão 5.4.0.
Exploit
Correção
Out of bounds Read
Encontrou algum problema na descrição? Tem algo a acrescentar? Fique à vontade para nos escrever 👾
Enumeração de Fraquezas
Identificadores relacionados
Produtos afetados
Openzeppelin Contracts