CVE-2025-39928

Source
https://cve.org/CVERecord?id=CVE-2025-39928
Import Source
https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2025-39928.json
JSON Data
https://api.osv.dev/v1/vulns/CVE-2025-39928
Downstream
Published
2025-10-01T08:07:15.530Z
Modified
2026-04-02T12:48:12.837662Z
Severity
  • 5.5 (Medium) CVSS_V3 - CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H CVSS Calculator
Summary
i2c: rtl9300: ensure data length is within supported range
Details

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 'rtl9300i2cconfig_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/i2cmst1ctrl2

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2025/39xxx/CVE-2025-39928.json",
    "cna_assigner": "Linux"
}
References

Affected packages

Git / git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git

Affected ranges

Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
c366be720235301fdadf67e6f1ea6ff32669c074
Fixed
c91382328fc89f73144d5582f2d8f1dd3e41c8f7
Fixed
06418cb5a1a542a003fdb4ad8e76ea542d57cfba

Database specific

source
"https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2025-39928.json"