๐Ÿ” CVE Alert

CVE-2026-31576

UNKNOWN 0.0

media: hackrf: fix to not free memory after the device is registered in hackrf_probe()

CVSS Score
0.0
EPSS Score
0.0%
EPSS Percentile
0th

In the Linux kernel, the following vulnerability has been resolved: media: hackrf: fix to not free memory after the device is registered in hackrf_probe() In hackrf driver, the following race condition occurs: ``` CPU0 CPU1 hackrf_probe() kzalloc(); // alloc hackrf_dev .... v4l2_device_register(); .... fd = sys_open("/path/to/dev"); // open hackrf fd .... v4l2_device_unregister(); .... kfree(); // free hackrf_dev .... sys_ioctl(fd, ...); v4l2_ioctl(); video_is_registered() // UAF!! .... sys_close(fd); v4l2_release() // UAF!! hackrf_video_release() kfree(); // DFB!! ``` When a V4L2 or video device is unregistered, the device node is removed so new open() calls are blocked. However, file descriptors that are already open-and any in-flight I/O-do not terminate immediately; they remain valid until the last reference is dropped and the driver's release() is invoked. Therefore, freeing device memory on the error path after hackrf_probe() has registered dev it will lead to a race to use-after-free vuln, since those already-open handles haven't been released yet. And since release() free memory too, race to use-after-free and double-free vuln occur. To prevent this, if device is registered from probe(), it should be modified to free memory only through release() rather than calling kfree() directly.

Vendor linux
Product linux
Ecosystems
Industries
Technology
Published Apr 24, 2026
Last Updated Jun 1, 2026
Stay Ahead of the Next One

Get instant alerts for linux linux

Be the first to know when new unknown vulnerabilities affecting linux linux are published โ€” delivered to Slack, Telegram or Discord.

Get Free Alerts โ†’ Free ยท No credit card ยท 60 sec setup

Affected Versions

Linux / Linux
8bc4a9ed85046c214458c9e82aea75d2f46cfffd < 87b9685cca91ed715c39ba544715832d26a7f4b4 8bc4a9ed85046c214458c9e82aea75d2f46cfffd < 131ec9046e1c8af101aebdaec4e8095e05f3312b 8bc4a9ed85046c214458c9e82aea75d2f46cfffd < 67fd62e3efdc9dce01f76d95a745212f4feb38e6 8bc4a9ed85046c214458c9e82aea75d2f46cfffd < 45cbaf5c7cdc5386d86377f0daf94a17a007fed0 8bc4a9ed85046c214458c9e82aea75d2f46cfffd < 98a0a81ce78020c2522e0046f49d200de9778cb9 8bc4a9ed85046c214458c9e82aea75d2f46cfffd < 07e9e674b6146b1f6fc41b1f54b8968bf2802824 8bc4a9ed85046c214458c9e82aea75d2f46cfffd < 2145c71a8044362e82e9923f001ba2aeb771b848 8bc4a9ed85046c214458c9e82aea75d2f46cfffd < fcd1d70792a35c8a97414fe429f48311e41269c2 8bc4a9ed85046c214458c9e82aea75d2f46cfffd < 3b7da2b4d0fe014eff181ed37e3bf832eb8ed258
Linux / Linux
4.4

References

NVD โ†— CVE.org โ†— EPSS Data โ†—
git.kernel.org: https://git.kernel.org/stable/c/87b9685cca91ed715c39ba544715832d26a7f4b4 git.kernel.org: https://git.kernel.org/stable/c/131ec9046e1c8af101aebdaec4e8095e05f3312b git.kernel.org: https://git.kernel.org/stable/c/67fd62e3efdc9dce01f76d95a745212f4feb38e6 git.kernel.org: https://git.kernel.org/stable/c/45cbaf5c7cdc5386d86377f0daf94a17a007fed0 git.kernel.org: https://git.kernel.org/stable/c/98a0a81ce78020c2522e0046f49d200de9778cb9 git.kernel.org: https://git.kernel.org/stable/c/07e9e674b6146b1f6fc41b1f54b8968bf2802824 git.kernel.org: https://git.kernel.org/stable/c/2145c71a8044362e82e9923f001ba2aeb771b848 git.kernel.org: https://git.kernel.org/stable/c/fcd1d70792a35c8a97414fe429f48311e41269c2 git.kernel.org: https://git.kernel.org/stable/c/3b7da2b4d0fe014eff181ed37e3bf832eb8ed258