CVE-2026-31787
Description
In the Linux kernel, the following vulnerability has been resolved:
xen/privcmd: fix double free via VMA splitting
privcmd_vm_ops defines .close (privcmd_close), but neither .may_split nor .open. When userspace does a partial munmap() on a privcmd mapping, the kernel splits the VMA via __split_vma(). Since may_split is NULL, the split is allowed. vm_area_dup() copies vm_private_data (a pages array allocated in alloc_empty_pages()) into the new VMA without any fixup, because there is no .open callback.
Both VMAs now point to the same pages array. When the unmapped portion is closed, privcmd_close() calls: - xen_unmap_domain_gfn_range() - xen_free_unpopulated_pages() - kvfree(pages)
The surviving VMA still holds the dangling pointer. When it is later destroyed, the same sequence runs again, which leads to a double free.
Fix this issue by adding a .may_split callback denying the VMA split.
This is XSA-487 / CVE-2026-31787
AI Insight
LLM-synthesized narrative grounded in this CVE's description and references.
Affected products
91- osv-coords88 versionspkg:apk/chainguard/linux-aws-6.12pkg:apk/chainguard/linux-aws-6.18pkg:apk/chainguard/linux-azure-6.12pkg:apk/chainguard/linux-azure-6.18pkg:apk/chainguard/linux-gcp-6.12pkg:apk/chainguard/linux-gcp-6.18pkg:apk/chainguard/linux-qemu-6.12pkg:apk/chainguard/linux-qemu-6.18pkg:apk/chainguard/linux-qemu-rcpkg:apk/chainguard/linux-vmware-6.12pkg:apk/chainguard/linux-vmware-6.18pkg:rpm/almalinux/bpftoolpkg:rpm/almalinux/kernelpkg:rpm/almalinux/kernel-64kpkg:rpm/almalinux/kernel-64k-corepkg:rpm/almalinux/kernel-64k-debugpkg:rpm/almalinux/kernel-64k-debug-corepkg:rpm/almalinux/kernel-64k-debug-develpkg:rpm/almalinux/kernel-64k-debug-devel-matchedpkg:rpm/almalinux/kernel-64k-debug-modulespkg:rpm/almalinux/kernel-64k-debug-modules-corepkg:rpm/almalinux/kernel-64k-debug-modules-extrapkg:rpm/almalinux/kernel-64k-develpkg:rpm/almalinux/kernel-64k-devel-matchedpkg:rpm/almalinux/kernel-64k-modulespkg:rpm/almalinux/kernel-64k-modules-corepkg:rpm/almalinux/kernel-64k-modules-extrapkg:rpm/almalinux/kernel-abi-stablelistspkg:rpm/almalinux/kernel-corepkg:rpm/almalinux/kernel-cross-headerspkg:rpm/almalinux/kernel-debugpkg:rpm/almalinux/kernel-debug-corepkg:rpm/almalinux/kernel-debug-develpkg:rpm/almalinux/kernel-debug-devel-matchedpkg:rpm/almalinux/kernel-debug-modulespkg:rpm/almalinux/kernel-debug-modules-corepkg:rpm/almalinux/kernel-debug-modules-extrapkg:rpm/almalinux/kernel-debug-uki-virtpkg:rpm/almalinux/kernel-develpkg:rpm/almalinux/kernel-devel-matchedpkg:rpm/almalinux/kernel-docpkg:rpm/almalinux/kernel-headerspkg:rpm/almalinux/kernel-modulespkg:rpm/almalinux/kernel-modules-corepkg:rpm/almalinux/kernel-modules-extrapkg:rpm/almalinux/kernel-modules-extra-matchedpkg:rpm/almalinux/kernel-rtpkg:rpm/almalinux/kernel-rt-64kpkg:rpm/almalinux/kernel-rt-64k-corepkg:rpm/almalinux/kernel-rt-64k-debugpkg:rpm/almalinux/kernel-rt-64k-debug-corepkg:rpm/almalinux/kernel-rt-64k-debug-develpkg:rpm/almalinux/kernel-rt-64k-debug-modulespkg:rpm/almalinux/kernel-rt-64k-debug-modules-corepkg:rpm/almalinux/kernel-rt-64k-debug-modules-extrapkg:rpm/almalinux/kernel-rt-64k-develpkg:rpm/almalinux/kernel-rt-64k-modulespkg:rpm/almalinux/kernel-rt-64k-modules-corepkg:rpm/almalinux/kernel-rt-64k-modules-extrapkg:rpm/almalinux/kernel-rt-corepkg:rpm/almalinux/kernel-rt-debugpkg:rpm/almalinux/kernel-rt-debug-corepkg:rpm/almalinux/kernel-rt-debug-develpkg:rpm/almalinux/kernel-rt-debug-modulespkg:rpm/almalinux/kernel-rt-debug-modules-corepkg:rpm/almalinux/kernel-rt-debug-modules-extrapkg:rpm/almalinux/kernel-rt-develpkg:rpm/almalinux/kernel-rt-modulespkg:rpm/almalinux/kernel-rt-modules-corepkg:rpm/almalinux/kernel-rt-modules-extrapkg:rpm/almalinux/kernel-toolspkg:rpm/almalinux/kernel-tools-libspkg:rpm/almalinux/kernel-tools-libs-develpkg:rpm/almalinux/kernel-uki-virtpkg:rpm/almalinux/kernel-uki-virt-addonspkg:rpm/almalinux/kernel-zfcpdumppkg:rpm/almalinux/kernel-zfcpdump-corepkg:rpm/almalinux/kernel-zfcpdump-develpkg:rpm/almalinux/kernel-zfcpdump-devel-matchedpkg:rpm/almalinux/kernel-zfcpdump-modulespkg:rpm/almalinux/kernel-zfcpdump-modules-corepkg:rpm/almalinux/kernel-zfcpdump-modules-extrapkg:rpm/almalinux/libperfpkg:rpm/almalinux/perfpkg:rpm/almalinux/python3-perfpkg:rpm/almalinux/rtlapkg:rpm/almalinux/rvpkg:rpm/opensuse/kernel-source&distro=openSUSE%20Tumbleweed
< 6.12.85-r2+ 87 more
- (no CPE)range: < 6.12.85-r2
- (no CPE)range: < 6.18.31-r0
- (no CPE)range: < 6.12.85-r2
- (no CPE)range: < 6.18.31-r0
- (no CPE)range: < 6.12.89-r0
- (no CPE)range: < 6.18.31-r0
- (no CPE)range: < 6.12.89-r0
- (no CPE)range: < 6.18.24-r3
- (no CPE)range: < 7.1_rc3-r0
- (no CPE)range: < 6.12.85-r2
- (no CPE)range: < 6.18.31-r0
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.rt7.475.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.rt7.475.el8_10
- (no CPE)range: < 4.18.0-553.134.1.rt7.475.el8_10
- (no CPE)range: < 4.18.0-553.134.1.rt7.475.el8_10
- (no CPE)range: < 4.18.0-553.134.1.rt7.475.el8_10
- (no CPE)range: < 4.18.0-553.134.1.rt7.475.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.rt7.475.el8_10
- (no CPE)range: < 4.18.0-553.134.1.rt7.475.el8_10
- (no CPE)range: < 4.18.0-553.134.1.rt7.475.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.rt7.475.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 4.18.0-553.134.1.el8_10
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 6.12.0-211.26.1.el10_2
- (no CPE)range: < 7.0.3-1.1
Patches
Vulnerability mechanics
References
10- git.kernel.org/stable/c/1576ff3869cbd3620717195f971c85b7d7fd62b5nvdPatch
- git.kernel.org/stable/c/24daca4fc07f3ff8cd0e3f629cd982187f48436anvdPatch
- git.kernel.org/stable/c/2894a351fe2ea8684919d36df3188b9a35e3926fnvdPatch
- git.kernel.org/stable/c/2b985d3a024b9e8c24e21671b34e855569763808nvdPatch
- git.kernel.org/stable/c/402d84ad9e89bd4cbfd07ca8598532b7021daf95nvdPatch
- git.kernel.org/stable/c/446ee446d9ae66f36e95c3c90bbcc4e56b94cde0nvdPatch
- git.kernel.org/stable/c/71bf829800758a6e3889096e4754ef47ba7fc850nvdPatch
- git.kernel.org/stable/c/dbf862ce9f009128ab86b234d91413a3e450beb4nvdPatch
- www.openwall.com/lists/oss-security/2026/04/28/14nvdMailing ListThird Party Advisory
- xenbits.xen.org/xsa/advisory-487.htmlnvdThird Party Advisory
News mentions
0No linked articles in our index yet.