CVE-2022-23093

ping reads raw IP packets from the network to process responses in the pr_pack() function.  As part of processing a response ping has toreconstruct the IP header, the ICMP header and if present a "quotedpacket," which represents the packet that generated an ICMP error.  Thequoted packet again has an IP header and an ICMP header.

The pr_pack() copies received IP and ICMP headers into stack buffersfor further processing.  In so doing, it fails to take into account the possible presence of IP option headers following the IP header in either the response or the quoted packet.  When IP options are present, pr_pack() overflows the destination buffer by up to 40 bytes.

The memory safety bugs described above can be triggered by a remotehost, causing the ping program to crash.

The ping process runs in a capability mode sandbox on all affectedversions of FreeBSD and is thus very constrained in how it can interactwith the rest of the system at the point where the bug can occur.
Classic Buffer Overflow
ProviderTypeBase ScoreAtk. VectorAtk. ComplexityPriv. RequiredVector
NISTNIST
6.5 MEDIUM
NETWORK
LOW
LOW
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H
freebsdCNA
---
---
CISA-ADPADP
6.5 MEDIUM
NETWORK
LOW
LOW
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H
CVEADP
---
---