scsi: bfa: release allocated memory in case of error
authorNavid Emamdoost <navid.emamdoost@gmail.com>
Tue, 10 Sep 2019 23:44:15 +0000 (18:44 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 14 Jan 2020 19:08:37 +0000 (20:08 +0100)
commit 0e62395da2bd5166d7c9e14cbc7503b256a34cb0 upstream.

In bfad_im_get_stats if bfa_port_get_stats fails, allocated memory needs to
be released.

Link: https://lore.kernel.org/r/20190910234417.22151-1-navid.emamdoost@gmail.com
Signed-off-by: Navid Emamdoost <navid.emamdoost@gmail.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Cc: Ben Hutchings <ben.hutchings@codethink.co.uk>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/scsi/bfa/bfad_attr.c

index 29ab81df75c0173abc8ae843bc3553fcd770903e..fbfce02e5b93501d8c181f249b47e4d38314c155 100644 (file)
@@ -275,8 +275,10 @@ bfad_im_get_stats(struct Scsi_Host *shost)
        rc = bfa_port_get_stats(BFA_FCPORT(&bfad->bfa),
                                fcstats, bfad_hcb_comp, &fcomp);
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
-       if (rc != BFA_STATUS_OK)
+       if (rc != BFA_STATUS_OK) {
+               kfree(fcstats);
                return NULL;
+       }
 
        wait_for_completion(&fcomp.comp);