CVE-2019-14842
CVE-2019-14842
Em resumo
O protocolo NBD tem um bug onde um servidor pode escrever dados no local errado da memória devido a um erro na verificação de deslocamentos de chunks. Isso permite que um atacante que controla o servidor sobrescreva memória e execute código arbitrário no cliente.
Detalhe técnico
Uma confusão entre inteiros com e sem sinal na validação de limites para respostas estruturadas no protocolo NBD newstyle falha em validar adequadamente deslocamentos negativos de chunks, permitindo que um servidor controlado por um atacante escreva dados antes do buffer de leitura do cliente. A exploração resulta em corrupção de memória na stack ou heap, viabilizando execução de código arbitrário no contexto do processo cliente NBD.
Resumo gerado e traduzido por IA a partir da descrição oficial.
Structured reply is a feature of the newstyle NBD protocol allowing the server to send a reply in chunks. A bounds check which was supposed to test for chunk offsets smaller than the beginning of the request did not work because of signed/unsigned confusion. If one of these chunks contains a negative offset then data under control of the server is written to memory before the read buffer supplied by the client. If the read buffer is located on the stack then this allows the stack return address from nbd_pread() to be trivially modified, allowing arbitrary code execution under the control of the server. If the buffer is located on the heap then other memory objects before the buffer can be overwritten, which again would usually lead to arbitrary code execution.
CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:L