CVE-2026-46280

Source
https://cve.org/CVERecord?id=CVE-2026-46280
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2026-46280.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2026-46280
Downstream
Related
Published
2026-06-08T15:41:23.095Z
Modified
2026-06-23T03:55:29.845097002Z
Severity
  • 7.8 (High) CVSS_V3 - CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H CVSS Calculator
Summary
lib: test_hmm: evict device pages on file close to avoid use-after-free
Details

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

lib: test_hmm: evict device pages on file close to avoid use-after-free

Patch series "Minor hmm_test fixes and cleanups".

Two bugfixes a cleanup for the HMM kernel selftests. These were mostly reported by Zenghui Yu with special thanks to Lorenzo for analysing and pointing out the problems.

This patch (of 3):

When dmirrorfopsrelease() is called it frees the dmirror struct but doesn't migrate device private pages back to system memory first. This leaves those pages with a dangling zonedevicedata pointer to the freed dmirror.

If a subsequent fault occurs on those pages (eg. during coredump) the dmirrordevmemfault() callback dereferences the stale pointer causing a kernel panic. This was reported [1] when running mm/ksft_hmm.sh on arm64, where a test failure triggered SIGABRT and the resulting coredump walked the VMAs faulting in the stale device private pages.

Fix this by calling dmirrordeviceevictchunk() for each devmem chunk in dmirrorfops_release() to migrate all device private pages back to system memory before freeing the dmirror struct. The function is moved earlier in the file to avoid a forward declaration.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2026/46xxx/CVE-2026-46280.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
b2ef9f5a5cb37643ca5def3516c546457074b882
Fixed
234071b4318feaeb27cd2e4e1b16ef6b055adf89
Fixed
bf477abd448c76bb8ea51c9b4f63a3a17c4b6239
Fixed
5846715b6382dd4c6a69b35a56ca6115d33bc2a0
Fixed
38f113f81d3f0adc658a4475dd3ecaec985e21d3
Fixed
9de1eb0aac2862d6144b8db0ec1388e79f8bc3e1
Fixed
744dd97752ef1076a8d8672bb0d8aa2c7abc1144

Database specific

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

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
5.8.0
Fixed
6.1.176
Type
ECOSYSTEM
Events
Introduced
6.2.0
Fixed
6.6.140
Type
ECOSYSTEM
Events
Introduced
6.7.0
Fixed
6.12.86
Type
ECOSYSTEM
Events
Introduced
6.13.0
Fixed
6.18.27
Type
ECOSYSTEM
Events
Introduced
6.19.0
Fixed
7.0.4

Database specific

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