QEMU before 8.2.0 has an integer underflow, and resultant buffer overflow, via a TI command when an expected non-DMA transfer length is less than the length of the available FIFO data. This occurs in espdonodma in hw/scsi/esp.c because of an underflow of async_len.
{ "availability": "No subscription required", "binaries": [ { "binary_name": "qemu", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-block-extra", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-guest-agent", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system-arm", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system-common", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system-data", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system-gui", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system-mips", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system-misc", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system-ppc", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system-s390x", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system-sparc", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system-x86", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system-x86-microvm", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-system-x86-xen", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-user", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-user-binfmt", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-user-static", "binary_version": "1:6.2+dfsg-2ubuntu6.22" }, { "binary_name": "qemu-utils", "binary_version": "1:6.2+dfsg-2ubuntu6.22" } ] }