]> Git Repo - linux.git/commitdiff
scsi: ufs: mcq: Use pointer arithmetic in ufshcd_send_command()
authorAvri Altman <[email protected]>
Wed, 29 Mar 2023 10:13:03 +0000 (13:13 +0300)
committerMartin K. Petersen <[email protected]>
Wed, 12 Apr 2023 01:46:59 +0000 (21:46 -0400)
Make sqe_base_addr the UTRD pointer it is, instead of an opaque void *.

Signed-off-by: Avri Altman <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Martin K. Petersen <[email protected]>
drivers/ufs/core/ufshcd.c
include/ufs/ufshcd.h

index 03c47f9a2750f23faf1bfc99afec39c3b06e10f4..9434328ba3231996430348e5013279203376b968 100644 (file)
@@ -2242,10 +2242,11 @@ void ufshcd_send_command(struct ufs_hba *hba, unsigned int task_tag,
 
        if (is_mcq_enabled(hba)) {
                int utrd_size = sizeof(struct utp_transfer_req_desc);
+               struct utp_transfer_req_desc *src = lrbp->utr_descriptor_ptr;
+               struct utp_transfer_req_desc *dest = hwq->sqe_base_addr + hwq->sq_tail_slot;
 
                spin_lock(&hwq->sq_lock);
-               memcpy(hwq->sqe_base_addr + (hwq->sq_tail_slot * utrd_size),
-                      lrbp->utr_descriptor_ptr, utrd_size);
+               memcpy(dest, src, utrd_size);
                ufshcd_inc_sq_tail(hwq);
                spin_unlock(&hwq->sq_lock);
        } else {
index 8b1046c21960c5cd2b0f5902c1b6a8776ef3a0c8..721ae4cd370237ab00bfdb2397b66720d3d2a9f9 100644 (file)
@@ -1095,7 +1095,7 @@ struct ufs_hw_queue {
        void __iomem *mcq_cq_head;
        void __iomem *mcq_cq_tail;
 
-       void *sqe_base_addr;
+       struct utp_transfer_req_desc *sqe_base_addr;
        dma_addr_t sqe_dma_addr;
        struct cq_entry *cqe_base_addr;
        dma_addr_t cqe_dma_addr;
This page took 0.086423 seconds and 4 git commands to generate.