CVE-2026-31788

Source
https://cve.org/CVERecord?id=CVE-2026-31788
Import Source
https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2026-31788.json
JSON Data
https://api.osv.dev/v1/vulns/CVE-2026-31788
Downstream
Published
2026-03-25T10:25:05.542Z
Modified
2026-04-02T13:23:30.304547Z
Summary
xen/privcmd: restrict usage in unprivileged domU
Details

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

xen/privcmd: restrict usage in unprivileged domU

The Xen privcmd driver allows to issue arbitrary hypercalls from user space processes. This is normally no problem, as access is usually limited to root and the hypervisor will deny any hypercalls affecting other domains.

In case the guest is booted using secure boot, however, the privcmd driver would be enabling a root user process to modify e.g. kernel memory contents, thus breaking the secure boot feature.

The only known case where an unprivileged domU is really needing to use the privcmd driver is the case when it is acting as the device model for another guest. In this case all hypercalls issued via the privcmd driver will target that other guest.

Fortunately the privcmd driver can already be locked down to allow only hypercalls targeting a specific domain, but this mode can be activated from user land only today.

The target domain can be obtained from Xenstore, so when not running in dom0 restrict the privcmd driver to that target domain from the beginning, resolving the potential problem of breaking secure boot.

This is XSA-482


V2: - defer reading from Xenstore if Xenstore isn't ready yet (Jan Beulich) - wait in open() if target domain isn't known yet - issue message in case no target domain found (Jan Beulich)

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2026/31xxx/CVE-2026-31788.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
1c5de1939c204bde9cce87f4eb3d26e9f9eb732b
Fixed
87a803edb2ded911cb587c53bff179d2a2ed2a28
Fixed
1879319d790f7d57622cdc22807b60ea78b56b6d
Fixed
78432d8f0372c71c518096395537fa12be7ff24e
Fixed
389bae9a4409934e8b8d4dbdaaf02a3ae71cf8e4
Fixed
cbede2e833da1893afbea9b3ff29b5dda23a4a91
Fixed
453b8fb68f3641fea970db88b7d9a153ed2a37e8

Database specific

source
"https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2026-31788.json"

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
2.6.37
Fixed
6.1.167
Type
ECOSYSTEM
Events
Introduced
6.2.0
Fixed
6.6.130
Type
ECOSYSTEM
Events
Introduced
6.7.0
Fixed
6.12.78
Type
ECOSYSTEM
Events
Introduced
6.13.0
Fixed
6.18.20
Type
ECOSYSTEM
Events
Introduced
6.19.0
Fixed
6.19.10

Database specific

source
"https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2026-31788.json"