CVE-2026-46314 PUBLISHED

drm/v3d: Reject empty multisync extension to prevent infinite loop

Assigner: Linux
Reserved: 13.05.2026 Published: 08.06.2026 Updated: 19.06.2026

In the Linux kernel, the following vulnerability has been resolved:

drm/v3d: Reject empty multisync extension to prevent infinite loop

v3d_get_extensions() walks a userspace-provided singly-linked list of ioctl extensions without any bound on the chain length. A local user can craft a self-referential extension (ext->next == &ext) with zero in_sync_count and out_sync_count, which bypasses the existing duplicate- extension guard:

<pre>if (se->in_sync_count || se->out_sync_count) return -EINVAL; </pre>

The guard never fires because v3d_get_multisync_post_deps() returns immediately when count is zero, leaving both fields at zero on every iteration. The result is an infinite loop in kernel context, blocking the calling thread and pegging a CPU core indefinitely.

Fix this by rejecting a multisync extension where both in_sync_count and out_sync_count are zero in v3d_get_multisync_submit_deps(). An empty multisync carries no synchronization information and serves no useful purpose, so returning -EINVAL for such an extension is the correct defense against this attack vector.

Product Status

Vendor Linux
Product Linux
Versions Default: unaffected
  • affected from e4165ae8304e5ea822fbe5909dd3be5445c058b7 to 309abbddeca0c12714721928a819ef45e5710998 (excl.)
  • affected from e4165ae8304e5ea822fbe5909dd3be5445c058b7 to 4fa42a249e8cd6ed17aea04e5695b6e9001f2433 (excl.)
  • affected from e4165ae8304e5ea822fbe5909dd3be5445c058b7 to 9c5164781cb388d219d8f49fa0f0b04cf86ad544 (excl.)
  • affected from e4165ae8304e5ea822fbe5909dd3be5445c058b7 to fb44d589bf3148e13452185a6e772a7efbf2d684 (excl.)
Vendor Linux
Product Linux
Versions Default: affected
  • Version 5.16 is affected
  • unaffected from 0 to 5.16 (excl.)
  • unaffected from 6.1.176 to 6.1.* (incl.)
  • unaffected from 6.18.33 to 6.18.* (incl.)
  • unaffected from 7.0.9 to 7.0.* (incl.)
  • unaffected from 7.1 to * (incl.)

References