CVE-2025-38214

Source
https://cve.org/CVERecord?id=CVE-2025-38214
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2025-38214.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2025-38214
Downstream
Related
Published
2025-07-04T13:37:32.410Z
Modified
2026-03-20T12:42:44.551800Z
Summary
fbdev: Fix fb_set_var to prevent null-ptr-deref in fb_videomode_to_var
Details

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

fbdev: Fix fbsetvar to prevent null-ptr-deref in fbvideomodeto_var

If fbaddvideomode() in fbsetvar() fails to allocate memory for fbvideomode, later it may lead to a null-ptr dereference in fbvideomodetovar(), as the fbinfo is registered while not having the mode in modelist that is expected to be there, i.e. the one that is described in fbinfo->var.

================================================================ general protection fault, probably for non-canonical address 0xdffffc0000000001: 0000 [#1] PREEMPT SMP KASAN NOPTI KASAN: null-ptr-deref in range [0x0000000000000008-0x000000000000000f] CPU: 1 PID: 30371 Comm: syz-executor.1 Not tainted 5.10.226-syzkaller #0 Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.12.0-1 04/01/2014 RIP: 0010:fbvideomodetovar+0x24/0x610 drivers/video/fbdev/core/modedb.c:901 Call Trace: displaytovar+0x3a/0x7c0 drivers/video/fbdev/core/fbcon.c:929 fbconresize+0x3e2/0x8f0 drivers/video/fbdev/core/fbcon.c:2071 resizescreen drivers/tty/vt/vt.c:1176 [inline] vcdoresize+0x53a/0x1170 drivers/tty/vt/vt.c:1263 fbconmodechanged+0x3ac/0x6e0 drivers/video/fbdev/core/fbcon.c:2720 fbconupdatevcs+0x43/0x60 drivers/video/fbdev/core/fbcon.c:2776 dofbioctl+0x6d2/0x740 drivers/video/fbdev/core/fbmem.c:1128 fbioctl+0xe7/0x150 drivers/video/fbdev/core/fbmem.c:1203 vfsioctl fs/ioctl.c:48 [inline] __dosysioctl fs/ioctl.c:753 [inline] __sesysioctl fs/ioctl.c:739 [inline] __x64sysioctl+0x19a/0x210 fs/ioctl.c:739 dosyscall64+0x33/0x40 arch/x86/entry/common.c:46

entrySYSCALL64afterhwframe+0x67/0xd1

The reason is that fbinfo->var is being modified in fbsetvar(), and then fbvideomodetovar() is called. If it fails to add the mode to fbinfo->modelist, fbsetvar() returns error, but does not restore the old value of fbinfo->var. Restore fb_info->var on failure the same way it is done earlier in the function.

Found by Linux Verification Center (linuxtesting.org) with Syzkaller.

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2025/38xxx/CVE-2025-38214.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
1da177e4c3f41524e886b7f1b8a0c1fc7321cac2
Fixed
ee20216f12d9482cd70e44dae5e7fabb38367c71
Fixed
fab201d72fde38d081e2c5d4ad25595c535b7b22
Fixed
1a10d91766eb6ddfd5414e4785611e33a4fe0f9b
Fixed
ff0e037241173b574b385bff53d67567b9816db5
Fixed
3ca78032a388a0795201792b36e6fc9b6e6e8eed
Fixed
b3071bb463ea1e6c686d0dc9638fc940f2f5cf17
Fixed
8a3a2887794b2c8e78b3e5d6e3de724527c9f41b
Fixed
05f6e183879d9785a3cdf2f08a498bc31b7a20aa

Database specific

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