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 dosyscall_64+0x33/0x40 arch/x86/entry/common.c:46
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.
[
    {
        "deprecated": false,
        "signature_version": "v1",
        "digest": {
            "threshold": 0.9,
            "line_hashes": [
                "55735543909866401690898676994990520784",
                "208243487935031299979468516138484128265",
                "97232342027304108586339148491034692134",
                "262304277851207670183417087624182550485",
                "110318784336869687641147005083747623769"
            ]
        },
        "target": {
            "file": "drivers/video/fbdev/core/fbmem.c"
        },
        "id": "CVE-2025-38214-181c6e95",
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@8a3a2887794b2c8e78b3e5d6e3de724527c9f41b",
        "signature_type": "Line"
    },
    {
        "deprecated": false,
        "signature_version": "v1",
        "digest": {
            "function_hash": "296600992874123883581873852320502722491",
            "length": 2540.0
        },
        "target": {
            "function": "fb_set_var",
            "file": "drivers/video/fbdev/core/fbmem.c"
        },
        "id": "CVE-2025-38214-3b7ab2c4",
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@fab201d72fde38d081e2c5d4ad25595c535b7b22",
        "signature_type": "Function"
    },
    {
        "deprecated": false,
        "signature_version": "v1",
        "digest": {
            "function_hash": "296600992874123883581873852320502722491",
            "length": 2540.0
        },
        "target": {
            "function": "fb_set_var",
            "file": "drivers/video/fbdev/core/fbmem.c"
        },
        "id": "CVE-2025-38214-43edb1d1",
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@1a10d91766eb6ddfd5414e4785611e33a4fe0f9b",
        "signature_type": "Function"
    },
    {
        "deprecated": false,
        "signature_version": "v1",
        "digest": {
            "threshold": 0.9,
            "line_hashes": [
                "55735543909866401690898676994990520784",
                "208243487935031299979468516138484128265",
                "97232342027304108586339148491034692134",
                "262304277851207670183417087624182550485",
                "110318784336869687641147005083747623769"
            ]
        },
        "target": {
            "file": "drivers/video/fbdev/core/fbmem.c"
        },
        "id": "CVE-2025-38214-47dce81d",
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@ff0e037241173b574b385bff53d67567b9816db5",
        "signature_type": "Line"
    },
    {
        "deprecated": false,
        "signature_version": "v1",
        "digest": {
            "function_hash": "296600992874123883581873852320502722491",
            "length": 2540.0
        },
        "target": {
            "function": "fb_set_var",
            "file": "drivers/video/fbdev/core/fbmem.c"
        },
        "id": "CVE-2025-38214-4ec9d3ad",
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@8a3a2887794b2c8e78b3e5d6e3de724527c9f41b",
        "signature_type": "Function"
    },
    {
        "deprecated": false,
        "signature_version": "v1",
        "digest": {
            "function_hash": "296600992874123883581873852320502722491",
            "length": 2540.0
        },
        "target": {
            "function": "fb_set_var",
            "file": "drivers/video/fbdev/core/fbmem.c"
        },
        "id": "CVE-2025-38214-7117ec0d",
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@ff0e037241173b574b385bff53d67567b9816db5",
        "signature_type": "Function"
    },
    {
        "deprecated": false,
        "signature_version": "v1",
        "digest": {
            "threshold": 0.9,
            "line_hashes": [
                "55735543909866401690898676994990520784",
                "208243487935031299979468516138484128265",
                "97232342027304108586339148491034692134",
                "262304277851207670183417087624182550485",
                "110318784336869687641147005083747623769"
            ]
        },
        "target": {
            "file": "drivers/video/fbdev/core/fbmem.c"
        },
        "id": "CVE-2025-38214-8295fba3",
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@b3071bb463ea1e6c686d0dc9638fc940f2f5cf17",
        "signature_type": "Line"
    },
    {
        "deprecated": false,
        "signature_version": "v1",
        "digest": {
            "function_hash": "296600992874123883581873852320502722491",
            "length": 2540.0
        },
        "target": {
            "function": "fb_set_var",
            "file": "drivers/video/fbdev/core/fbmem.c"
        },
        "id": "CVE-2025-38214-a44d810c",
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@ee20216f12d9482cd70e44dae5e7fabb38367c71",
        "signature_type": "Function"
    },
    {
        "deprecated": false,
        "signature_version": "v1",
        "digest": {
            "threshold": 0.9,
            "line_hashes": [
                "55735543909866401690898676994990520784",
                "208243487935031299979468516138484128265",
                "97232342027304108586339148491034692134",
                "262304277851207670183417087624182550485",
                "110318784336869687641147005083747623769"
            ]
        },
        "target": {
            "file": "drivers/video/fbdev/core/fbmem.c"
        },
        "id": "CVE-2025-38214-d2225dc6",
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@fab201d72fde38d081e2c5d4ad25595c535b7b22",
        "signature_type": "Line"
    },
    {
        "deprecated": false,
        "signature_version": "v1",
        "digest": {
            "threshold": 0.9,
            "line_hashes": [
                "55735543909866401690898676994990520784",
                "208243487935031299979468516138484128265",
                "97232342027304108586339148491034692134",
                "262304277851207670183417087624182550485",
                "110318784336869687641147005083747623769"
            ]
        },
        "target": {
            "file": "drivers/video/fbdev/core/fbmem.c"
        },
        "id": "CVE-2025-38214-e173d90b",
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@ee20216f12d9482cd70e44dae5e7fabb38367c71",
        "signature_type": "Line"
    },
    {
        "deprecated": false,
        "signature_version": "v1",
        "digest": {
            "function_hash": "296600992874123883581873852320502722491",
            "length": 2540.0
        },
        "target": {
            "function": "fb_set_var",
            "file": "drivers/video/fbdev/core/fbmem.c"
        },
        "id": "CVE-2025-38214-eb716115",
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@b3071bb463ea1e6c686d0dc9638fc940f2f5cf17",
        "signature_type": "Function"
    },
    {
        "deprecated": false,
        "signature_version": "v1",
        "digest": {
            "threshold": 0.9,
            "line_hashes": [
                "55735543909866401690898676994990520784",
                "208243487935031299979468516138484128265",
                "97232342027304108586339148491034692134",
                "262304277851207670183417087624182550485",
                "110318784336869687641147005083747623769"
            ]
        },
        "target": {
            "file": "drivers/video/fbdev/core/fbmem.c"
        },
        "id": "CVE-2025-38214-ed9ed4a2",
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@1a10d91766eb6ddfd5414e4785611e33a4fe0f9b",
        "signature_type": "Line"
    }
]