CVE-2026-23401

EUVD-2026-17828
In the Linux kernel, the following vulnerability has been resolved:

KVM: x86/mmu: Drop/zap existing present SPTE even when creating an MMIO SPTE

When installing an emulated MMIO SPTE, do so *after* dropping/zapping the
existing SPTE (if it's shadow-present).  While commit a54aa15c6bda3 was
right about it being impossible to convert a shadow-present SPTE to an
MMIO SPTE due to a _guest_ write, it failed to account for writes to guest
memory that are outside the scope of KVM.

E.g. if host userspace modifies a shadowed gPTE to switch from a memslot
to emulted MMIO and then the guest hits a relevant page fault, KVM will
install the MMIO SPTE without first zapping the shadow-present SPTE.

  ------------[ cut here ]------------
  is_shadow_present_pte(*sptep)
  WARNING: arch/x86/kvm/mmu/mmu.c:484 at mark_mmio_spte+0xb2/0xc0 [kvm], CPU#0: vmx_ept_stale_r/4292
  Modules linked in: kvm_intel kvm irqbypass
  CPU: 0 UID: 1000 PID: 4292 Comm: vmx_ept_stale_r Not tainted 7.0.0-rc2-eafebd2d2ab0-sink-vm #319 PREEMPT
  Hardware name: QEMU Standard PC (Q35 + ICH9, 2009), BIOS 0.0.0 02/06/2015
  RIP: 0010:mark_mmio_spte+0xb2/0xc0 [kvm]
  Call Trace:
   <TASK>
   mmu_set_spte+0x237/0x440 [kvm]
   ept_page_fault+0x535/0x7f0 [kvm]
   kvm_mmu_do_page_fault+0xee/0x1f0 [kvm]
   kvm_mmu_page_fault+0x8d/0x620 [kvm]
   vmx_handle_exit+0x18c/0x5a0 [kvm_intel]
   kvm_arch_vcpu_ioctl_run+0xc55/0x1c20 [kvm]
   kvm_vcpu_ioctl+0x2d5/0x980 [kvm]
   __x64_sys_ioctl+0x8a/0xd0
   do_syscall_64+0xb5/0x730
   entry_SYSCALL_64_after_hwframe+0x4b/0x53
  RIP: 0033:0x47fa3f
   </TASK>
  ---[ end trace 0000000000000000 ]---
ProviderTypeBase ScoreAtk. VectorAtk. ComplexityPriv. RequiredVector
NISTPrimary
5.5 MEDIUM
LOCAL
LOW
LOW
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H
Base Score
CVSS 3.x
EPSS Score
Percentile: 5%
Affected Products (NVD)
VendorProductVersion
linuxlinux_kernel
5.13.1 ≤
𝑥
< 5.15.203
linuxlinux_kernel
5.16 ≤
𝑥
< 6.1.168
linuxlinux_kernel
6.2 ≤
𝑥
< 6.6.131
linuxlinux_kernel
6.7 ≤
𝑥
< 6.12.80
linuxlinux_kernel
6.13 ≤
𝑥
< 6.18.21
linuxlinux_kernel
6.19 ≤
𝑥
< 6.19.11
linuxlinux_kernel
5.13
linuxlinux_kernel
7.0:rc1
linuxlinux_kernel
7.0:rc2
linuxlinux_kernel
7.0:rc3
linuxlinux_kernel
7.0:rc4
linuxlinux_kernel
7.0:rc5
linuxlinux_kernel
7.0:rc6
linuxlinux_kernel
7.0:rc7
𝑥
= Vulnerable software versions
Debian logo
Debian Releases
Debian Product
Codename
linux
bookworm
vulnerable
bookworm (security)
6.1.170-3
fixed
bullseye
5.10.223-1
fixed
bullseye (security)
5.10.251-4
fixed
forky
7.0.4-1
fixed
sid
7.0.4-1
fixed
trixie
vulnerable
trixie (security)
6.12.86-1
fixed
linux-6.1
bullseye (security)
6.1.170-3~deb11u1
fixed
Red Hat logo
Red Hat Enterprise Linux Releases
Red Hat Product
Release
bpftool
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-abi-stablelists
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-core
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-debug
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-debug-core
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-debug-devel
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-debug-modules
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-debug-modules-extra
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-devel
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-doc
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-modules
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-modules-extra
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-rt
RHEL 8
0:4.18.0-553.123.1.rt7.464.el8_10
fixed
kernel-rt-core
RHEL 8
0:4.18.0-553.123.1.rt7.464.el8_10
fixed
kernel-rt-debug
RHEL 8
0:4.18.0-553.123.1.rt7.464.el8_10
fixed
kernel-rt-debug-core
RHEL 8
0:4.18.0-553.123.1.rt7.464.el8_10
fixed
kernel-rt-debug-devel
RHEL 8
0:4.18.0-553.123.1.rt7.464.el8_10
fixed
kernel-rt-debug-kvm
RHEL 8
0:4.18.0-553.123.1.rt7.464.el8_10
fixed
kernel-rt-debug-modules
RHEL 8
0:4.18.0-553.123.1.rt7.464.el8_10
fixed
kernel-rt-debug-modules-extra
RHEL 8
0:4.18.0-553.123.1.rt7.464.el8_10
fixed
kernel-rt-devel
RHEL 8
0:4.18.0-553.123.1.rt7.464.el8_10
fixed
kernel-rt-kvm
RHEL 8
0:4.18.0-553.123.1.rt7.464.el8_10
fixed
kernel-rt-modules
RHEL 8
0:4.18.0-553.123.1.rt7.464.el8_10
fixed
kernel-rt-modules-extra
RHEL 8
0:4.18.0-553.123.1.rt7.464.el8_10
fixed
kernel-tools
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-tools-libs
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
kernel-tools-libs-devel
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
kernel-zfcpdump
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
kernel-zfcpdump-core
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
kernel-zfcpdump-devel
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
kernel-zfcpdump-modules
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
kernel-zfcpdump-modules-extra
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
perf
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed
python3-perf
RHEL 8
0:4.18.0-553.123.1.el8_10
fixed
RHEL 8.6 AUS
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 E4S
0:4.18.0-372.191.1.el8_6
fixed
RHEL 8.6 TUS
0:4.18.0-372.191.1.el8_6
fixed