Home

Description

In the Linux kernel, the following vulnerability has been resolved: usb: dwc2: gadget: Fix spin_lock/unlock mismatch in dwc2_hsotg_udc_stop() dwc2_gadget_exit_clock_gating() internally calls call_gadget() macro, which expects hsotg->lock to be held since it does spin_unlock/spin_lock around the gadget driver callback invocation. However, dwc2_hsotg_udc_stop() calls dwc2_gadget_exit_clock_gating() without holding the lock. This leads to: - spin_unlock on a lock that is not held (undefined behavior) - The lock remaining held after dwc2_gadget_exit_clock_gating() returns, causing a deadlock when spin_lock_irqsave() is called later in the same function. Fix this by acquiring hsotg->lock before calling dwc2_gadget_exit_clock_gating() and releasing it afterwards, which satisfies the locking requirement of the call_gadget() macro.

PUBLISHED Reserved 2026-03-09 | Published 2026-05-01 | Updated 2026-05-01 | Assigner Linux

Product status

Default status
unaffected

5cb3cb3db317c58d50b68f3ca3bb8343ea9d1acd (git) before e9fcca3e87463013d595c65c2189ffaa32ad3b50
affected

1ac826cebc2776f91569f2aa9c9c3da2375d2096 (git) before 8ffe31acb3b77a30ae34d01719a269881569fb7f
affected

41732f9febdccb4f9b87c13cb915d717d68ccafd (git) before beab10429439e20708036a66fb0d97ffb79da6a1
affected

ba78c2b3254c4a458c01776612e8a573e12f8d26 (git) before 4ed9d2dd9f29828c311db6ec4b8e0d34bfd6d6a4
affected

af076a41f8a28faf9ceb9dd2d88aef2c202ef39a (git) before 61937f686290494998236c680ce0836b8dd63a3f
affected

af076a41f8a28faf9ceb9dd2d88aef2c202ef39a (git) before 51b62286fc668c6eb74dee7624ec0beec3c5a0ed
affected

af076a41f8a28faf9ceb9dd2d88aef2c202ef39a (git) before 9bb4b5ed7f8c4f95cc556bdf042b0ba2fa13557a
affected

b39c203690fa1678daecc60f347e43c8b593b969 (git)
affected

Default status
affected

6.16
affected

Any version before 6.16
unaffected

5.15.203 (semver)
unaffected

6.1.168 (semver)
unaffected

6.6.134 (semver)
unaffected

6.12.81 (semver)
unaffected

6.18.22 (semver)
unaffected

6.19.12 (semver)
unaffected

7.0 (original_commit_for_fix)
unaffected

References

git.kernel.org/...c/e9fcca3e87463013d595c65c2189ffaa32ad3b50

git.kernel.org/...c/8ffe31acb3b77a30ae34d01719a269881569fb7f

git.kernel.org/...c/beab10429439e20708036a66fb0d97ffb79da6a1

git.kernel.org/...c/4ed9d2dd9f29828c311db6ec4b8e0d34bfd6d6a4

git.kernel.org/...c/61937f686290494998236c680ce0836b8dd63a3f

git.kernel.org/...c/51b62286fc668c6eb74dee7624ec0beec3c5a0ed

git.kernel.org/...c/9bb4b5ed7f8c4f95cc556bdf042b0ba2fa13557a

cve.org (CVE-2026-31756)

nvd.nist.gov (CVE-2026-31756)

Download JSON