HOMEVULNERABILITIESCVE-2026-53145
HIGH

CVE-2026-53145

Published: June 25, 2026· Updated: Jun 30, 2026

7.8
CVSS v3.1
EPSS:0.17%probability of exploitation in 30 daysPercentile:7.0th

Official Description

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

drm/gem: Try to fix change_handle ioctl, attempt 4

[airlied: just added some comments on how to reenable]

On-list because the cat is out of the bag and we're clearly not good

enough to figure this out in private. The story thus far:

5e28b7b94408 ("drm: Set old handle to NULL before prime swap in

change_handle") tried to fix a race condition between the gem_close and

gem_change_handle ioctls, but got a few things wrong:

- There's a confusion with the local variable handle, which is actually

the new handle, and so the two-stage trick was actually applied to the

wrong idr slot. 7164d78559b0 ("drm/gem: fix race between

change_handle and handle_delete") tried to fix that by adding yet

another code block, but forgot to add the error handling. Which meant

we now have two paths, both kinda wrong.

- dc366607c41c ("drm: Replace old pointer to new idr") tried to apply

another fix, but inconsistently, again because of the handle confusion

- this would be the right fix (kinda, somewhat, it's a mess) if we'd

do the two-stage approach for the new handle. Except that wasn't the

intent of the original fix.

We also didn't have an igt merged for the original ioctl, which is a big

no-go. This was attempted to address off-list in the original bugfix,

and amd QA people claimed the bug was fixed now. Very clearly that's not

the case. Here's my attempt to sort this out:

- Rename the local variable to new_handle, the old aliasing with

args->handle is just too dangerously confusing.

- Merge the gem obj lookup with the two-stage idr_replace so that we

avoid getting ourselves confused there.

- This means we don't have a surplus temporary reference anymore, only

an inherited from the idr. A concurrent gem_close on the new_handle

could steal that. Fix that with the same two-stage approach

create_tail uses. This is a bit overkill as documented in the comment,

but I also don't trust my ability to understand this all correctly, so

go with the established pattern we have from other ioctls instead for

maximum paranoia.

- Adjust error paths. I've tried to make the error and success paths

common, because they are identical except for which handle is removed

and on which we call idr_replace to (re)install the object again. But

that made things messier to read, so I've left it at the more verbose

version, which unfortunately hides the symmetry in the entire code

flow a bit.

- While at it, also replace the 7 space indent with 1 tab.

And finally, because I flat out don't trust my abilities here at all

anymore:

- Disable the ioctl until we have the igt situation and everything else

sorted out on-list and with full consensus.

v2:

Sashiko noticed that I didn't handle the error path for idr_replace

correctly, it must be checked with IS_ERR_OR_NULL like in

gem_handle_delete. So yeah, definitely should just the existing paths

1:1 because this is endless amounts of tricky.

Also add the Fixes: line for the original ioctl, I forgot that too.

NVD Source

Technical Analysis

CVE-2026-53145 requires local access, meaning attackers must already have a foothold on the target system.

Exploitation requires low privileges, which limits the exposure to scenarios where an attacker has already gained initial access.

A successful exploit results in complete confidentiality breach (data exposure), full integrity compromise (data manipulation), availability disruption (denial of service), with a CVSS base score of 7.8.

CVSS v3.1 Vector Breakdown

Exploitability
Attack VectorLocal
Attack ComplexityLow
Privileges Req.Low
User InteractionNone
ScopeUnchanged
Impact
ConfidentialityHigh
IntegrityHigh
AvailabilityHigh
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

Affected Vendors & Products

Mentioned vendors (from description):
LinuxGo
CPE data not yet available in NVD for this CVE.

Exploit & PoC Resources

NO KNOWN EXPLOITNo public exploit confirmed at this time
External links open in a new tab. Always verify in a controlled environment before use.

All References (6)

Quick Facts

CVE IDCVE-2026-53145
CVSS Score7.8 / 10
SeverityHIGH
CISA KEVNo
EPSS (30d)0.17%
PublishedJun 25, 2026

Recommended Actions

  • Apply vendor patches immediately
  • Monitor CVE-2026-53145 in threat intel feeds
  • Review IDS/IPS signatures for exploitation attempts
Data sourced from NVD (NIST), CISA KEV, and EPSS (FIRST). Analysis generated by CTIWATCH.COM. CVE data is provided under the NVD usage policy.