CVE-2026-43054
Gravedad CVSS v3.1:
MEDIA
Tipo:
No Disponible / Otro tipo
Fecha de publicación:
01/05/2026
Última modificación:
07/05/2026
Descripción
*** Pendiente de traducción *** In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
scsi: target: tcm_loop: Drain commands in target_reset handler<br />
<br />
tcm_loop_target_reset() violates the SCSI EH contract: it returns SUCCESS<br />
without draining any in-flight commands. The SCSI EH documentation<br />
(scsi_eh.rst) requires that when a reset handler returns SUCCESS the driver<br />
has made lower layers "forget about timed out scmds" and is ready for new<br />
commands. Every other SCSI LLD (virtio_scsi, mpt3sas, ipr, scsi_debug,<br />
mpi3mr) enforces this by draining or completing outstanding commands before<br />
returning SUCCESS.<br />
<br />
Because tcm_loop_target_reset() doesn&#39;t drain, the SCSI EH reuses in-flight<br />
scsi_cmnd structures for recovery commands (e.g. TUR) while the target core<br />
still has async completion work queued for the old se_cmd. The memset in<br />
queuecommand zeroes se_lun and lun_ref_active, causing<br />
transport_lun_remove_cmd() to skip its percpu_ref_put(). The leaked LUN<br />
reference prevents transport_clear_lun_ref() from completing, hanging<br />
configfs LUN unlink forever in D-state:<br />
<br />
INFO: task rm:264 blocked for more than 122 seconds.<br />
rm D 0 264 258 0x00004000<br />
Call Trace:<br />
__schedule+0x3d0/0x8e0<br />
schedule+0x36/0xf0<br />
transport_clear_lun_ref+0x78/0x90 [target_core_mod]<br />
core_tpg_remove_lun+0x28/0xb0 [target_core_mod]<br />
target_fabric_port_unlink+0x50/0x60 [target_core_mod]<br />
configfs_unlink+0x156/0x1f0 [configfs]<br />
vfs_unlink+0x109/0x290<br />
do_unlinkat+0x1d5/0x2d0<br />
<br />
Fix this by making tcm_loop_target_reset() actually drain commands:<br />
<br />
1. Issue TMR_LUN_RESET via tcm_loop_issue_tmr() to drain all commands that<br />
the target core knows about (those not yet CMD_T_COMPLETE).<br />
<br />
2. Use blk_mq_tagset_busy_iter() to iterate all started requests and<br />
flush_work() on each se_cmd — this drains any deferred completion work<br />
for commands that already had CMD_T_COMPLETE set before the TMR (which<br />
the TMR skips via __target_check_io_state()). This is the same pattern<br />
used by mpi3mr, scsi_debug, and libsas to drain outstanding commands<br />
during reset.
Impacto
Puntuación base 3.x
5.50
Gravedad 3.x
MEDIA
Productos y versiones vulnerables
| CPE | Desde | Hasta |
|---|---|---|
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.13 (incluyendo) | 5.15.203 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.16 (incluyendo) | 6.1.168 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.2 (incluyendo) | 6.6.134 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.7 (incluyendo) | 6.12.81 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.13 (incluyendo) | 6.18.22 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.19 (incluyendo) | 6.19.12 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:7.0:rc1:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc2:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc3:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc4:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc5:*:*:*:*:*:* |
Para consultar la lista completa de nombres de CPE con productos y versiones, ver esta página
Referencias a soluciones, herramientas e información
- https://git.kernel.org/stable/c/05ac3754467363558a0a54ae4bb7c89b2c9574cf
- https://git.kernel.org/stable/c/103f79e4949513247d763c6e7f3cbbf62017afdf
- https://git.kernel.org/stable/c/1333eee56cdf3f0cf67c6ab4114c2c9e0a952026
- https://git.kernel.org/stable/c/15f5241d5a52364a7e7867b49128b0442dbcad9d
- https://git.kernel.org/stable/c/757c43c692294cdfad31390accc0e90429b2ef8a
- https://git.kernel.org/stable/c/7cbd69aaa507b1245240a28022bf5da0f07c68d9
- https://git.kernel.org/stable/c/a836054ea81014117ec6b73529a21626a9e1f829



