[SCSI] qla4xxx: Fix verify boot idx correctly
qla4xxx_verify_boot_idx can falsely report a DDB to be boot target if ha->pri_ddb_idx and ha->sec_ddb_idx are not initialized correctly. What this could cause is if there is DDB entry in FLash at index 0, then qla4xxx_verify_boot_idx would return wrong result as ha->pri_ddb_idx is not set correctly. Fixed the qla4xxx_get_boot_info to set the ha->pri_ddb_idx and ha->sec_ddb_idx correctly. Signed-off-by: Lalit Chandivade <lalit.chandivade@qlogic.com> Signed-off-by: Vikas Chaudhary <vikas.chaudhary@qlogic.com> Reviewed-by: Mike Christie <michaelc@cs.wisc.edu> Signed-off-by: James Bottomley <JBottomley@Parallels.com>
This commit is contained in:
parent
981c982c2d
commit
20e835b43f
1 changed files with 2 additions and 3 deletions
|
@ -3463,12 +3463,11 @@ static int get_fw_boot_info(struct scsi_qla_host *ha, uint16_t ddb_index[])
|
|||
" target ID %d\n", __func__, ddb_index[0],
|
||||
ddb_index[1]));
|
||||
|
||||
ha->pri_ddb_idx = ddb_index[0];
|
||||
ha->sec_ddb_idx = ddb_index[1];
|
||||
|
||||
exit_boot_info_free:
|
||||
dma_free_coherent(&ha->pdev->dev, size, buf, buf_dma);
|
||||
exit_boot_info:
|
||||
ha->pri_ddb_idx = ddb_index[0];
|
||||
ha->sec_ddb_idx = ddb_index[1];
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue