diff options
author | Nilesh Javali <nilesh.javali@qlogic.com> | 2014-04-09 21:12:26 -0400 |
---|---|---|
committer | Christoph Hellwig <hch@lst.de> | 2014-05-19 13:12:19 -0400 |
commit | f65241e7294e344f4641131000ea88e3d70fa550 (patch) | |
tree | 15d67a5e4d28de2fa832eed0d42fe11fb8cf36a5 | |
parent | 906cbf3d2cef76a6e23207647cbbbc66023886f9 (diff) |
qla4xxx: Fix memory leak for ha->saved_acb
Signed-off-by: Vikas Chaudhary <vikas.chaudhary@qlogic.com>
Reviewed-by: Mike Christie <michaelc@cs.wisc.edu>
Signed-off-by: Christoph Hellwig <hch@lst.de>
-rw-r--r-- | drivers/scsi/qla4xxx/ql4_mbx.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/drivers/scsi/qla4xxx/ql4_mbx.c b/drivers/scsi/qla4xxx/ql4_mbx.c index 1345c0eaa6d7..0a3312c6dd6d 100644 --- a/drivers/scsi/qla4xxx/ql4_mbx.c +++ b/drivers/scsi/qla4xxx/ql4_mbx.c | |||
@@ -2395,8 +2395,6 @@ int qla4_84xx_config_acb(struct scsi_qla_host *ha, int acb_config) | |||
2395 | } | 2395 | } |
2396 | 2396 | ||
2397 | memcpy(acb, ha->saved_acb, acb_len); | 2397 | memcpy(acb, ha->saved_acb, acb_len); |
2398 | kfree(ha->saved_acb); | ||
2399 | ha->saved_acb = NULL; | ||
2400 | 2398 | ||
2401 | rval = qla4xxx_set_acb(ha, &mbox_cmd[0], &mbox_sts[0], acb_dma); | 2399 | rval = qla4xxx_set_acb(ha, &mbox_cmd[0], &mbox_sts[0], acb_dma); |
2402 | if (rval != QLA_SUCCESS) | 2400 | if (rval != QLA_SUCCESS) |
@@ -2412,6 +2410,10 @@ exit_free_acb: | |||
2412 | dma_free_coherent(&ha->pdev->dev, sizeof(struct addr_ctrl_blk), acb, | 2410 | dma_free_coherent(&ha->pdev->dev, sizeof(struct addr_ctrl_blk), acb, |
2413 | acb_dma); | 2411 | acb_dma); |
2414 | exit_config_acb: | 2412 | exit_config_acb: |
2413 | if ((acb_config == ACB_CONFIG_SET) && ha->saved_acb) { | ||
2414 | kfree(ha->saved_acb); | ||
2415 | ha->saved_acb = NULL; | ||
2416 | } | ||
2415 | DEBUG2(ql4_printk(KERN_INFO, ha, | 2417 | DEBUG2(ql4_printk(KERN_INFO, ha, |
2416 | "%s %s\n", __func__, | 2418 | "%s %s\n", __func__, |
2417 | rval == QLA_SUCCESS ? "SUCCEEDED" : "FAILED")); | 2419 | rval == QLA_SUCCESS ? "SUCCEEDED" : "FAILED")); |