Xext: saver: fix length checking with bigreq

The authorative source of the request frame size is client->req_len,
especially with big requests larger than 2^18 bytes.

Signed-off-by: Enrico Weigelt, metux IT consult <info@metux.net>
Part-of: <https://gitlab.freedesktop.org/xorg/xserver/-/merge_requests/1639>
(cherry picked from commit bacc4b1477)
This commit is contained in:
Enrico Weigelt, metux IT consult 2024-08-06 15:58:11 +02:00 committed by Alan Coopersmith
parent f5a24358bf
commit d9f8aad4b6

View file

@ -749,7 +749,7 @@ ScreenSaverSetAttributes(ClientPtr client)
if (ret != Success)
return ret;
len = stuff->length - bytes_to_int32(sizeof(xScreenSaverSetAttributesReq));
len = client->req_len - bytes_to_int32(sizeof(xScreenSaverSetAttributesReq));
if (Ones(stuff->mask) != len)
return BadLength;
if (!stuff->width || !stuff->height) {
@ -1098,7 +1098,7 @@ ProcScreenSaverSetAttributes(ClientPtr client)
return (status == BadValue) ? BadDrawable : status;
len =
stuff->length -
client->req_len -
bytes_to_int32(sizeof(xScreenSaverSetAttributesReq));
if (Ones(stuff->mask) != len)
return BadLength;