lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [day] [month] [year] [list]
Message-ID: <2025111252-CVE-2025-40118-19e2@gregkh>
Date: Wed, 12 Nov 2025 19:23:54 +0900
From: Greg Kroah-Hartman <gregkh@...uxfoundation.org>
To: linux-cve-announce@...r.kernel.org
Cc: Greg Kroah-Hartman <gregkh@...nel.org>
Subject: CVE-2025-40118: scsi: pm80xx: Fix array-index-out-of-of-bounds on rmmod

From: Greg Kroah-Hartman <gregkh@...nel.org>

Description
===========

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/pm8001_sas.c:786:17
  index 28 is out of range for type 'pm8001_phy [16]'

on rmmod when using an expander.

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

I.e. while pm8001_ha will have pm8001_ha->chip->n_phy local phys, for a
device behind an expander, attached_phy can be much larger than
pm8001_ha->chip->n_phy (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 pm8001_ha->phy array only contains the phys of the HBA.  It does not
contain the phys of the expander.  Thus, it is wrong to use attached_phy
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.

The Linux kernel CVE team has assigned CVE-2025-40118 to this issue.


Affected and fixed versions
===========================

	Issue introduced in 5.4.293 with commit 05b512879eab41faa515b67fa3896d0005e97909 and fixed in 5.4.301 with commit d94be0a6ae9ade706d4270e740bdb4f79953a7fc
	Issue introduced in 5.10.237 with commit bc2140c8136200b4437e1abc0fb659968cb9baab and fixed in 5.10.246 with commit 45acbf154befedd9bc135f5e031fe7855d1e6493
	Issue introduced in 5.15.181 with commit 1d8f9378cb4800c18e20d80ecd605b2b93e87a03 and fixed in 5.15.195 with commit eef5ef400893f8e3dbb09342583be0cdc716d566
	Issue introduced in 6.1.136 with commit 30e482dfb8f27d22f518695d4bcb5e7f4c6cb08a and fixed in 6.1.156 with commit 9c671d4dbfbfb0d73cfdfb706afb36d9ad60a582
	Issue introduced in 6.6.89 with commit a862d24e1fc3ab1b5e5f20878d2898cea346d0ec and fixed in 6.6.112 with commit e62251954a128a2d0fcbc19e5fa39e08935bb628
	Issue introduced in 6.12.26 with commit 0f9802f174227f553959422f844eeb9ba72467fe and fixed in 6.12.53 with commit 9326a1541e1b7ed3efdbab72061b82cf01c6477a
	Issue introduced in 6.15 with commit f7b705c238d1483f0a766e2b20010f176e5c0fb7 and fixed in 6.17.3 with commit 83ced3c206c292458e47c7fac54223abc7141585
	Issue introduced in 6.15 with commit f7b705c238d1483f0a766e2b20010f176e5c0fb7 and fixed in 6.18-rc1 with commit 251be2f6037fb7ab399f68cd7428ff274133d693
	Issue introduced in 6.14.5 with commit 722026c010fa75bcf9e2373aff1d7930a3d7e3cf

Please see https://www.kernel.org for a full list of currently supported
kernel versions by the kernel community.

Unaffected versions might change over time as fixes are backported to
older supported kernel versions.  The official CVE entry at
	https://cve.org/CVERecord/?id=CVE-2025-40118
will be updated if fixes are backported, please check that for the most
up to date information about this issue.


Affected files
==============

The file(s) affected by this issue are:
	drivers/scsi/pm8001/pm8001_sas.c


Mitigation
==========

The Linux kernel CVE team recommends that you update to the latest
stable kernel version for this, and many other bugfixes.  Individual
changes are never tested alone, but rather are part of a larger kernel
release.  Cherry-picking individual commits is not recommended or
supported by the Linux kernel community at all.  If however, updating to
the latest release is impossible, the individual changes to resolve this
issue can be found at these commits:
	https://git.kernel.org/stable/c/d94be0a6ae9ade706d4270e740bdb4f79953a7fc
	https://git.kernel.org/stable/c/45acbf154befedd9bc135f5e031fe7855d1e6493
	https://git.kernel.org/stable/c/eef5ef400893f8e3dbb09342583be0cdc716d566
	https://git.kernel.org/stable/c/9c671d4dbfbfb0d73cfdfb706afb36d9ad60a582
	https://git.kernel.org/stable/c/e62251954a128a2d0fcbc19e5fa39e08935bb628
	https://git.kernel.org/stable/c/9326a1541e1b7ed3efdbab72061b82cf01c6477a
	https://git.kernel.org/stable/c/83ced3c206c292458e47c7fac54223abc7141585
	https://git.kernel.org/stable/c/251be2f6037fb7ab399f68cd7428ff274133d693

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ