summaryrefslogtreecommitdiffstats
path: root/drivers/scsi/hisi_sas/hisi_sas.h
diff options
context:
space:
mode:
authorAdrian Hunter <adrian.hunter@intel.com>2021-10-08 11:40:48 +0300
committerMartin K. Petersen <martin.petersen@oracle.com>2021-10-12 13:53:18 -0400
commitd489f18ad1fc33ab9b60dc40fe3851bb0d87de28 (patch)
treee684b5afb96f38e62adf346cf0149aa5707a8082 /drivers/scsi/hisi_sas/hisi_sas.h
parent9561f58442e48c3c71da250aa63bd02ec6bffcb5 (diff)
downloadlinux-d489f18ad1fc33ab9b60dc40fe3851bb0d87de28.tar.bz2
scsi: ufs: core: Fix synchronization between scsi_unjam_host() and ufshcd_queuecommand()
The SCSI error handler calls scsi_unjam_host() which can call the queue function ufshcd_queuecommand() indirectly. The error handler changes the state to UFSHCD_STATE_RESET while running, but error interrupts that happen while the error handler is running could change the state to UFSHCD_STATE_EH_SCHEDULED_NON_FATAL which would allow requests to go through ufshcd_queuecommand() even though the error handler is running. Block that hole by checking whether the error handler is in progress. Link: https://lore.kernel.org/r/20211008084048.257498-1-adrian.hunter@intel.com Reviewed-by: Asutosh Das <asutoshd@codeaurora.org> Signed-off-by: Adrian Hunter <adrian.hunter@intel.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Diffstat (limited to 'drivers/scsi/hisi_sas/hisi_sas.h')
0 files changed, 0 insertions, 0 deletions