WRT_REG_WORD(®->mailbox0, MBC_DUMP_RISC_RAM_EXTENDED);
        clear_bit(MBX_INTERRUPT, &ha->mbx_cmd_flags);
 
-       dwords = GID_LIST_SIZE / 4;
+       dwords = qla2x00_gid_list_size(ha) / 4;
        for (cnt = 0; cnt < ram_dwords && rval == QLA_SUCCESS;
            cnt += dwords, addr += dwords) {
                if (cnt + dwords > ram_dwords)
        WRT_MAILBOX_REG(ha, reg, 0, MBC_DUMP_RISC_RAM_EXTENDED);
        clear_bit(MBX_INTERRUPT, &ha->mbx_cmd_flags);
 
-       words = GID_LIST_SIZE / 2;
+       words = qla2x00_gid_list_size(ha) / 2;
        for (cnt = 0; cnt < ram_words && rval == QLA_SUCCESS;
            cnt += words, addr += words) {
                if (cnt + words > ram_words)
 
  * Fibre Channel device definitions.
  */
 #define WWN_SIZE               8       /* Size of WWPN, WWN & WWNN */
-#define MAX_FIBRE_DEVICES      512
+#define MAX_FIBRE_DEVICES_2100 512
+#define MAX_FIBRE_DEVICES_2400 2048
+#define MAX_FIBRE_DEVICES_LOOP 128
+#define MAX_FIBRE_DEVICES_MAX  MAX_FIBRE_DEVICES_2400
 #define MAX_FIBRE_LUNS         0xFFFF
 #define        MAX_HOST_COUNT          16
 
  * Host adapter default definitions.
  */
 #define MAX_BUSES              1  /* We only have one bus today */
-#define MAX_TARGETS_2100       MAX_FIBRE_DEVICES
-#define MAX_TARGETS_2200       MAX_FIBRE_DEVICES
 #define MIN_LUNS               8
 #define MAX_LUNS               MAX_FIBRE_LUNS
 #define MAX_CMDS_PER_LUN       255
 
 #define        GID_PT_CMD      0x1A1
 #define        GID_PT_REQ_SIZE (16 + 4)
-#define        GID_PT_RSP_SIZE (16 + (MAX_FIBRE_DEVICES * 4))
 
 #define        GPN_ID_CMD      0x112
 #define        GPN_ID_REQ_SIZE (16 + 4)
                } ga_nxt;
 
                struct {
-                       struct ct_sns_gid_pt_data entries[MAX_FIBRE_DEVICES];
+                       /* Assume the largest number of targets for the union */
+                       struct ct_sns_gid_pt_data
+                           entries[MAX_FIBRE_DEVICES_MAX];
                } gid_pt;
 
                struct {
 
 #define        GID_PT_SNS_SCMD_LEN     6
 #define        GID_PT_SNS_CMD_SIZE     28
-#define        GID_PT_SNS_DATA_SIZE    (MAX_FIBRE_DEVICES * 4 + 16)
+/*
+ * Assume MAX_FIBRE_DEVICES_2100 as these defines are only used with older
+ * adapters.
+ */
+#define        GID_PT_SNS_DATA_SIZE    (MAX_FIBRE_DEVICES_2100 * 4 + 16)
 
 #define        GPN_ID_SNS_SCMD_LEN     6
 #define        GPN_ID_SNS_CMD_SIZE     28
        uint16_t loop_id;       /* ISP23XX         -- 6 bytes. */
        uint16_t reserved_1;    /* ISP24XX         -- 8 bytes. */
 };
-#define GID_LIST_SIZE (sizeof(struct gid_list_info) * MAX_FIBRE_DEVICES)
 
 /* NPIV */
 typedef struct vport_info {
        atomic_t        loop_down_timer;         /* loop down timer */
        uint8_t         link_down_timeout;       /* link down timeout */
        uint16_t        max_loop_id;
+       uint16_t        max_fibre_devices;      /* Maximum number of targets */
 
        uint16_t        fb_rev;
        uint16_t        min_external_loopid;    /* First external loop Id */
 
        return (rval);
 }
 
+static inline int
+qla2x00_gid_pt_rsp_size(scsi_qla_host_t *vha)
+{
+       return vha->hw->max_fibre_devices * 4 + 16;
+}
+
 /**
  * qla2x00_gid_pt() - SNS scan for fabric devices via GID_PT command.
  * @ha: HA context
 
        struct ct_sns_gid_pt_data *gid_data;
        struct qla_hw_data *ha = vha->hw;
+       uint16_t gid_pt_rsp_size;
 
        if (IS_QLA2100(ha) || IS_QLA2200(ha))
                return qla2x00_sns_gid_pt(vha, list);
 
        gid_data = NULL;
-
+       gid_pt_rsp_size = qla2x00_gid_pt_rsp_size(vha);
        /* Issue GID_PT */
        /* Prepare common MS IOCB */
        ms_pkt = ha->isp_ops->prep_ms_iocb(vha, GID_PT_REQ_SIZE,
-           GID_PT_RSP_SIZE);
+           gid_pt_rsp_size);
 
        /* Prepare CT request */
        ct_req = qla2x00_prep_ct_req(&ha->ct_sns->p.req, GID_PT_CMD,
-           GID_PT_RSP_SIZE);
+           gid_pt_rsp_size);
        ct_rsp = &ha->ct_sns->p.rsp;
 
        /* Prepare CT arguments -- port_type */
                rval = QLA_FUNCTION_FAILED;
        } else {
                /* Set port IDs in switch info list. */
-               for (i = 0; i < MAX_FIBRE_DEVICES; i++) {
+               for (i = 0; i < ha->max_fibre_devices; i++) {
                        gid_data = &ct_rsp->rsp.gid_pt.entries[i];
                        list[i].d_id.b.domain = gid_data->port_id[0];
                        list[i].d_id.b.area = gid_data->port_id[1];
                 * single call.  Return a failed status, and let GA_NXT handle
                 * the overload.
                 */
-               if (i == MAX_FIBRE_DEVICES)
+               if (i == ha->max_fibre_devices)
                        rval = QLA_FUNCTION_FAILED;
        }
 
 int
 qla2x00_gpn_id(scsi_qla_host_t *vha, sw_info_t *list)
 {
-       int             rval;
+       int             rval = QLA_SUCCESS;
        uint16_t        i;
 
        ms_iocb_entry_t *ms_pkt;
        if (IS_QLA2100(ha) || IS_QLA2200(ha))
                return qla2x00_sns_gpn_id(vha, list);
 
-       for (i = 0; i < MAX_FIBRE_DEVICES; i++) {
+       for (i = 0; i < ha->max_fibre_devices; i++) {
                /* Issue GPN_ID */
                /* Prepare common MS IOCB */
                ms_pkt = ha->isp_ops->prep_ms_iocb(vha, GPN_ID_REQ_SIZE,
 int
 qla2x00_gnn_id(scsi_qla_host_t *vha, sw_info_t *list)
 {
-       int             rval;
+       int             rval = QLA_SUCCESS;
        uint16_t        i;
        struct qla_hw_data *ha = vha->hw;
        ms_iocb_entry_t *ms_pkt;
        if (IS_QLA2100(ha) || IS_QLA2200(ha))
                return qla2x00_sns_gnn_id(vha, list);
 
-       for (i = 0; i < MAX_FIBRE_DEVICES; i++) {
+       for (i = 0; i < ha->max_fibre_devices; i++) {
                /* Issue GNN_ID */
                /* Prepare common MS IOCB */
                ms_pkt = ha->isp_ops->prep_ms_iocb(vha, GNN_ID_REQ_SIZE,
 static int
 qla2x00_sns_ga_nxt(scsi_qla_host_t *vha, fc_port_t *fcport)
 {
-       int             rval;
+       int             rval = QLA_SUCCESS;
        struct qla_hw_data *ha = vha->hw;
        struct sns_cmd_pkt      *sns_cmd;
 
        uint16_t        i;
        uint8_t         *entry;
        struct sns_cmd_pkt      *sns_cmd;
+       uint16_t gid_pt_sns_data_size;
+
+       gid_pt_sns_data_size = qla2x00_gid_pt_rsp_size(vha);
 
        /* Issue GID_PT. */
        /* Prepare SNS command request. */
        sns_cmd = qla2x00_prep_sns_cmd(vha, GID_PT_CMD, GID_PT_SNS_SCMD_LEN,
-           GID_PT_SNS_DATA_SIZE);
+           gid_pt_sns_data_size);
 
        /* Prepare SNS command arguments -- port_type. */
        sns_cmd->p.cmd.param[0] = NS_NX_PORT_TYPE;
                rval = QLA_FUNCTION_FAILED;
        } else {
                /* Set port IDs in switch info list. */
-               for (i = 0; i < MAX_FIBRE_DEVICES; i++) {
+               for (i = 0; i < ha->max_fibre_devices; i++) {
                        entry = &sns_cmd->p.gid_data[(i * 4) + 16];
                        list[i].d_id.b.domain = entry[1];
                        list[i].d_id.b.area = entry[2];
                 * single call.  Return a failed status, and let GA_NXT handle
                 * the overload.
                 */
-               if (i == MAX_FIBRE_DEVICES)
+               if (i == ha->max_fibre_devices)
                        rval = QLA_FUNCTION_FAILED;
        }
 
 static int
 qla2x00_sns_gpn_id(scsi_qla_host_t *vha, sw_info_t *list)
 {
-       int             rval;
+       int             rval = QLA_SUCCESS;
        struct qla_hw_data *ha = vha->hw;
        uint16_t        i;
        struct sns_cmd_pkt      *sns_cmd;
 
-       for (i = 0; i < MAX_FIBRE_DEVICES; i++) {
+       for (i = 0; i < ha->max_fibre_devices; i++) {
                /* Issue GPN_ID */
                /* Prepare SNS command request. */
                sns_cmd = qla2x00_prep_sns_cmd(vha, GPN_ID_CMD,
 static int
 qla2x00_sns_gnn_id(scsi_qla_host_t *vha, sw_info_t *list)
 {
-       int             rval;
+       int             rval = QLA_SUCCESS;
        struct qla_hw_data *ha = vha->hw;
        uint16_t        i;
        struct sns_cmd_pkt      *sns_cmd;
 
-       for (i = 0; i < MAX_FIBRE_DEVICES; i++) {
+       for (i = 0; i < ha->max_fibre_devices; i++) {
                /* Issue GNN_ID */
                /* Prepare SNS command request. */
                sns_cmd = qla2x00_prep_sns_cmd(vha, GNN_ID_CMD,
 int
 qla2x00_gfpn_id(scsi_qla_host_t *vha, sw_info_t *list)
 {
-       int             rval;
+       int             rval = QLA_SUCCESS;
        uint16_t        i;
        struct qla_hw_data *ha = vha->hw;
        ms_iocb_entry_t *ms_pkt;
        if (!IS_IIDMA_CAPABLE(ha))
                return QLA_FUNCTION_FAILED;
 
-       for (i = 0; i < MAX_FIBRE_DEVICES; i++) {
+       for (i = 0; i < ha->max_fibre_devices; i++) {
                /* Issue GFPN_ID */
                /* Prepare common MS IOCB */
                ms_pkt = ha->isp_ops->prep_ms_iocb(vha, GFPN_ID_REQ_SIZE,
        if (rval)
                return rval;
 
-       for (i = 0; i < MAX_FIBRE_DEVICES; i++) {
+       for (i = 0; i < ha->max_fibre_devices; i++) {
                /* Issue GFPN_ID */
                /* Prepare common MS IOCB */
                ms_pkt = qla24xx_prep_ms_fm_iocb(vha, GPSC_REQ_SIZE,
        struct qla_hw_data *ha = vha->hw;
        uint8_t fcp_scsi_features = 0;
 
-       for (i = 0; i < MAX_FIBRE_DEVICES; i++) {
+       for (i = 0; i < ha->max_fibre_devices; i++) {
                /* Set default FC4 Type as UNKNOWN so the default is to
                 * Process this port */
                list[i].fc4_type = FC4_TYPE_UNKNOWN;
 
                        ql_dbg(ql_dbg_disc, vha, 0x2015,
                            "Loop resync needed, failing.\n");
                        rval = QLA_FUNCTION_FAILED;
-               }
-               else
+               } else
                        rval = qla2x00_configure_local_loop(vha);
        }
 
 
        found_devs = 0;
        new_fcport = NULL;
-       entries = MAX_FIBRE_DEVICES;
+       entries = MAX_FIBRE_DEVICES_LOOP;
 
        ql_dbg(ql_dbg_disc, vha, 0x2016,
            "Getting FCAL position map.\n");
                qla2x00_get_fcal_position_map(vha, NULL);
 
        /* Get list of logged in devices. */
-       memset(ha->gid_list, 0, GID_LIST_SIZE);
+       memset(ha->gid_list, 0, qla2x00_gid_list_size(ha));
        rval = qla2x00_get_id_list(vha, ha->gid_list, ha->gid_list_dma,
            &entries);
        if (rval != QLA_SUCCESS)
 
        /* Try GID_PT to get device list, else GAN. */
        if (!ha->swl)
-               ha->swl = kcalloc(MAX_FIBRE_DEVICES, sizeof(sw_info_t),
+               ha->swl = kcalloc(ha->max_fibre_devices, sizeof(sw_info_t),
                    GFP_KERNEL);
        swl = ha->swl;
        if (!swl) {
                ql_dbg(ql_dbg_disc, vha, 0x2054,
                    "GID_PT allocations failed, fallback on GA_NXT.\n");
        } else {
-               memset(swl, 0, MAX_FIBRE_DEVICES * sizeof(sw_info_t));
+               memset(swl, 0, ha->max_fibre_devices * sizeof(sw_info_t));
                if (qla2x00_gid_pt(vha, swl) != QLA_SUCCESS) {
                        swl = NULL;
                } else if (qla2x00_gpn_id(vha, swl) != QLA_SUCCESS) {
 
        add_timer(&sp->u.iocb_cmd.timer);
        sp->free = qla2x00_sp_free;
 }
+
+static inline int
+qla2x00_gid_list_size(struct qla_hw_data *ha)
+{
+       return sizeof(struct gid_list_info) * ha->max_fibre_devices;
+}
 
        host->max_channel = MAX_BUSES - 1;
        host->max_lun = ql2xmaxlun;
        host->unique_id = host->host_no;
-       host->max_id = MAX_TARGETS_2200;
+       host->max_id = ha->max_fibre_devices;
        host->transportt = qla2xxx_transport_vport_template;
 
        ql_dbg(ql_dbg_vport, vha, 0xa007,
 
        char pci_info[30];
        char fw_str[30];
        struct scsi_host_template *sht;
-       int bars, max_id, mem_only = 0;
+       int bars, mem_only = 0;
        uint16_t req_length = 0, rsp_length = 0;
        struct req_que *req = NULL;
        struct rsp_que *rsp = NULL;
        ha->optrom_size = OPTROM_SIZE_2300;
 
        /* Assign ISP specific operations. */
-       max_id = MAX_TARGETS_2200;
        if (IS_QLA2100(ha)) {
-               max_id = MAX_TARGETS_2100;
+               ha->max_fibre_devices = MAX_FIBRE_DEVICES_2100;
                ha->mbx_count = MAILBOX_REGISTER_COUNT_2100;
                req_length = REQUEST_ENTRY_CNT_2100;
                rsp_length = RESPONSE_ENTRY_CNT_2100;
                ha->nvram_data_off = ~0;
                ha->isp_ops = &qla2100_isp_ops;
        } else if (IS_QLA2200(ha)) {
+               ha->max_fibre_devices = MAX_FIBRE_DEVICES_2100;
                ha->mbx_count = MAILBOX_REGISTER_COUNT_2200;
                req_length = REQUEST_ENTRY_CNT_2200;
                rsp_length = RESPONSE_ENTRY_CNT_2100;
                ha->nvram_data_off = ~0;
                ha->isp_ops = &qla2100_isp_ops;
        } else if (IS_QLA23XX(ha)) {
+               ha->max_fibre_devices = MAX_FIBRE_DEVICES_2100;
                ha->mbx_count = MAILBOX_REGISTER_COUNT;
                req_length = REQUEST_ENTRY_CNT_2200;
                rsp_length = RESPONSE_ENTRY_CNT_2300;
                ha->nvram_data_off = ~0;
                ha->isp_ops = &qla2300_isp_ops;
        } else if (IS_QLA24XX_TYPE(ha)) {
+               ha->max_fibre_devices = MAX_FIBRE_DEVICES_2400;
                ha->mbx_count = MAILBOX_REGISTER_COUNT;
                req_length = REQUEST_ENTRY_CNT_24XX;
                rsp_length = RESPONSE_ENTRY_CNT_2300;
                ha->nvram_conf_off = FARX_ACCESS_NVRAM_CONF;
                ha->nvram_data_off = FARX_ACCESS_NVRAM_DATA;
        } else if (IS_QLA25XX(ha)) {
+               ha->max_fibre_devices = MAX_FIBRE_DEVICES_2400;
                ha->mbx_count = MAILBOX_REGISTER_COUNT;
                req_length = REQUEST_ENTRY_CNT_24XX;
                rsp_length = RESPONSE_ENTRY_CNT_2300;
                ha->nvram_conf_off = FARX_ACCESS_NVRAM_CONF;
                ha->nvram_data_off = FARX_ACCESS_NVRAM_DATA;
        } else if (IS_QLA81XX(ha)) {
+               ha->max_fibre_devices = MAX_FIBRE_DEVICES_2400;
                ha->mbx_count = MAILBOX_REGISTER_COUNT;
                req_length = REQUEST_ENTRY_CNT_24XX;
                rsp_length = RESPONSE_ENTRY_CNT_2300;
                ha->nvram_conf_off = ~0;
                ha->nvram_data_off = ~0;
        } else if (IS_QLA82XX(ha)) {
+               ha->max_fibre_devices = MAX_FIBRE_DEVICES_2400;
                ha->mbx_count = MAILBOX_REGISTER_COUNT;
                req_length = REQUEST_ENTRY_CNT_82XX;
                rsp_length = RESPONSE_ENTRY_CNT_82XX;
                ha->nvram_conf_off = FARX_ACCESS_NVRAM_CONF;
                ha->nvram_data_off = FARX_ACCESS_NVRAM_DATA;
        } else if (IS_QLA83XX(ha)) {
+               ha->max_fibre_devices = MAX_FIBRE_DEVICES_2400;
                ha->mbx_count = MAILBOX_REGISTER_COUNT;
                req_length = REQUEST_ENTRY_CNT_24XX;
                rsp_length = RESPONSE_ENTRY_CNT_2300;
        ql_dbg_pci(ql_dbg_init, pdev, 0x001e,
            "mbx_count=%d, req_length=%d, "
            "rsp_length=%d, max_loop_id=%d, init_cb_size=%d, "
-           "gid_list_info_size=%d, optrom_size=%d, nvram_npiv_size=%d, .\n",
+           "gid_list_info_size=%d, optrom_size=%d, nvram_npiv_size=%d, "
+           "max_fibre_devices=%d.\n",
            ha->mbx_count, req_length, rsp_length, ha->max_loop_id,
            ha->init_cb_size, ha->gid_list_info_size, ha->optrom_size,
-           ha->nvram_npiv_size);
+           ha->nvram_npiv_size, ha->max_fibre_devices);
        ql_dbg_pci(ql_dbg_init, pdev, 0x001f,
            "isp_ops=%p, flash_conf_off=%d, "
            "flash_data_off=%d, nvram_conf_off=%d, nvram_data_off=%d.\n",
            "mgmt_svr_loop_id=%d, sg_tablesize=%d.\n",
            host->can_queue, base_vha->req,
            base_vha->mgmt_svr_loop_id, host->sg_tablesize);
-       host->max_id = max_id;
+       host->max_id = ha->max_fibre_devices;
        host->this_id = 255;
        host->cmd_per_lun = 3;
        host->unique_id = host->host_no;
        if (!ha->init_cb)
                goto fail;
 
-       ha->gid_list = dma_alloc_coherent(&ha->pdev->dev, GID_LIST_SIZE,
-               &ha->gid_list_dma, GFP_KERNEL);
+       ha->gid_list = dma_alloc_coherent(&ha->pdev->dev,
+               qla2x00_gid_list_size(ha), &ha->gid_list_dma, GFP_KERNEL);
        if (!ha->gid_list)
                goto fail_free_init_cb;
 
        mempool_destroy(ha->srb_mempool);
        ha->srb_mempool = NULL;
 fail_free_gid_list:
-       dma_free_coherent(&ha->pdev->dev, GID_LIST_SIZE, ha->gid_list,
+       dma_free_coherent(&ha->pdev->dev, qla2x00_gid_list_size(ha),
+       ha->gid_list,
        ha->gid_list_dma);
        ha->gid_list = NULL;
        ha->gid_list_dma = 0;
                dma_pool_destroy(ha->s_dma_pool);
 
        if (ha->gid_list)
-               dma_free_coherent(&ha->pdev->dev, GID_LIST_SIZE, ha->gid_list,
-               ha->gid_list_dma);
+               dma_free_coherent(&ha->pdev->dev, qla2x00_gid_list_size(ha),
+               ha->gid_list, ha->gid_list_dma);
 
        if (IS_QLA82XX(ha)) {
                if (!list_empty(&ha->gbl_dsd_list)) {