diff --git a/xkb/xkb.c b/xkb/xkb.c index f42f59ef3..1841cff26 100644 --- a/xkb/xkb.c +++ b/xkb/xkb.c @@ -5137,6 +5137,11 @@ _GetCountedString(char **wire_inout, ClientPtr client, char **str) CARD16 len; wire = *wire_inout; + + if (client->req_len < + bytes_to_int32(wire + 2 - (char *) client->requestBuffer)) + return BadValue; + len = *(CARD16 *) wire; if (client->swapped) { swaps(&len);