]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
scsi: qla2xxx: Always check the return value of qla24xx_get_isp_stats()
authorBart Van Assche <bvanassche@acm.org>
Sat, 20 Mar 2021 23:23:58 +0000 (16:23 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 12 May 2021 06:37:23 +0000 (08:37 +0200)
[ Upstream commit a2b2cc660822cae08c351c7f6b452bfd1330a4f7 ]

This patch fixes the following Coverity warning:

    CID 361199 (#1 of 1): Unchecked return value (CHECKED_RETURN)
    3. check_return: Calling qla24xx_get_isp_stats without checking return
    value (as is done elsewhere 4 out of 5 times).

Link: https://lore.kernel.org/r/20210320232359.941-7-bvanassche@acm.org
Cc: Quinn Tran <qutran@marvell.com>
Cc: Mike Christie <michael.christie@oracle.com>
Cc: Himanshu Madhani <himanshu.madhani@oracle.com>
Cc: Daniel Wagner <dwagner@suse.de>
Cc: Lee Duncan <lduncan@suse.com>
Reviewed-by: Daniel Wagner <dwagner@suse.de>
Reviewed-by: Himanshu Madhani <himanshu.madhani@oracle.com>
Signed-off-by: Bart Van Assche <bvanassche@acm.org>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/scsi/qla2xxx/qla_attr.c

index ab45ac1e5a72c20bd186b1d6f59b61675f8fe87f..6a2c4a6fcded86fa4112099ea1d18288d25af7cd 100644 (file)
@@ -2855,6 +2855,8 @@ qla2x00_reset_host_stats(struct Scsi_Host *shost)
        vha->qla_stats.jiffies_at_last_reset = get_jiffies_64();
 
        if (IS_FWI2_CAPABLE(ha)) {
+               int rval;
+
                stats = dma_alloc_coherent(&ha->pdev->dev,
                    sizeof(*stats), &stats_dma, GFP_KERNEL);
                if (!stats) {
@@ -2864,7 +2866,11 @@ qla2x00_reset_host_stats(struct Scsi_Host *shost)
                }
 
                /* reset firmware statistics */
-               qla24xx_get_isp_stats(base_vha, stats, stats_dma, BIT_0);
+               rval = qla24xx_get_isp_stats(base_vha, stats, stats_dma, BIT_0);
+               if (rval != QLA_SUCCESS)
+                       ql_log(ql_log_warn, vha, 0x70de,
+                              "Resetting ISP statistics failed: rval = %d\n",
+                              rval);
 
                dma_free_coherent(&ha->pdev->dev, sizeof(*stats),
                    stats, stats_dma);