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"
}
]
}