Kitty is a cross-platform GPU based terminal. In versions 0.46.2 and below, the handle_compose_command() function in kitty/graphics.c performs bounds validation on composition offsets using unsigned 32-bit arithmetic that is subject to integer wrapping, potentially leading to Heap Buffer Over-Read/Write. An attacker who can write escape sequences to a kitty terminal (e.g., via a malicious file, SSH login banner, or piped content) can supply crafted x_offset/y_offset values that pass the bounds check after wrapping but cause massive out-of-bounds heap memory access in compose_rectangles(). No user interaction is required. No non-default configuration is required. The attacker only needs the ability to produce output in a kitty terminal window. This issue has been fixed in version 0.47.0.
0.41.1-2+deb13u1build0.25.10.10.15.0-1ubuntu0.2+esm10.21.2-1ubuntu0.22.04.1+esm10.32.2-1ubuntu0.4+esm10.45.0-1ubuntu0.1~esm1Exploitability
AV:NAC:LPR:NUI:NScope
S:CImpact
C:LI:LA:HCVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:H