aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/scsi/qla2xxx/qla_attr.c22
-rw-r--r--drivers/scsi/qla2xxx/qla_def.h4
-rw-r--r--drivers/scsi/qla2xxx/qla_isr.c4
-rw-r--r--drivers/scsi/qla2xxx/qla_os.c1
4 files changed, 29 insertions, 2 deletions
diff --git a/drivers/scsi/qla2xxx/qla_attr.c b/drivers/scsi/qla2xxx/qla_attr.c
index b17ee62dd1a9..e03140fec179 100644
--- a/drivers/scsi/qla2xxx/qla_attr.c
+++ b/drivers/scsi/qla2xxx/qla_attr.c
@@ -426,6 +426,26 @@ qla2x00_get_host_port_id(struct Scsi_Host *shost)
426} 426}
427 427
428static void 428static void
429qla2x00_get_host_speed(struct Scsi_Host *shost)
430{
431 scsi_qla_host_t *ha = to_qla_host(shost);
432 uint32_t speed = 0;
433
434 switch (ha->link_data_rate) {
435 case LDR_1GB:
436 speed = 1;
437 break;
438 case LDR_2GB:
439 speed = 2;
440 break;
441 case LDR_4GB:
442 speed = 4;
443 break;
444 }
445 fc_host_speed(shost) = speed;
446}
447
448static void
429qla2x00_get_starget_node_name(struct scsi_target *starget) 449qla2x00_get_starget_node_name(struct scsi_target *starget)
430{ 450{
431 struct Scsi_Host *host = dev_to_shost(starget->dev.parent); 451 struct Scsi_Host *host = dev_to_shost(starget->dev.parent);
@@ -520,6 +540,8 @@ struct fc_function_template qla2xxx_transport_functions = {
520 540
521 .get_host_port_id = qla2x00_get_host_port_id, 541 .get_host_port_id = qla2x00_get_host_port_id,
522 .show_host_port_id = 1, 542 .show_host_port_id = 1,
543 .get_host_speed = qla2x00_get_host_speed,
544 .show_host_speed = 1,
523 545
524 .dd_fcrport_size = sizeof(struct fc_port *), 546 .dd_fcrport_size = sizeof(struct fc_port *),
525 .show_rport_supported_classes = 1, 547 .show_rport_supported_classes = 1,
diff --git a/drivers/scsi/qla2xxx/qla_def.h b/drivers/scsi/qla2xxx/qla_def.h
index bad066e5772a..26af5319c219 100644
--- a/drivers/scsi/qla2xxx/qla_def.h
+++ b/drivers/scsi/qla2xxx/qla_def.h
@@ -2331,6 +2331,10 @@ typedef struct scsi_qla_host {
2331 uint16_t min_external_loopid; /* First external loop Id */ 2331 uint16_t min_external_loopid; /* First external loop Id */
2332 2332
2333 uint16_t link_data_rate; /* F/W operating speed */ 2333 uint16_t link_data_rate; /* F/W operating speed */
2334#define LDR_1GB 0
2335#define LDR_2GB 1
2336#define LDR_4GB 3
2337#define LDR_UNKNOWN 0xFFFF
2334 2338
2335 uint8_t current_topology; 2339 uint8_t current_topology;
2336 uint8_t prev_topology; 2340 uint8_t prev_topology;
diff --git a/drivers/scsi/qla2xxx/qla_isr.c b/drivers/scsi/qla2xxx/qla_isr.c
index 71a46fcee8cc..42aa7a7c1a73 100644
--- a/drivers/scsi/qla2xxx/qla_isr.c
+++ b/drivers/scsi/qla2xxx/qla_isr.c
@@ -402,9 +402,9 @@ qla2x00_async_event(scsi_qla_host_t *ha, uint16_t *mb)
402 break; 402 break;
403 403
404 case MBA_LOOP_UP: /* Loop Up Event */ 404 case MBA_LOOP_UP: /* Loop Up Event */
405 ha->link_data_rate = 0;
406 if (IS_QLA2100(ha) || IS_QLA2200(ha)) { 405 if (IS_QLA2100(ha) || IS_QLA2200(ha)) {
407 link_speed = link_speeds[0]; 406 link_speed = link_speeds[0];
407 ha->link_data_rate = LDR_1GB;
408 } else { 408 } else {
409 link_speed = link_speeds[LS_UNKNOWN]; 409 link_speed = link_speeds[LS_UNKNOWN];
410 if (mb[1] < 5) 410 if (mb[1] < 5)
@@ -436,7 +436,7 @@ qla2x00_async_event(scsi_qla_host_t *ha, uint16_t *mb)
436 } 436 }
437 437
438 ha->flags.management_server_logged_in = 0; 438 ha->flags.management_server_logged_in = 0;
439 ha->link_data_rate = 0; 439 ha->link_data_rate = LDR_UNKNOWN;
440 if (ql2xfdmienable) 440 if (ql2xfdmienable)
441 set_bit(REGISTER_FDMI_NEEDED, &ha->dpc_flags); 441 set_bit(REGISTER_FDMI_NEEDED, &ha->dpc_flags);
442 442
diff --git a/drivers/scsi/qla2xxx/qla_os.c b/drivers/scsi/qla2xxx/qla_os.c
index 5866a7c706a8..6e133edb2016 100644
--- a/drivers/scsi/qla2xxx/qla_os.c
+++ b/drivers/scsi/qla2xxx/qla_os.c
@@ -1312,6 +1312,7 @@ int qla2x00_probe_one(struct pci_dev *pdev, struct qla_board_info *brd_info)
1312 ha->ports = MAX_BUSES; 1312 ha->ports = MAX_BUSES;
1313 ha->init_cb_size = sizeof(init_cb_t); 1313 ha->init_cb_size = sizeof(init_cb_t);
1314 ha->mgmt_svr_loop_id = MANAGEMENT_SERVER; 1314 ha->mgmt_svr_loop_id = MANAGEMENT_SERVER;
1315 ha->link_data_rate = LDR_UNKNOWN;
1315 1316
1316 /* Assign ISP specific operations. */ 1317 /* Assign ISP specific operations. */
1317 ha->isp_ops.pci_config = qla2100_pci_config; 1318 ha->isp_ops.pci_config = qla2100_pci_config;