diff options
| author | Bart Van Assche <bvanassche@acm.org> | 2025-10-31 13:39:34 -0700 |
|---|---|---|
| committer | Martin K. Petersen <martin.petersen@oracle.com> | 2025-11-12 17:02:34 -0500 |
| commit | 4b6c0d9cca359d1d2f666e14c42482befe5c4829 (patch) | |
| tree | 49c49a6078c2db6b7c5e932d34b2e594a2848406 /drivers/ufs/core/ufshcd.c | |
| parent | 9a2c9500921d5ebbe96f7531adc73d9205c76485 (diff) | |
scsi: ufs: core: Make blk_mq_tagset_busy_iter() skip reserved requests
A later patch will convert hba->reserved_slot into a reserved tag. Make
blk_mq_tagset_busy_iter() skip reserved requests such that device
management commands are skipped.
Signed-off-by: Bart Van Assche <bvanassche@acm.org>
Link: https://patch.msgid.link/20251031204029.2883185-27-bvanassche@acm.org
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Diffstat (limited to 'drivers/ufs/core/ufshcd.c')
| -rw-r--r-- | drivers/ufs/core/ufshcd.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/drivers/ufs/core/ufshcd.c b/drivers/ufs/core/ufshcd.c index 3e0fa433579d..f493f180279f 100644 --- a/drivers/ufs/core/ufshcd.c +++ b/drivers/ufs/core/ufshcd.c @@ -644,7 +644,8 @@ static bool ufshcd_print_tr_iter(struct request *req, void *priv) struct Scsi_Host *shost = sdev->host; struct ufs_hba *hba = shost_priv(shost); - ufshcd_print_tr(hba, blk_mq_rq_to_pdu(req), *(bool *)priv); + if (!blk_mq_is_reserved_rq(req)) + ufshcd_print_tr(hba, blk_mq_rq_to_pdu(req), *(bool *)priv); return true; } @@ -5753,7 +5754,7 @@ static bool ufshcd_mcq_force_compl_one(struct request *rq, void *priv) struct ufs_hba *hba = shost_priv(shost); struct ufs_hw_queue *hwq = ufshcd_mcq_req_to_hwq(hba, rq); - if (!hwq) + if (blk_mq_is_reserved_rq(rq) || !hwq) return true; ufshcd_mcq_compl_all_cqes_lock(hba, hwq); @@ -5780,7 +5781,7 @@ static bool ufshcd_mcq_compl_one(struct request *rq, void *priv) struct ufs_hba *hba = shost_priv(shost); struct ufs_hw_queue *hwq = ufshcd_mcq_req_to_hwq(hba, rq); - if (hwq) + if (!blk_mq_is_reserved_rq(rq) && hwq) ufshcd_mcq_poll_cqe_lock(hba, hwq); return true; @@ -6648,6 +6649,9 @@ static bool ufshcd_abort_one(struct request *rq, void *priv) struct Scsi_Host *shost = sdev->host; struct ufs_hba *hba = shost_priv(shost); + if (blk_mq_is_reserved_rq(rq)) + return true; + *ret = ufshcd_try_to_abort_task(hba, tag); dev_err(hba->dev, "Aborting tag %d / CDB %#02x %s\n", tag, ufshcd_is_scsi_cmd(cmd) ? cmd->cmnd[0] : -1, @@ -7597,7 +7601,7 @@ static bool ufshcd_clear_lu_cmds(struct request *req, void *priv) const u64 lun = *(u64 *)priv; const u32 tag = req->tag; - if (sdev->lun != lun) + if (blk_mq_is_reserved_rq(req) || sdev->lun != lun) return true; if (ufshcd_clear_cmd(hba, tag) < 0) { |