scsi: mpi3mr: Fix reporting of actual data transfer size
authorSreekanth Reddy <sreekanth.reddy@broadcom.com>
Thu, 10 Feb 2022 09:58:14 +0000 (15:28 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 13 Apr 2022 18:59:04 +0000 (20:59 +0200)
[ Upstream commit 9992246127246a27cc7184f05cce6f62ac48f84e ]

The driver is missing to set the residual size while completing an
I/O. Ensure proper data transfer size is reported to the kernel on I/O
completion based on the transfer length reported by the firmware.

Link: https://lore.kernel.org/r/20220210095817.22828-7-sreekanth.reddy@broadcom.com
Signed-off-by: Sreekanth Reddy <sreekanth.reddy@broadcom.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/scsi/mpi3mr/mpi3mr_os.c

index 3cae880..b2c6505 100644 (file)
@@ -2204,6 +2204,8 @@ void mpi3mr_process_op_reply_desc(struct mpi3mr_ioc *mrioc,
                scmd->result = DID_OK << 16;
                goto out_success;
        }
+
+       scsi_set_resid(scmd, scsi_bufflen(scmd) - xfer_count);
        if (ioc_status == MPI3_IOCSTATUS_SCSI_DATA_UNDERRUN &&
            xfer_count == 0 && (scsi_status == MPI3_SCSI_STATUS_BUSY ||
            scsi_status == MPI3_SCSI_STATUS_RESERVATION_CONFLICT ||