]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
scsi: sd: Make sd shutdown issue START STOP UNIT appropriately
authorSalomon Dushimirimana <salomondush@google.com>
Thu, 24 Jul 2025 21:45:20 +0000 (21:45 +0000)
committerMartin K. Petersen <martin.petersen@oracle.com>
Fri, 25 Jul 2025 13:01:21 +0000 (09:01 -0400)
Commit aa3998dbeb3a ("ata: libata-scsi: Disable scsi device
manage_system_start_stop") enabled libata EH to manage device power mode
trasitions for system suspend/resume and removed the flag from
ata_scsi_dev_config. However, since the sd_shutdown() function still
relies on the manage_system_start_stop flag, a spin-down command is not
issued to the disk with command "echo 1 > /sys/block/sdb/device/delete"

sd_shutdown() can be called for both system/runtime start stop
operations, so utilize the manage_run_time_start_stop flag set in the
ata_scsi_dev_config and issue a spin-down command during disk removal
when the system is running. This is in addition to when the system is
powering off and manage_shutdown flag is set. The
manage_system_start_stop flag will still be used for drivers that still
set the flag.

Fixes: aa3998dbeb3a ("ata: libata-scsi: Disable scsi device manage_system_start_stop")
Signed-off-by: Salomon Dushimirimana <salomondush@google.com>
Link: https://lore.kernel.org/r/20250724214520.112927-1-salomondush@google.com
Tested-by: Damien Le Moal <dlemoal@kernel.org>
Reviewed-by: Damien Le Moal <dlemoal@kernel.org>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/sd.c

index daddef2e9e875e43b5605ec7d4041b1ce06ffd33..9e9b905b28813b5181243f159ee6b4ddf17e4499 100644 (file)
@@ -4168,7 +4168,9 @@ static void sd_shutdown(struct device *dev)
        if ((system_state != SYSTEM_RESTART &&
             sdkp->device->manage_system_start_stop) ||
            (system_state == SYSTEM_POWER_OFF &&
-            sdkp->device->manage_shutdown)) {
+            sdkp->device->manage_shutdown) ||
+           (system_state == SYSTEM_RUNNING &&
+            sdkp->device->manage_runtime_start_stop)) {
                sd_printk(KERN_NOTICE, sdkp, "Stopping disk\n");
                sd_start_stop_device(sdkp, 0);
        }