Commit 2bbeb8d1 authored by Douglas Gilbert's avatar Douglas Gilbert Committed by Martin K. Petersen

scsi: core: Handle depopulation and restoration in progress

The default handling of the NOT READY sense key is to wait for the device
to become ready. The "wait" is assumed to be relatively short. However
there is a sub-class of NOT READY that have the "... in progress" phrase in
their additional sense code and these can take much longer.  Following on
from commit 505aa4b6 ("scsi: sd: Defer spinning up drive while SANITIZE
is in progress") we now have element depopulation and restoration that can
take a long time.  For example, over 24 hours for a 20 TB, 7200 rpm hard
disk to depopulate 1 of its 20 elements.

Add handling of ASC/ASCQ: 0x4,0x24 (depopulation in progress)
and ASC/ASCQ: 0x4,0x25 (depopulation restoration in progress)
to sd.c . The scsi_lib.c has incomplete handling of these
two messages, so complete it.
Signed-off-by: default avatarDouglas Gilbert <dgilbert@interlog.com>
Link: https://lore.kernel.org/r/20231015050650.131145-1-dgilbert@interlog.comSigned-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 72208ebe
...@@ -774,6 +774,7 @@ static void scsi_io_completion_action(struct scsi_cmnd *cmd, int result) ...@@ -774,6 +774,7 @@ static void scsi_io_completion_action(struct scsi_cmnd *cmd, int result)
case 0x1b: /* sanitize in progress */ case 0x1b: /* sanitize in progress */
case 0x1d: /* configuration in progress */ case 0x1d: /* configuration in progress */
case 0x24: /* depopulation in progress */ case 0x24: /* depopulation in progress */
case 0x25: /* depopulation restore in progress */
action = ACTION_DELAYED_RETRY; action = ACTION_DELAYED_RETRY;
break; break;
case 0x0a: /* ALUA state transition */ case 0x0a: /* ALUA state transition */
......
...@@ -2227,6 +2227,10 @@ sd_spinup_disk(struct scsi_disk *sdkp) ...@@ -2227,6 +2227,10 @@ sd_spinup_disk(struct scsi_disk *sdkp)
break; /* unavailable */ break; /* unavailable */
if (sshdr.asc == 4 && sshdr.ascq == 0x1b) if (sshdr.asc == 4 && sshdr.ascq == 0x1b)
break; /* sanitize in progress */ break; /* sanitize in progress */
if (sshdr.asc == 4 && sshdr.ascq == 0x24)
break; /* depopulation in progress */
if (sshdr.asc == 4 && sshdr.ascq == 0x25)
break; /* depopulation restoration in progress */
/* /*
* Issue command to spin up drive when not ready * Issue command to spin up drive when not ready
*/ */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment