Skip to content

Commit f3ee24a

Browse files
bvanasschegregkh
authored andcommitted
scsi: ufs: core: Fix handling of lrbp->cmd
[ Upstream commit 549e91a ] ufshcd_queuecommand() may be called two times in a row for a SCSI command before it is completed. Hence make the following changes: - In the functions that submit a command, do not check the old value of lrbp->cmd nor clear lrbp->cmd in error paths. - In ufshcd_release_scsi_cmd(), do not clear lrbp->cmd. See also scsi_send_eh_cmnd(). This commit prevents that the following appears if a command times out: WARNING: at drivers/ufs/core/ufshcd.c:2965 ufshcd_queuecommand+0x6f8/0x9a8 Call trace: ufshcd_queuecommand+0x6f8/0x9a8 scsi_send_eh_cmnd+0x2c0/0x960 scsi_eh_test_devices+0x100/0x314 scsi_eh_ready_devs+0xd90/0x114c scsi_error_handler+0x2b4/0xb70 kthread+0x16c/0x1e0 Fixes: 5a0b0cb ("[SCSI] ufs: Add support for sending NOP OUT UPIU") Signed-off-by: Bart Van Assche <bvanassche@acm.org> Link: https://lore.kernel.org/r/20230524203659.1394307-3-bvanassche@acm.org Acked-by: Adrian Hunter <adrian.hunter@intel.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
1 parent bf37fe5 commit f3ee24a

1 file changed

Lines changed: 1 addition & 6 deletions

File tree

drivers/ufs/core/ufshcd.c

Lines changed: 1 addition & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -2917,7 +2917,6 @@ static int ufshcd_queuecommand(struct Scsi_Host *host, struct scsi_cmnd *cmd)
29172917
(hba->clk_gating.state != CLKS_ON));
29182918

29192919
lrbp = &hba->lrb[tag];
2920-
WARN_ON(lrbp->cmd);
29212920
lrbp->cmd = cmd;
29222921
lrbp->task_tag = tag;
29232922
lrbp->lun = ufshcd_scsi_to_upiu_lun(cmd->device->lun);
@@ -2933,7 +2932,6 @@ static int ufshcd_queuecommand(struct Scsi_Host *host, struct scsi_cmnd *cmd)
29332932

29342933
err = ufshcd_map_sg(hba, lrbp);
29352934
if (err) {
2936-
lrbp->cmd = NULL;
29372935
ufshcd_release(hba);
29382936
goto out;
29392937
}
@@ -3152,7 +3150,7 @@ static int ufshcd_exec_dev_cmd(struct ufs_hba *hba,
31523150
down_read(&hba->clk_scaling_lock);
31533151

31543152
lrbp = &hba->lrb[tag];
3155-
WARN_ON(lrbp->cmd);
3153+
lrbp->cmd = NULL;
31563154
err = ufshcd_compose_dev_cmd(hba, lrbp, cmd_type, tag);
31573155
if (unlikely(err))
31583156
goto out;
@@ -5391,7 +5389,6 @@ static void ufshcd_release_scsi_cmd(struct ufs_hba *hba,
53915389
struct scsi_cmnd *cmd = lrbp->cmd;
53925390

53935391
scsi_dma_unmap(cmd);
5394-
lrbp->cmd = NULL; /* Mark the command as completed. */
53955392
ufshcd_release(hba);
53965393
ufshcd_clk_scaling_update_busy(hba);
53975394
}
@@ -7006,7 +7003,6 @@ static int ufshcd_issue_devman_upiu_cmd(struct ufs_hba *hba,
70067003
down_read(&hba->clk_scaling_lock);
70077004

70087005
lrbp = &hba->lrb[tag];
7009-
WARN_ON(lrbp->cmd);
70107006
lrbp->cmd = NULL;
70117007
lrbp->task_tag = tag;
70127008
lrbp->lun = 0;
@@ -7178,7 +7174,6 @@ int ufshcd_advanced_rpmb_req_handler(struct ufs_hba *hba, struct utp_upiu_req *r
71787174
down_read(&hba->clk_scaling_lock);
71797175

71807176
lrbp = &hba->lrb[tag];
7181-
WARN_ON(lrbp->cmd);
71827177
lrbp->cmd = NULL;
71837178
lrbp->task_tag = tag;
71847179
lrbp->lun = UFS_UPIU_RPMB_WLUN;

0 commit comments

Comments
 (0)