• Home
  • History
  • Annotate
  • Raw
  • Download
  • only in /netgear-WNDR4500v2-V1.0.0.60_1.0.38/src/linux/linux-2.6/drivers/scsi/qla2xxx/

Lines Matching refs:ha

24  * @ha: HA context
28 * Returns a pointer to the @ha's ms_iocb.
31 qla2x00_prep_ms_iocb(scsi_qla_host_t *ha, uint32_t req_size, uint32_t rsp_size)
35 ms_pkt = ha->ms_iocb;
40 SET_TARGET_ID(ha, ms_pkt->loop_id, SIMPLE_NAME_SERVER);
48 ms_pkt->dseg_req_address[0] = cpu_to_le32(LSD(ha->ct_sns_dma));
49 ms_pkt->dseg_req_address[1] = cpu_to_le32(MSD(ha->ct_sns_dma));
52 ms_pkt->dseg_rsp_address[0] = cpu_to_le32(LSD(ha->ct_sns_dma));
53 ms_pkt->dseg_rsp_address[1] = cpu_to_le32(MSD(ha->ct_sns_dma));
61 * @ha: HA context
65 * Returns a pointer to the @ha's ms_iocb.
68 qla24xx_prep_ms_iocb(scsi_qla_host_t *ha, uint32_t req_size, uint32_t rsp_size)
72 ct_pkt = (struct ct_entry_24xx *)ha->ms_iocb;
84 ct_pkt->dseg_0_address[0] = cpu_to_le32(LSD(ha->ct_sns_dma));
85 ct_pkt->dseg_0_address[1] = cpu_to_le32(MSD(ha->ct_sns_dma));
88 ct_pkt->dseg_1_address[0] = cpu_to_le32(LSD(ha->ct_sns_dma));
89 ct_pkt->dseg_1_address[1] = cpu_to_le32(MSD(ha->ct_sns_dma));
118 qla2x00_chk_ms_status(scsi_qla_host_t *ha, ms_iocb_entry_t *ms_pkt,
127 ha->host_no, routine, ms_pkt->entry_status));
129 if (IS_QLA24XX(ha) || IS_QLA54XX(ha))
141 "rejected request:\n", ha->host_no,
152 "status (%x).\n", ha->host_no, routine,
162 * @ha: HA context
168 qla2x00_ga_nxt(scsi_qla_host_t *ha, fc_port_t *fcport)
176 if (IS_QLA2100(ha) || IS_QLA2200(ha)) {
177 return (qla2x00_sns_ga_nxt(ha, fcport));
182 ms_pkt = ha->isp_ops.prep_ms_iocb(ha, GA_NXT_REQ_SIZE, GA_NXT_RSP_SIZE);
185 ct_req = qla2x00_prep_ct_req(&ha->ct_sns->p.req, GA_NXT_CMD,
187 ct_rsp = &ha->ct_sns->p.rsp;
195 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
200 ha->host_no, rval));
201 } else if (qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp, "GA_NXT") !=
223 ha->host_no,
241 * @ha: HA context
249 qla2x00_gid_pt(scsi_qla_host_t *ha, sw_info_t *list)
260 if (IS_QLA2100(ha) || IS_QLA2200(ha)) {
261 return (qla2x00_sns_gid_pt(ha, list));
268 ms_pkt = ha->isp_ops.prep_ms_iocb(ha, GID_PT_REQ_SIZE, GID_PT_RSP_SIZE);
271 ct_req = qla2x00_prep_ct_req(&ha->ct_sns->p.req, GID_PT_CMD,
273 ct_rsp = &ha->ct_sns->p.rsp;
279 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
284 ha->host_no, rval));
285 } else if (qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp, "GID_PT") !=
318 * @ha: HA context
324 qla2x00_gpn_id(scsi_qla_host_t *ha, sw_info_t *list)
333 if (IS_QLA2100(ha) || IS_QLA2200(ha)) {
334 return (qla2x00_sns_gpn_id(ha, list));
340 ms_pkt = ha->isp_ops.prep_ms_iocb(ha, GPN_ID_REQ_SIZE,
344 ct_req = qla2x00_prep_ct_req(&ha->ct_sns->p.req, GPN_ID_CMD,
346 ct_rsp = &ha->ct_sns->p.rsp;
354 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
359 "(%d).\n", ha->host_no, rval));
360 } else if (qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp,
379 * @ha: HA context
385 qla2x00_gnn_id(scsi_qla_host_t *ha, sw_info_t *list)
394 if (IS_QLA2100(ha) || IS_QLA2200(ha)) {
395 return (qla2x00_sns_gnn_id(ha, list));
401 ms_pkt = ha->isp_ops.prep_ms_iocb(ha, GNN_ID_REQ_SIZE,
405 ct_req = qla2x00_prep_ct_req(&ha->ct_sns->p.req, GNN_ID_CMD,
407 ct_rsp = &ha->ct_sns->p.rsp;
415 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
420 "(%d).\n", ha->host_no, rval));
421 } else if (qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp,
433 ha->host_no,
456 * @ha: HA context
461 qla2x00_rft_id(scsi_qla_host_t *ha)
469 if (IS_QLA2100(ha) || IS_QLA2200(ha)) {
470 return (qla2x00_sns_rft_id(ha));
475 ms_pkt = ha->isp_ops.prep_ms_iocb(ha, RFT_ID_REQ_SIZE, RFT_ID_RSP_SIZE);
478 ct_req = qla2x00_prep_ct_req(&ha->ct_sns->p.req, RFT_ID_CMD,
480 ct_rsp = &ha->ct_sns->p.rsp;
483 ct_req->req.rft_id.port_id[0] = ha->d_id.b.domain;
484 ct_req->req.rft_id.port_id[1] = ha->d_id.b.area;
485 ct_req->req.rft_id.port_id[2] = ha->d_id.b.al_pa;
490 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
495 ha->host_no, rval));
496 } else if (qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp, "RFT_ID") !=
501 ha->host_no));
509 * @ha: HA context
514 qla2x00_rff_id(scsi_qla_host_t *ha)
522 if (IS_QLA2100(ha) || IS_QLA2200(ha)) {
524 "ISP2100/ISP2200.\n", ha->host_no));
530 ms_pkt = ha->isp_ops.prep_ms_iocb(ha, RFF_ID_REQ_SIZE, RFF_ID_RSP_SIZE);
533 ct_req = qla2x00_prep_ct_req(&ha->ct_sns->p.req, RFF_ID_CMD,
535 ct_rsp = &ha->ct_sns->p.rsp;
538 ct_req->req.rff_id.port_id[0] = ha->d_id.b.domain;
539 ct_req->req.rff_id.port_id[1] = ha->d_id.b.area;
540 ct_req->req.rff_id.port_id[2] = ha->d_id.b.al_pa;
546 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
551 ha->host_no, rval));
552 } else if (qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp, "RFF_ID") !=
557 ha->host_no));
565 * @ha: HA context
570 qla2x00_rnn_id(scsi_qla_host_t *ha)
578 if (IS_QLA2100(ha) || IS_QLA2200(ha)) {
579 return (qla2x00_sns_rnn_id(ha));
584 ms_pkt = ha->isp_ops.prep_ms_iocb(ha, RNN_ID_REQ_SIZE, RNN_ID_RSP_SIZE);
587 ct_req = qla2x00_prep_ct_req(&ha->ct_sns->p.req, RNN_ID_CMD,
589 ct_rsp = &ha->ct_sns->p.rsp;
592 ct_req->req.rnn_id.port_id[0] = ha->d_id.b.domain;
593 ct_req->req.rnn_id.port_id[1] = ha->d_id.b.area;
594 ct_req->req.rnn_id.port_id[2] = ha->d_id.b.al_pa;
596 memcpy(ct_req->req.rnn_id.node_name, ha->node_name, WWN_SIZE);
599 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
604 ha->host_no, rval));
605 } else if (qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp, "RNN_ID") !=
610 ha->host_no));
617 qla2x00_get_sym_node_name(scsi_qla_host_t *ha, uint8_t *snn)
619 sprintf(snn, "%s FW:v%d.%02d.%02d DVR:v%s",ha->model_number,
620 ha->fw_major_version, ha->fw_minor_version,
621 ha->fw_subminor_version, qla2x00_version_str);
626 * @ha: HA context
631 qla2x00_rsnn_nn(scsi_qla_host_t *ha)
638 if (IS_QLA2100(ha) || IS_QLA2200(ha)) {
640 "ISP2100/ISP2200.\n", ha->host_no));
647 ms_pkt = ha->isp_ops.prep_ms_iocb(ha, 0, RSNN_NN_RSP_SIZE);
650 ct_req = qla2x00_prep_ct_req(&ha->ct_sns->p.req, RSNN_NN_CMD,
652 ct_rsp = &ha->ct_sns->p.rsp;
655 memcpy(ct_req->req.rsnn_nn.node_name, ha->node_name, WWN_SIZE);
658 qla2x00_get_sym_node_name(ha, ct_req->req.rsnn_nn.sym_node_name);
670 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
675 ha->host_no, rval));
676 } else if (qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp, "RSNN_NN") !=
681 ha->host_no));
689 * @ha: HA context
694 * Returns a pointer to the @ha's sns_cmd.
697 qla2x00_prep_sns_cmd(scsi_qla_host_t *ha, uint16_t cmd, uint16_t scmd_len,
703 sns_cmd = ha->sns_cmd;
707 sns_cmd->p.cmd.buffer_address[0] = cpu_to_le32(LSD(ha->sns_cmd_dma));
708 sns_cmd->p.cmd.buffer_address[1] = cpu_to_le32(MSD(ha->sns_cmd_dma));
719 * @ha: HA context
727 qla2x00_sns_ga_nxt(scsi_qla_host_t *ha, fc_port_t *fcport)
735 sns_cmd = qla2x00_prep_sns_cmd(ha, GA_NXT_CMD, GA_NXT_SNS_SCMD_LEN,
744 rval = qla2x00_send_sns(ha, ha->sns_cmd_dma, GA_NXT_SNS_CMD_SIZE / 2,
749 ha->host_no, rval));
753 "ga_nxt_rsp:\n", ha->host_no));
773 ha->host_no,
791 * @ha: HA context
801 qla2x00_sns_gid_pt(scsi_qla_host_t *ha, sw_info_t *list)
811 sns_cmd = qla2x00_prep_sns_cmd(ha, GID_PT_CMD, GID_PT_SNS_SCMD_LEN,
818 rval = qla2x00_send_sns(ha, ha->sns_cmd_dma, GID_PT_SNS_CMD_SIZE / 2,
823 ha->host_no, rval));
827 "gid_rsp:\n", ha->host_no));
860 * @ha: HA context
868 qla2x00_sns_gpn_id(scsi_qla_host_t *ha, sw_info_t *list)
878 sns_cmd = qla2x00_prep_sns_cmd(ha, GPN_ID_CMD,
887 rval = qla2x00_send_sns(ha, ha->sns_cmd_dma,
892 "(%d).\n", ha->host_no, rval));
896 "request, gpn_rsp:\n", ha->host_no));
915 * @ha: HA context
923 qla2x00_sns_gnn_id(scsi_qla_host_t *ha, sw_info_t *list)
933 sns_cmd = qla2x00_prep_sns_cmd(ha, GNN_ID_CMD,
942 rval = qla2x00_send_sns(ha, ha->sns_cmd_dma,
947 "(%d).\n", ha->host_no, rval));
951 "request, gnn_rsp:\n", ha->host_no));
963 ha->host_no,
986 * @ha: HA context
993 qla2x00_sns_rft_id(scsi_qla_host_t *ha)
1001 sns_cmd = qla2x00_prep_sns_cmd(ha, RFT_ID_CMD, RFT_ID_SNS_SCMD_LEN,
1005 sns_cmd->p.cmd.param[0] = ha->d_id.b.al_pa;
1006 sns_cmd->p.cmd.param[1] = ha->d_id.b.area;
1007 sns_cmd->p.cmd.param[2] = ha->d_id.b.domain;
1012 rval = qla2x00_send_sns(ha, ha->sns_cmd_dma, RFT_ID_SNS_CMD_SIZE / 2,
1017 ha->host_no, rval));
1021 "rft_rsp:\n", ha->host_no));
1026 ha->host_no));
1035 * @ha: HA context
1042 qla2x00_sns_rnn_id(scsi_qla_host_t *ha)
1050 sns_cmd = qla2x00_prep_sns_cmd(ha, RNN_ID_CMD, RNN_ID_SNS_SCMD_LEN,
1054 sns_cmd->p.cmd.param[0] = ha->d_id.b.al_pa;
1055 sns_cmd->p.cmd.param[1] = ha->d_id.b.area;
1056 sns_cmd->p.cmd.param[2] = ha->d_id.b.domain;
1058 sns_cmd->p.cmd.param[4] = ha->node_name[7];
1059 sns_cmd->p.cmd.param[5] = ha->node_name[6];
1060 sns_cmd->p.cmd.param[6] = ha->node_name[5];
1061 sns_cmd->p.cmd.param[7] = ha->node_name[4];
1062 sns_cmd->p.cmd.param[8] = ha->node_name[3];
1063 sns_cmd->p.cmd.param[9] = ha->node_name[2];
1064 sns_cmd->p.cmd.param[10] = ha->node_name[1];
1065 sns_cmd->p.cmd.param[11] = ha->node_name[0];
1068 rval = qla2x00_send_sns(ha, ha->sns_cmd_dma, RNN_ID_SNS_CMD_SIZE / 2,
1073 ha->host_no, rval));
1077 "rnn_rsp:\n", ha->host_no));
1082 ha->host_no));
1090 * @ha: HA context
1095 qla2x00_mgmt_svr_login(scsi_qla_host_t *ha)
1101 if (ha->flags.management_server_logged_in)
1104 ha->isp_ops.fabric_login(ha, ha->mgmt_svr_loop_id, 0xff, 0xff, 0xfa,
1109 __func__, ha->host_no, ha->mgmt_svr_loop_id, mb[0], mb[1],
1113 ha->flags.management_server_logged_in = 1;
1120 * @ha: HA context
1124 * Returns a pointer to the @ha's ms_iocb.
1127 qla2x00_prep_ms_fdmi_iocb(scsi_qla_host_t *ha, uint32_t req_size,
1132 ms_pkt = ha->ms_iocb;
1137 SET_TARGET_ID(ha, ms_pkt->loop_id, ha->mgmt_svr_loop_id);
1145 ms_pkt->dseg_req_address[0] = cpu_to_le32(LSD(ha->ct_sns_dma));
1146 ms_pkt->dseg_req_address[1] = cpu_to_le32(MSD(ha->ct_sns_dma));
1149 ms_pkt->dseg_rsp_address[0] = cpu_to_le32(LSD(ha->ct_sns_dma));
1150 ms_pkt->dseg_rsp_address[1] = cpu_to_le32(MSD(ha->ct_sns_dma));
1158 * @ha: HA context
1162 * Returns a pointer to the @ha's ms_iocb.
1165 qla24xx_prep_ms_fdmi_iocb(scsi_qla_host_t *ha, uint32_t req_size,
1170 ct_pkt = (struct ct_entry_24xx *)ha->ms_iocb;
1175 ct_pkt->nport_handle = cpu_to_le16(ha->mgmt_svr_loop_id);
1182 ct_pkt->dseg_0_address[0] = cpu_to_le32(LSD(ha->ct_sns_dma));
1183 ct_pkt->dseg_0_address[1] = cpu_to_le32(MSD(ha->ct_sns_dma));
1186 ct_pkt->dseg_1_address[0] = cpu_to_le32(LSD(ha->ct_sns_dma));
1187 ct_pkt->dseg_1_address[1] = cpu_to_le32(MSD(ha->ct_sns_dma));
1194 qla2x00_update_ms_fdmi_iocb(scsi_qla_host_t *ha, uint32_t req_size)
1196 ms_iocb_entry_t *ms_pkt = ha->ms_iocb;
1197 struct ct_entry_24xx *ct_pkt = (struct ct_entry_24xx *)ha->ms_iocb;
1199 if (IS_QLA24XX(ha) || IS_QLA54XX(ha)) {
1235 * @ha: HA context
1240 qla2x00_fdmi_rhba(scsi_qla_host_t *ha)
1254 ms_pkt = ha->isp_ops.prep_ms_fdmi_iocb(ha, 0, RHBA_RSP_SIZE);
1257 ct_req = qla2x00_prep_ct_fdmi_req(&ha->ct_sns->p.req, RHBA_CMD,
1259 ct_rsp = &ha->ct_sns->p.rsp;
1262 memcpy(ct_req->req.rhba.hba_identifier, ha->port_name, WWN_SIZE);
1264 memcpy(ct_req->req.rhba.port_name, ha->port_name, WWN_SIZE);
1276 memcpy(eiter->a.node_name, ha->node_name, WWN_SIZE);
1280 __func__, ha->host_no,
1294 DEBUG13(printk("%s(%ld): MANUFACTURER=%s.\n", __func__, ha->host_no,
1300 sn = ((ha->serial0 & 0x1f) << 16) | (ha->serial2 << 8) | ha->serial1;
1307 DEBUG13(printk("%s(%ld): SERIALNO=%s.\n", __func__, ha->host_no,
1313 strcpy(eiter->a.model, ha->model_number);
1319 DEBUG13(printk("%s(%ld): MODEL_NAME=%s.\n", __func__, ha->host_no,
1325 if (ha->model_desc)
1326 strncpy(eiter->a.model_desc, ha->model_desc, 80);
1332 DEBUG13(printk("%s(%ld): MODEL_DESC=%s.\n", __func__, ha->host_no,
1338 strcpy(eiter->a.hw_version, ha->adapter_id);
1344 DEBUG13(printk("%s(%ld): HARDWAREVER=%s.\n", __func__, ha->host_no,
1356 DEBUG13(printk("%s(%ld): DRIVERVER=%s.\n", __func__, ha->host_no,
1368 DEBUG13(printk("%s(%ld): OPTROMVER=%s.\n", __func__, ha->host_no,
1374 ha->isp_ops.fw_version_str(ha, eiter->a.fw_version);
1380 DEBUG13(printk("%s(%ld): FIRMWAREVER=%s.\n", __func__, ha->host_no,
1384 qla2x00_update_ms_fdmi_iocb(ha, size + 16);
1388 ha->host_no, ct_req->req.rhba.hba_identifier[0],
1399 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
1404 ha->host_no, rval));
1405 } else if (qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp, "RHBA") !=
1412 __func__, ha->host_no));
1417 ha->host_no));
1425 * @ha: HA context
1430 qla2x00_fdmi_dhba(scsi_qla_host_t *ha)
1440 ms_pkt = ha->isp_ops.prep_ms_fdmi_iocb(ha, DHBA_REQ_SIZE,
1444 ct_req = qla2x00_prep_ct_fdmi_req(&ha->ct_sns->p.req, DHBA_CMD,
1446 ct_rsp = &ha->ct_sns->p.rsp;
1449 memcpy(ct_req->req.dhba.port_name, ha->port_name, WWN_SIZE);
1452 "%02x%02x%02x%02x%02x%02x%02x%02x.\n", __func__, ha->host_no,
1459 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
1464 ha->host_no, rval));
1465 } else if (qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp, "DHBA") !=
1470 ha->host_no));
1478 * @ha: HA context
1483 qla2x00_fdmi_rpa(scsi_qla_host_t *ha)
1493 struct init_cb_24xx *icb24 = (struct init_cb_24xx *)ha->init_cb;
1498 ms_pkt = ha->isp_ops.prep_ms_fdmi_iocb(ha, 0, RPA_RSP_SIZE);
1501 ct_req = qla2x00_prep_ct_fdmi_req(&ha->ct_sns->p.req, RPA_CMD,
1503 ct_rsp = &ha->ct_sns->p.rsp;
1506 memcpy(ct_req->req.rpa.port_name, ha->port_name, WWN_SIZE);
1521 DEBUG13(printk("%s(%ld): FC4_TYPES=%02x %02x.\n", __func__, ha->host_no,
1528 if (IS_QLA24XX(ha) || IS_QLA54XX(ha))
1530 else if (IS_QLA23XX(ha))
1536 DEBUG13(printk("%s(%ld): SUPPORTED_SPEED=%x.\n", __func__, ha->host_no,
1543 switch (ha->link_data_rate) {
1556 DEBUG13(printk("%s(%ld): CURRENT_SPEED=%x.\n", __func__, ha->host_no,
1563 max_frame_size = IS_QLA24XX(ha) || IS_QLA54XX(ha) ?
1565 (uint32_t) ha->init_cb->frame_payload_size;
1569 DEBUG13(printk("%s(%ld): MAX_FRAME_SIZE=%x.\n", __func__, ha->host_no,
1575 sprintf(eiter->a.os_dev_name, "/proc/scsi/qla2xxx/%ld", ha->host_no);
1581 DEBUG13(printk("%s(%ld): OS_DEVICE_NAME=%s.\n", __func__, ha->host_no,
1585 if (strlen(fc_host_system_hostname(ha->host))) {
1589 "%s", fc_host_system_hostname(ha->host));
1596 ha->host_no, eiter->a.host_name));
1600 qla2x00_update_ms_fdmi_iocb(ha, size + 16);
1604 ha->host_no, ct_req->req.rpa.port_name[0],
1612 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
1617 ha->host_no, rval));
1618 } else if (qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp, "RPA") !=
1623 ha->host_no));
1631 * @ha: HA context
1636 qla2x00_fdmi_register(scsi_qla_host_t *ha)
1640 rval = qla2x00_mgmt_svr_login(ha);
1644 rval = qla2x00_fdmi_rhba(ha);
1649 rval = qla2x00_fdmi_dhba(ha);
1653 rval = qla2x00_fdmi_rhba(ha);
1657 rval = qla2x00_fdmi_rpa(ha);
1664 * @ha: HA context
1670 qla2x00_gfpn_id(scsi_qla_host_t *ha, sw_info_t *list)
1679 if (!IS_QLA24XX(ha) && !IS_QLA54XX(ha))
1687 ms_pkt = ha->isp_ops.prep_ms_iocb(ha, GFPN_ID_REQ_SIZE,
1691 ct_req = qla2x00_prep_ct_req(&ha->ct_sns->p.req, GFPN_ID_CMD,
1693 ct_rsp = &ha->ct_sns->p.rsp;
1701 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
1706 "failed (%d).\n", ha->host_no, rval));
1707 } else if (qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp,
1725 qla24xx_prep_ms_fm_iocb(scsi_qla_host_t *ha, uint32_t req_size,
1730 ct_pkt = (struct ct_entry_24xx *)ha->ms_iocb;
1735 ct_pkt->nport_handle = cpu_to_le16(ha->mgmt_svr_loop_id);
1742 ct_pkt->dseg_0_address[0] = cpu_to_le32(LSD(ha->ct_sns_dma));
1743 ct_pkt->dseg_0_address[1] = cpu_to_le32(MSD(ha->ct_sns_dma));
1746 ct_pkt->dseg_1_address[0] = cpu_to_le32(LSD(ha->ct_sns_dma));
1747 ct_pkt->dseg_1_address[1] = cpu_to_le32(MSD(ha->ct_sns_dma));
1771 * @ha: HA context
1777 qla2x00_gpsc(scsi_qla_host_t *ha, sw_info_t *list)
1786 if (!IS_QLA24XX(ha) && !IS_QLA54XX(ha))
1788 if (!ha->flags.gpsc_supported)
1791 rval = qla2x00_mgmt_svr_login(ha);
1800 ms_pkt = qla24xx_prep_ms_fm_iocb(ha, GPSC_REQ_SIZE,
1804 ct_req = qla24xx_prep_ct_fm_req(&ha->ct_sns->p.req,
1806 ct_rsp = &ha->ct_sns->p.rsp;
1813 rval = qla2x00_issue_iocb(ha, ha->ms_iocb, ha->ms_iocb_dma,
1818 "failed (%d).\n", ha->host_no, rval));
1819 } else if ((rval = qla2x00_chk_ms_status(ha, ms_pkt, ct_rsp,
1827 ha->host_no));
1828 ha->flags.gpsc_supported = 0;
1840 "speed=%04x.\n", ha->host_no,