diff options
author | James Smart <james.smart@emulex.com> | 2010-02-26 14:12:57 -0500 |
---|---|---|
committer | James Bottomley <James.Bottomley@suse.de> | 2010-03-03 08:38:34 -0500 |
commit | 9f1177a3f8eee22427eb97e6e00b62ff0be2871f (patch) | |
tree | a004d94e7d406f791e420eec7c02c2d5bcf70587 /drivers/scsi/lpfc/lpfc_hbadisc.c | |
parent | 43aebfa12e7631124472237dc945c27af54ca646 (diff) |
[SCSI] lpfc 8.3.10: Fix Initialization issues
- Add NULL checks to the pointers for the config_async mailbox
and dump_wakeup_params mailbox.
- Add code to check return value of lpfc_read_sparams everywhere
and handle failures appropriately.
Signed-off-by: James Smart <james.smart@emulex.com>
Signed-off-by: James Bottomley <James.Bottomley@suse.de>
Diffstat (limited to 'drivers/scsi/lpfc/lpfc_hbadisc.c')
-rw-r--r-- | drivers/scsi/lpfc/lpfc_hbadisc.c | 32 |
1 files changed, 18 insertions, 14 deletions
diff --git a/drivers/scsi/lpfc/lpfc_hbadisc.c b/drivers/scsi/lpfc/lpfc_hbadisc.c index 2359d0bfb734..e58d8aeec09e 100644 --- a/drivers/scsi/lpfc/lpfc_hbadisc.c +++ b/drivers/scsi/lpfc/lpfc_hbadisc.c | |||
@@ -2024,8 +2024,6 @@ lpfc_mbx_process_link_up(struct lpfc_hba *phba, READ_LA_VAR *la) | |||
2024 | int rc; | 2024 | int rc; |
2025 | struct fcf_record *fcf_record; | 2025 | struct fcf_record *fcf_record; |
2026 | 2026 | ||
2027 | sparam_mbox = mempool_alloc(phba->mbox_mem_pool, GFP_KERNEL); | ||
2028 | |||
2029 | spin_lock_irq(&phba->hbalock); | 2027 | spin_lock_irq(&phba->hbalock); |
2030 | switch (la->UlnkSpeed) { | 2028 | switch (la->UlnkSpeed) { |
2031 | case LA_1GHZ_LINK: | 2029 | case LA_1GHZ_LINK: |
@@ -2117,18 +2115,24 @@ lpfc_mbx_process_link_up(struct lpfc_hba *phba, READ_LA_VAR *la) | |||
2117 | spin_unlock_irq(&phba->hbalock); | 2115 | spin_unlock_irq(&phba->hbalock); |
2118 | 2116 | ||
2119 | lpfc_linkup(phba); | 2117 | lpfc_linkup(phba); |
2120 | if (sparam_mbox) { | 2118 | sparam_mbox = mempool_alloc(phba->mbox_mem_pool, GFP_KERNEL); |
2121 | lpfc_read_sparam(phba, sparam_mbox, 0); | 2119 | if (!sparam_mbox) |
2122 | sparam_mbox->vport = vport; | 2120 | goto out; |
2123 | sparam_mbox->mbox_cmpl = lpfc_mbx_cmpl_read_sparam; | 2121 | |
2124 | rc = lpfc_sli_issue_mbox(phba, sparam_mbox, MBX_NOWAIT); | 2122 | rc = lpfc_read_sparam(phba, sparam_mbox, 0); |
2125 | if (rc == MBX_NOT_FINISHED) { | 2123 | if (rc) { |
2126 | mp = (struct lpfc_dmabuf *) sparam_mbox->context1; | 2124 | mempool_free(sparam_mbox, phba->mbox_mem_pool); |
2127 | lpfc_mbuf_free(phba, mp->virt, mp->phys); | 2125 | goto out; |
2128 | kfree(mp); | 2126 | } |
2129 | mempool_free(sparam_mbox, phba->mbox_mem_pool); | 2127 | sparam_mbox->vport = vport; |
2130 | goto out; | 2128 | sparam_mbox->mbox_cmpl = lpfc_mbx_cmpl_read_sparam; |
2131 | } | 2129 | rc = lpfc_sli_issue_mbox(phba, sparam_mbox, MBX_NOWAIT); |
2130 | if (rc == MBX_NOT_FINISHED) { | ||
2131 | mp = (struct lpfc_dmabuf *) sparam_mbox->context1; | ||
2132 | lpfc_mbuf_free(phba, mp->virt, mp->phys); | ||
2133 | kfree(mp); | ||
2134 | mempool_free(sparam_mbox, phba->mbox_mem_pool); | ||
2135 | goto out; | ||
2132 | } | 2136 | } |
2133 | 2137 | ||
2134 | if (!(phba->hba_flag & HBA_FCOE_SUPPORT)) { | 2138 | if (!(phba->hba_flag & HBA_FCOE_SUPPORT)) { |