CVE-2025-40118

Source
https://nvd.nist.gov/vuln/detail/CVE-2025-40118
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2025-40118.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2025-40118
Downstream
Published
2025-11-12T10:23:18.179Z
Modified
2025-11-28T02:35:06.285983Z
Summary
scsi: pm80xx: Fix array-index-out-of-of-bounds on rmmod
Details

In the Linux kernel, the following vulnerability has been resolved:

scsi: pm80xx: Fix array-index-out-of-of-bounds on rmmod

Since commit f7b705c238d1 ("scsi: pm80xx: Set phy_attached to zero when device is gone") UBSAN reports:

UBSAN: array-index-out-of-bounds in drivers/scsi/pm8001/pm8001sas.c:786:17 index 28 is out of range for type 'pm8001phy [16]'

on rmmod when using an expander.

For a direct attached device, attachedphy contains the local phy id. For a device behind an expander, attachedphy contains the remote phy id, not the local phy id.

I.e. while pm8001ha will have pm8001ha->chip->nphy local phys, for a device behind an expander, attachedphy can be much larger than pm8001ha->chip->nphy (depending on the amount of phys of the expander).

E.g. on my system pm8001_ha has 8 phys with phy ids 0-7. One of the ports has an expander connected. The expander has 31 phys with phy ids 0-30.

The pm8001ha->phy array only contains the phys of the HBA. It does not contain the phys of the expander. Thus, it is wrong to use attachedphy to index the pm8001_ha->phy array for a device behind an expander.

Thus, we can only clear phy_attached for devices that are directly attached.

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2025/40xxx/CVE-2025-40118.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
05b512879eab41faa515b67fa3896d0005e97909
Fixed
d94be0a6ae9ade706d4270e740bdb4f79953a7fc
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
bc2140c8136200b4437e1abc0fb659968cb9baab
Fixed
45acbf154befedd9bc135f5e031fe7855d1e6493
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
1d8f9378cb4800c18e20d80ecd605b2b93e87a03
Fixed
eef5ef400893f8e3dbb09342583be0cdc716d566
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
30e482dfb8f27d22f518695d4bcb5e7f4c6cb08a
Fixed
9c671d4dbfbfb0d73cfdfb706afb36d9ad60a582
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
a862d24e1fc3ab1b5e5f20878d2898cea346d0ec
Fixed
e62251954a128a2d0fcbc19e5fa39e08935bb628
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
0f9802f174227f553959422f844eeb9ba72467fe
Fixed
9326a1541e1b7ed3efdbab72061b82cf01c6477a
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
f7b705c238d1483f0a766e2b20010f176e5c0fb7
Fixed
83ced3c206c292458e47c7fac54223abc7141585
Fixed
251be2f6037fb7ab399f68cd7428ff274133d693
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
0 Unknown introduced commit / All previous commits are affected
Last affected
722026c010fa75bcf9e2373aff1d7930a3d7e3cf

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
5.4.301
Type
ECOSYSTEM
Events
Introduced
5.5.0
Fixed
5.10.246
Type
ECOSYSTEM
Events
Introduced
5.11.0
Fixed
5.15.195
Type
ECOSYSTEM
Events
Introduced
5.16.0
Fixed
6.1.156
Type
ECOSYSTEM
Events
Introduced
6.2.0
Fixed
6.6.112
Type
ECOSYSTEM
Events
Introduced
6.7.0
Fixed
6.12.53
Type
ECOSYSTEM
Events
Introduced
6.13.0
Fixed
6.17.3