CVE-2026-31607
Description
In the Linux kernel, the following vulnerability has been resolved:
usbip: validate number_of_packets in usbip_pack_ret_submit()
When a USB/IP client receives a RET_SUBMIT response, usbip_pack_ret_submit() unconditionally overwrites urb->number_of_packets from the network PDU. This value is subsequently used as the loop bound in usbip_recv_iso() and usbip_pad_iso() to iterate over urb->iso_frame_desc[], a flexible array whose size was fixed at URB allocation time based on the *original* number_of_packets from the CMD_SUBMIT.
A malicious USB/IP server can set number_of_packets in the response to a value larger than what was originally submitted, causing a heap out-of-bounds write when usbip_recv_iso() writes to urb->iso_frame_desc[i] beyond the allocated region.
KASAN confirmed this with kernel 7.0.0-rc5:
BUG: KASAN: slab-out-of-bounds in usbip_recv_iso+0x46a/0x640 Write of size 4 at addr ffff888106351d40 by task vhci_rx/69
The buggy address is located 0 bytes to the right of allocated 320-byte region [ffff888106351c00, ffff888106351d40)
The server side (stub_rx.c) and gadget side (vudc_rx.c) already validate number_of_packets in the CMD_SUBMIT path since commits c6688ef9f297 ("usbip: fix stub_rx: harden CMD_SUBMIT path to handle malicious input") and b78d830f0049 ("usbip: fix vudc_rx: harden CMD_SUBMIT path to handle malicious input"). The server side validates against USBIP_MAX_ISO_PACKETS because no URB exists yet at that point. On the client side we have the original URB, so we can use the tighter bound: the response must not exceed the original number_of_packets.
This mirrors the existing validation of actual_length against transfer_buffer_length in usbip_recv_xbuff(), which checks the response value against the original allocation size.
Kelvin Mbogo's series ("usb: usbip: fix integer overflow in usbip_recv_iso()", v2) hardens the receive-side functions themselves; this patch complements that work by catching the bad value at its source -- in usbip_pack_ret_submit() before the overwrite -- and using the tighter per-URB allocation bound rather than the global USBIP_MAX_ISO_PACKETS limit.
Fix this by checking rpdu->number_of_packets against urb->number_of_packets in usbip_pack_ret_submit() before the overwrite. On violation, clamp to zero so that usbip_recv_iso() and usbip_pad_iso() safely return early.
AI Insight
LLM-synthesized narrative grounded in this CVE's description and references.
Affected products
95- osv-coords93 versionspkg:apk/chainguard/linux-aws-6.12pkg:apk/chainguard/linux-aws-6.18pkg:apk/chainguard/linux-azure-6.18pkg:apk/chainguard/linux-gcp-6.12pkg:apk/chainguard/linux-gcp-6.18pkg:apk/chainguard/linux-qemu-6.12pkg:apk/chainguard/linux-qemu-6.18pkg:apk/chainguard/linux-qemu-6.18-bootc-boot-installedpkg:apk/chainguard/linux-vmware-6.12pkg:apk/chainguard/linux-vmware-6.18pkg:rpm/almalinux/kernelpkg:rpm/almalinux/kernel-64kpkg:rpm/almalinux/kernel-64k-corepkg:rpm/almalinux/kernel-64k-debugpkg:rpm/almalinux/kernel-64k-debug-corepkg:rpm/almalinux/kernel-64k-debug-develpkg:rpm/almalinux/kernel-64k-debug-devel-matchedpkg:rpm/almalinux/kernel-64k-debug-modulespkg:rpm/almalinux/kernel-64k-debug-modules-corepkg:rpm/almalinux/kernel-64k-debug-modules-extrapkg:rpm/almalinux/kernel-64k-develpkg:rpm/almalinux/kernel-64k-devel-matchedpkg:rpm/almalinux/kernel-64k-modulespkg:rpm/almalinux/kernel-64k-modules-corepkg:rpm/almalinux/kernel-64k-modules-extrapkg:rpm/almalinux/kernel-abi-stablelistspkg:rpm/almalinux/kernel-corepkg:rpm/almalinux/kernel-cross-headerspkg:rpm/almalinux/kernel-debugpkg:rpm/almalinux/kernel-debug-corepkg:rpm/almalinux/kernel-debug-develpkg:rpm/almalinux/kernel-debug-devel-matchedpkg:rpm/almalinux/kernel-debug-modulespkg:rpm/almalinux/kernel-debug-modules-corepkg:rpm/almalinux/kernel-debug-modules-extrapkg:rpm/almalinux/kernel-debug-uki-virtpkg:rpm/almalinux/kernel-develpkg:rpm/almalinux/kernel-devel-matchedpkg:rpm/almalinux/kernel-docpkg:rpm/almalinux/kernel-headerspkg:rpm/almalinux/kernel-modulespkg:rpm/almalinux/kernel-modules-corepkg:rpm/almalinux/kernel-modules-extrapkg:rpm/almalinux/kernel-modules-extra-matchedpkg:rpm/almalinux/kernel-rtpkg:rpm/almalinux/kernel-rt-64kpkg:rpm/almalinux/kernel-rt-64k-corepkg:rpm/almalinux/kernel-rt-64k-debugpkg:rpm/almalinux/kernel-rt-64k-debug-corepkg:rpm/almalinux/kernel-rt-64k-debug-develpkg:rpm/almalinux/kernel-rt-64k-debug-modulespkg:rpm/almalinux/kernel-rt-64k-debug-modules-corepkg:rpm/almalinux/kernel-rt-64k-debug-modules-extrapkg:rpm/almalinux/kernel-rt-64k-develpkg:rpm/almalinux/kernel-rt-64k-modulespkg:rpm/almalinux/kernel-rt-64k-modules-corepkg:rpm/almalinux/kernel-rt-64k-modules-extrapkg:rpm/almalinux/kernel-rt-corepkg:rpm/almalinux/kernel-rt-debugpkg:rpm/almalinux/kernel-rt-debug-corepkg:rpm/almalinux/kernel-rt-debug-develpkg:rpm/almalinux/kernel-rt-debug-modulespkg:rpm/almalinux/kernel-rt-debug-modules-corepkg:rpm/almalinux/kernel-rt-debug-modules-extrapkg:rpm/almalinux/kernel-rt-develpkg:rpm/almalinux/kernel-rt-modulespkg:rpm/almalinux/kernel-rt-modules-corepkg:rpm/almalinux/kernel-rt-modules-extrapkg:rpm/almalinux/kernel-toolspkg:rpm/almalinux/kernel-tools-libspkg:rpm/almalinux/kernel-tools-libs-develpkg:rpm/almalinux/kernel-uki-virtpkg:rpm/almalinux/kernel-uki-virt-addonspkg:rpm/almalinux/kernel-zfcpdumppkg:rpm/almalinux/kernel-zfcpdump-corepkg:rpm/almalinux/kernel-zfcpdump-develpkg:rpm/almalinux/kernel-zfcpdump-devel-matchedpkg:rpm/almalinux/kernel-zfcpdump-modulespkg:rpm/almalinux/kernel-zfcpdump-modules-corepkg:rpm/almalinux/kernel-zfcpdump-modules-extrapkg:rpm/almalinux/libperfpkg:rpm/almalinux/perfpkg:rpm/almalinux/python3-perfpkg:rpm/almalinux/rtlapkg:rpm/almalinux/rvpkg:rpm/opensuse/kernel-source&distro=openSUSE%20Tumbleweedpkg:rpm/suse/kernel-default&distro=SUSE%20Linux%20Enterprise%20Server%2011%20SP4%20LTSS%20EXTREME%20COREpkg:rpm/suse/kernel-docs&distro=SUSE%20Linux%20Enterprise%20Server%2011%20SP4%20LTSS%20EXTREME%20COREpkg:rpm/suse/kernel-ec2&distro=SUSE%20Linux%20Enterprise%20Server%2011%20SP4%20LTSS%20EXTREME%20COREpkg:rpm/suse/kernel-source&distro=SUSE%20Linux%20Enterprise%20Server%2011%20SP4%20LTSS%20EXTREME%20COREpkg:rpm/suse/kernel-syms&distro=SUSE%20Linux%20Enterprise%20Server%2011%20SP4%20LTSS%20EXTREME%20COREpkg:rpm/suse/kernel-trace&distro=SUSE%20Linux%20Enterprise%20Server%2011%20SP4%20LTSS%20EXTREME%20COREpkg:rpm/suse/kernel-xen&distro=SUSE%20Linux%20Enterprise%20Server%2011%20SP4%20LTSS%20EXTREME%20CORE
< 6.12.85-r0+ 92 more
- (no CPE)range: < 6.12.85-r0
- (no CPE)range: < 6.18.31-r0
- (no CPE)range: < 6.18.31-r0
- (no CPE)range: < 6.12.85-r0
- (no CPE)range: < 6.18.31-r0
- (no CPE)range: < 6.12.85-r0
- (no CPE)range: < 6.18.31-r0
- (no CPE)range: < 6.18.31-r0
- (no CPE)range: < 6.12.85-r0
- (no CPE)range: < 6.18.31-r0
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 6.12.0-211.16.1.el10_2
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 5.14.0-687.10.1.el9_8
- (no CPE)range: < 7.0.3-1.1
- (no CPE)range: < 3.0.101-108.210.1
- (no CPE)range: < 3.0.101-108.210.1
- (no CPE)range: < 3.0.101-108.210.1
- (no CPE)range: < 3.0.101-108.210.1
- (no CPE)range: < 3.0.101-108.210.1
- (no CPE)range: < 3.0.101-108.210.1
- (no CPE)range: < 3.0.101-108.210.1
Patches
Vulnerability mechanics
References
9- git.kernel.org/stable/c/2ab833a16a825373aad2ba7d54b572b277e95b71nvdPatch
- git.kernel.org/stable/c/5e1c4ece08ccdc197177631f111845a2c68eede3nvdPatch
- git.kernel.org/stable/c/885c8591784da6314f9aa82fa460ac69f9f79e5fnvdPatch
- git.kernel.org/stable/c/8d155e2d1c4102f74f82a2bf9c016164bb0f7384nvdPatch
- git.kernel.org/stable/c/906f16a836de13fe61f49cdce2f66f2dbd14caf4nvdPatch
- git.kernel.org/stable/c/ef8ebb1c637b4cfb61a9dd2e013376774ee2033bnvdPatch
- git.kernel.org/stable/c/324262c38438255bf6bdbf6342ca47c0badaab76nvd
- git.kernel.org/stable/c/973f2c250289f5bf6cc146b98aa6fdde11fe50d6nvd
- git.kernel.org/stable/c/ce744264b06b97069b3722511ab355738311fee0nvd
News mentions
0No linked articles in our index yet.