diff options
author | Peter Hutterer <peter.hutterer@who-t.net> | 2022-11-29 13:26:57 +1000 |
---|---|---|
committer | Peter Hutterer <peter.hutterer@who-t.net> | 2022-12-14 11:02:40 +1000 |
commit | 8f454b793e1f13c99872c15f0eed1d7f3b823fe8 (patch) | |
tree | 34bec7eba46083d8c67cef8b384bc5f32083526f /Xi/gtmotion.h | |
parent | b8a84cb0f2807b07ab70ca9915fcdee21301b8ca (diff) |
Xi: avoid integer truncation in length check of ProcXIChangeProperty
This fixes an OOB read and the resulting information disclosure.
Length calculation for the request was clipped to a 32-bit integer. With
the correct stuff->num_items value the expected request size was
truncated, passing the REQUEST_FIXED_SIZE check.
The server then proceeded with reading at least stuff->num_items bytes
(depending on stuff->format) from the request and stuffing whatever it
finds into the property. In the process it would also allocate at least
stuff->num_items bytes, i.e. 4GB.
The same bug exists in ProcChangeProperty and ProcXChangeDeviceProperty,
so let's fix that too.
CVE-2022-46344, ZDI-CAN 19405
This vulnerability was discovered by:
Jan-Niklas Sohn working with Trend Micro Zero Day Initiative
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
Acked-by: Olivier Fourdan <ofourdan@redhat.com>
Diffstat (limited to 'Xi/gtmotion.h')
0 files changed, 0 insertions, 0 deletions