summaryrefslogtreecommitdiffstats
path: root/drivers/scsi/ufs/ufshcd.h
diff options
context:
space:
mode:
authorCan Guo <cang@codeaurora.org>2020-11-03 07:24:39 +0100
committerMartin K. Petersen <martin.petersen@oracle.com>2020-11-05 05:13:33 +0100
commitda3fecb0040324c08f1587e5bff1f15f36be1872 (patch)
tree34a24460b616963f2012b9da2509ff80c4d4fc9a /drivers/scsi/ufs/ufshcd.h
parentscsi: mpt3sas: Fix timeouts observed while reenabling IRQ (diff)
downloadlinux-da3fecb0040324c08f1587e5bff1f15f36be1872.tar.xz
linux-da3fecb0040324c08f1587e5bff1f15f36be1872.zip
scsi: ufs: Fix unbalanced scsi_block_reqs_cnt caused by ufshcd_hold()
The scsi_block_reqs_cnt increased in ufshcd_hold() is supposed to be decreased back in ufshcd_ungate_work() in a paired way. However, if specific ufshcd_hold/release sequences are met, it is possible that scsi_block_reqs_cnt is increased twice but only one ungate work is queued. To make sure scsi_block_reqs_cnt is handled by ufshcd_hold() and ufshcd_ungate_work() in a paired way, increase it only if queue_work() returns true. Link: https://lore.kernel.org/r/1604384682-15837-2-git-send-email-cang@codeaurora.org Reviewed-by: Hongwu Su <hongwus@codeaurora.org> Reviewed-by: Stanley Chu <stanley.chu@mediatek.com> Reviewed-by: Bean Huo <beanhuo@micron.com> Signed-off-by: Can Guo <cang@codeaurora.org> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Diffstat (limited to 'drivers/scsi/ufs/ufshcd.h')
0 files changed, 0 insertions, 0 deletions