CVE-2025-38102

Source
https://cve.org/CVERecord?id=CVE-2025-38102
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2025-38102.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2025-38102
Downstream
Related
Published
2025-07-03T08:35:12.255Z
Modified
2026-03-12T02:17:35.908098Z
Summary
VMCI: fix race between vmci_host_setup_notify and vmci_ctx_unset_notify
Details

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

VMCI: fix race between vmcihostsetupnotify and vmcictxunsetnotify

During our test, it is found that a warning can be trigger in trygrabfolio as follow:

------------[ cut here ]------------ WARNING: CPU: 0 PID: 1678 at mm/gup.c:147 trygrabfolio+0x106/0x130 Modules linked in: CPU: 0 UID: 0 PID: 1678 Comm: syz.3.31 Not tainted 6.15.0-rc5 #163 PREEMPT(undef) RIP: 0010:trygrabfolio+0x106/0x130 Call Trace: <TASK> followhugepmd+0x240/0x8e0 followpmdmask.constprop.0.isra.0+0x40b/0x5c0 followpudmask.constprop.0.isra.0+0x14a/0x170 followpagemask+0x1c2/0x1f0 __getuserpages+0x176/0x950 _guplongtermlocked+0x15b/0x1060 ? gupfast+0x120/0x1f0 gupfastfallback+0x17e/0x230 getuserpagesfast+0x5f/0x80 vmcihostunlockedioctl+0x21c/0xf80 RIP: 0033:0x54d2cd ---[ end trace 0000000000000000 ]---

Digging into the source, context->notifypage may init by getuserpagesfast and can be seen in vmcictxunsetnotify which will try to putpage. However getuserpagesfast is not finished here and lead to following trygrab_folio warning. The race condition is shown as follow:

cpu0 cpu1 vmcihostdosetnotify vmcihostsetupnotify getuserpagesfast(uva, 1, FOLLWRITE, &context->notifypage); locklesspagesfrommm guppgdrange guphugepmd // update &context->notifypage vmcihostdosetnotify vmcictxunsetnotify notifypage = context->notifypage; if (notifypage) putpage(notifypage); // page is freed __guplongtermlocked _getuserpages followtranshugepmd trygrabfolio // warn here

To slove this, use local variable page to make notifypage can be seen after finish getuserpagesfast.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2025/38xxx/CVE-2025-38102.json"
}
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
a1d88436d53a75e950db15834b3d2f8c0c358fdc
Fixed
74095bbbb19ca74a0368d857603a2438c88ca86c
Fixed
468aec888f838ce5174b96e0cb4396790d6f60ca
Fixed
b4209e4b778e4e57d0636e1c9fc07a924dbc6043
Fixed
58a90db70aa6616411e5f69d1982d9b1dd97d774
Fixed
6e3af836805ed1d7a699f76ec798626198917aa4
Fixed
00ddc7dad55b7bbb78df80d6e174d0c4764dea0c
Fixed
75b5313c80c39a26d27cbb602f968a05576c36f9
Fixed
1bd6406fb5f36c2bb1e96e27d4c3e9f4d09edde4

Database specific

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