CVE-2024-53135

Source
https://cve.org/CVERecord?id=CVE-2024-53135
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-53135.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2024-53135
Downstream
Related
Published
2024-12-04T14:20:40.815Z
Modified
2026-03-20T12:40:46.130083Z
Summary
KVM: VMX: Bury Intel PT virtualization (guest/host mode) behind CONFIG_BROKEN
Details

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

KVM: VMX: Bury Intel PT virtualization (guest/host mode) behind CONFIG_BROKEN

Hide KVM's ptmode module param behind CONFIGBROKEN, i.e. disable support for virtualizing Intel PT via guest/host mode unless BROKEN=y. There are myriad bugs in the implementation, some of which are fatal to the guest, and others which put the stability and health of the host at risk.

For guest fatalities, the most glaring issue is that KVM fails to ensure tracing is disabled, and stays disabled prior to VM-Enter, which is necessary as hardware disallows loading (the guest's) RTIT_CTL if tracing is enabled (enforced via a VMX consistency check). Per the SDM:

If the logical processor is operating with Intel PT enabled (if IA32RTITCTL.TraceEn = 1) at the time of VM entry, the "load IA32RTITCTL" VM-entry control must be 0.

On the host side, KVM doesn't validate the guest CPUID configuration provided by userspace, and even worse, uses the guest configuration to decide what MSRs to save/load at VM-Enter and VM-Exit. E.g. configuring guest CPUID to enumerate more address ranges than are supported in hardware will result in KVM trying to passthrough, save, and load non-existent MSRs, which generates a variety of WARNs, ToPA ERRORs in the host, a potential deadlock, etc.

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2024/53xxx/CVE-2024-53135.json",
    "cna_assigner": "Linux"
}
References

Affected packages

Git / git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git

Affected ranges

Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
f99e3daf94ff35dd4a878d32ff66e1fd35223ad6
Fixed
c3742319d021f5aa3a0a8c828485fee14753f6de
Fixed
d4b42f926adcce4e5ec193c714afd9d37bba8e5b
Fixed
b8a1d572478b6f239061ee9578b2451bf2f021c2
Fixed
e6716f4230a8784957273ddd27326264b27b9313
Fixed
d28b059ee4779b5102c5da6e929762520510e406
Fixed
b91bb0ce5cd7005b376eac690ec664c1b56372ec
Fixed
aa0d42cacf093a6fcca872edc954f6f812926a17

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-53135.json"