CVE-2025-39928

MEDIUM

Linux Kernel 6.13-6.16.7 - Integer Underflow in I2C RTL9300 Data Length Handling

Title source: llm
STIX 2.1

Description

In the Linux kernel, the following vulnerability has been resolved: i2c: rtl9300: ensure data length is within supported range Add an explicit check for the xfer length to 'rtl9300_i2c_config_xfer' to ensure the data length isn't within the supported range. In particular a data length of 0 is not supported by the hardware and causes unintended or destructive behaviour. This limitation becomes obvious when looking at the register documentation [1]. 4 bits are reserved for DATA_WIDTH and the value of these 4 bits is used as N + 1, allowing a data length range of 1 <= len <= 16. Affected by this is the SMBus Quick Operation which works with a data length of 0. Passing 0 as the length causes an underflow of the value due to: (len - 1) & 0xf and effectively specifying a transfer length of 16 via the registers. This causes a 16-byte write operation instead of a Quick Write. For example, on SFP modules without write-protected EEPROM this soft-bricks them by overwriting some initial bytes. For completeness, also add a quirk for the zero length. [1] https://svanheule.net/realtek/longan/register/i2c_mst1_ctrl2

Scores

CVSS v3 5.5
EPSS 0.0012
EPSS Percentile 1.9%
Attack Vector LOCAL
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H

CISA SSVC

Vulnrichment
Exploitation none
Automatable no
Technical Impact partial

Details

CWE
CWE-191
Status published
Products (9)
linux/Kernel 6.13.0 - 6.16.8linux
Linux/Linux < 6.13
Linux/Linux 6.13
Linux/Linux 6.16.8 - 6.16.*
Linux/Linux 6.17
Linux/Linux c366be720235301fdadf67e6f1ea6ff32669c074 - 06418cb5a1a542a003fdb4ad8e76ea542d57cfba
Linux/Linux c366be720235301fdadf67e6f1ea6ff32669c074 - c91382328fc89f73144d5582f2d8f1dd3e41c8f7
linux/linux_kernel 6.17 rc1 (4 CPE variants)
linux/linux_kernel 6.13 - 6.16.8
Published Oct 01, 2025
Tracked Since Feb 18, 2026