mirror of
https://gitlab.freedesktop.org/xorg/xserver.git
synced 2026-01-04 02:50:14 +01:00
xkb: Fix buffer overflow in XkbVModMaskText()
The code in XkbVModMaskText() allocates a fixed sized buffer on the stack and copies the virtual mod name. There's actually two issues in the code that can lead to a buffer overflow. First, the bound check mixes pointers and integers using misplaced parenthesis, defeating the bound check. But even though, if the check fails, the data is still copied, so the stack overflow will occur regardless. Change the logic to skip the copy entirely if the bound check fails. CVE-2025-26595, ZDI-CAN-25545 This vulnerability was discovered by: Jan-Niklas Sohn working with Trend Micro Zero Day Initiative Signed-off-by: Olivier Fourdan <ofourdan@redhat.com> Reviewed-by: Peter Hutterer <peter.hutterer@who-t.net> Part-of: <https://gitlab.freedesktop.org/xorg/xserver/-/merge_requests/1828>
This commit is contained in:
parent
b0a09ba602
commit
11fcda8753
1 changed files with 8 additions and 8 deletions
|
|
@ -173,14 +173,14 @@ XkbVModMaskText(XkbDescPtr xkb,
|
|||
len = strlen(tmp) + 1 + (str == buf ? 0 : 1);
|
||||
if (format == XkbCFile)
|
||||
len += 4;
|
||||
if ((str - (buf + len)) <= VMOD_BUFFER_SIZE) {
|
||||
if (str != buf) {
|
||||
if (format == XkbCFile)
|
||||
*str++ = '|';
|
||||
else
|
||||
*str++ = '+';
|
||||
len--;
|
||||
}
|
||||
if ((str - buf) + len > VMOD_BUFFER_SIZE)
|
||||
continue; /* Skip */
|
||||
if (str != buf) {
|
||||
if (format == XkbCFile)
|
||||
*str++ = '|';
|
||||
else
|
||||
*str++ = '+';
|
||||
len--;
|
||||
}
|
||||
if (format == XkbCFile)
|
||||
sprintf(str, "%sMask", tmp);
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue