In the Linux kernel, the following vulnerability has been resolved:
tty: Require CAPSYSADMIN for all usages of TIOCL_SELMOUSEREPORT
This requirement was overeagerly loosened in commit 2f83e38a095f ("tty: Permit some TIOCLSETSEL modes without CAPSYS_ADMIN"), but as it turns out,
(1) the logic I implemented there was inconsistent (apologies!),
(2) TIOCL_SELMOUSEREPORT might actually be a small security risk after all, and
(3) TIOCLSELMOUSEREPORT is only meant to be used by the mouse daemon (GPM or Consolation), which runs as CAPSYS_ADMIN already.
In more detail:
The previous patch has inconsistent logic:
In commit 2f83e38a095f ("tty: Permit some TIOCLSETSEL modes without CAPSYSADMIN"), we checked for selmode == TIOCLSELMOUSEREPORT, but overlooked that the lower four bits of this "mode" parameter were actually used as an additional way to pass an argument. So the patch did actually still require CAPSYS_ADMIN, if any of the mouse button bits are set, but did not require it if none of the mouse buttons bits are set.
This logic is inconsistent and was not intentional. We should have the same policies for using TIOCL_SELMOUSEREPORT independent of the value of the "hidden" mouse button argument.
I sent a separate documentation patch to the man page list with more details on TIOCL_SELMOUSEREPORT: https://lore.kernel.org/all/20250223091342.35523-2-gnoack3000@gmail.com/
TIOCL_SELMOUSEREPORT is indeed a potential security risk which can let an attacker simulate "keyboard" input to command line applications on the same terminal, like TIOCSTI and some other TIOCLINUX "selection mode" IOCTLs.
By enabling mouse reporting on a terminal and then injecting mouse reports through TIOCLSELMOUSEREPORT, an attacker can simulate mouse movements on the same terminal, similar to the TIOCSTI keystroke injection attacks that were previously possible with TIOCSTI and other TIOCLSETSEL selection modes.
Many programs (including libreadline/bash) are then prone to misinterpret these mouse reports as normal keyboard input because they do not expect input in the X11 mouse protocol form. The attacker does not have complete control over the escape sequence, but they can at least control the values of two consecutive bytes in the binary mouse reporting escape sequence.
I went into more detail on that in the discussion at https://lore.kernel.org/all/20250221.0a947528d8f3@gnoack.org/
It is not equally trivial to simulate arbitrary keystrokes as it was with TIOCSTI (commit 83efeeeb3d04 ("tty: Allow TIOCSTI to be disabled")), but the general mechanism is there, and together with the small number of existing legit use cases (see below), it would be better to revert back to requiring CAPSYSADMIN for TIOCLSELMOUSEREPORT, as it was already the case before commit 2f83e38a095f ("tty: Permit some TIOCLSETSEL modes without CAPSYSADMIN").
TIOCL_SELMOUSEREPORT is only used by the mouse daemons (GPM or Consolation), and they are the only legit use case:
To quote console_codes(4):
The mouse tracking facility is intended to return xterm(1)-compatible mouse status reports. Because the console driver has no way to know the device or type of the mouse, these reports are returned in the console input stream only when the virtual terminal driver receives a mouse update ioctl. These ioctls must be generated by a mouse-aware user-mode application such as the gpm(8) daemon.
Jared Finder has also confirmed in https://lore.kernel.org/all/491f3df9de6593df8e70dbe77614b026@finder.org/ that Emacs does not call TIOCL_SELMOUSEREPORT directly, and it would be difficult to find good reasons for doing that, given that it would interfere with the reports that GPM is sending.
More information on the interaction between GPM, terminals and th ---truncated---
[
    {
        "signature_version": "v1",
        "digest": {
            "function_hash": "332063658022894426265684049257124446176",
            "length": 354.0
        },
        "deprecated": false,
        "id": "CVE-2025-37814-32030133",
        "target": {
            "function": "set_selection_user",
            "file": "drivers/tty/vt/selection.c"
        },
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@ee6a44da3c87cf64d67dd02be8c0127a5bf56175",
        "signature_type": "Function"
    },
    {
        "signature_version": "v1",
        "digest": {
            "threshold": 0.9,
            "line_hashes": [
                "113998874548482263951894889557870083000",
                "160544763968473496115045806906815499566",
                "104609646357144880351722214914488964609",
                "331186939663182165680411117435795328789",
                "108223213379321522342180838409869189938",
                "101578136291147349819011134672265453878",
                "110547042403807656371900522066885738199"
            ]
        },
        "deprecated": false,
        "id": "CVE-2025-37814-37fd6e10",
        "target": {
            "file": "drivers/tty/vt/selection.c"
        },
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@ee6a44da3c87cf64d67dd02be8c0127a5bf56175",
        "signature_type": "Line"
    },
    {
        "signature_version": "v1",
        "digest": {
            "threshold": 0.9,
            "line_hashes": [
                "113998874548482263951894889557870083000",
                "160544763968473496115045806906815499566",
                "104609646357144880351722214914488964609",
                "331186939663182165680411117435795328789",
                "108223213379321522342180838409869189938",
                "101578136291147349819011134672265453878",
                "110547042403807656371900522066885738199"
            ]
        },
        "deprecated": false,
        "id": "CVE-2025-37814-81a40a01",
        "target": {
            "file": "drivers/tty/vt/selection.c"
        },
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@6f021bc0083b96125fdbed6a60d7b4396c4d6dac",
        "signature_type": "Line"
    },
    {
        "signature_version": "v1",
        "digest": {
            "function_hash": "332063658022894426265684049257124446176",
            "length": 354.0
        },
        "deprecated": false,
        "id": "CVE-2025-37814-8acc9e47",
        "target": {
            "function": "set_selection_user",
            "file": "drivers/tty/vt/selection.c"
        },
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@6f021bc0083b96125fdbed6a60d7b4396c4d6dac",
        "signature_type": "Function"
    },
    {
        "signature_version": "v1",
        "digest": {
            "threshold": 0.9,
            "line_hashes": [
                "113998874548482263951894889557870083000",
                "160544763968473496115045806906815499566",
                "104609646357144880351722214914488964609",
                "331186939663182165680411117435795328789",
                "108223213379321522342180838409869189938",
                "101578136291147349819011134672265453878",
                "110547042403807656371900522066885738199"
            ]
        },
        "deprecated": false,
        "id": "CVE-2025-37814-9ff00937",
        "target": {
            "file": "drivers/tty/vt/selection.c"
        },
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@9b50c9c97db953de756a39af83d4be4d7f618aa6",
        "signature_type": "Line"
    },
    {
        "signature_version": "v1",
        "digest": {
            "function_hash": "332063658022894426265684049257124446176",
            "length": 354.0
        },
        "deprecated": false,
        "id": "CVE-2025-37814-ebb3bede",
        "target": {
            "function": "set_selection_user",
            "file": "drivers/tty/vt/selection.c"
        },
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@9b50c9c97db953de756a39af83d4be4d7f618aa6",
        "signature_type": "Function"
    }
]