diff options
author | Vikas Chaudhary <vikas.chaudhary@qlogic.com> | 2012-01-19 06:06:55 -0500 |
---|---|---|
committer | James Bottomley <JBottomley@Parallels.com> | 2012-02-19 09:08:54 -0500 |
commit | aeddde2978f8931740032880134039fb937bb07c (patch) | |
tree | 8df6317dcd09ba6d13f24fe67c25ab9bcecf7dac | |
parent | 6c1b8789b0dd0ceeb04229f059dde08d84f28221 (diff) |
[SCSI] scsi_transport_iscsi: Added support to show port_state and port_speed in sysfs
sysfs patch to view port_state:
/sys/class/iscsi_host/host*/port_state
sysfs patch to view port_speed:
/sys/class/iscsi_host/host*/port_speed
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>
-rw-r--r-- | drivers/scsi/scsi_transport_iscsi.c | 63 | ||||
-rw-r--r-- | include/scsi/iscsi_if.h | 17 | ||||
-rw-r--r-- | include/scsi/scsi_transport_iscsi.h | 4 |
3 files changed, 84 insertions, 0 deletions
diff --git a/drivers/scsi/scsi_transport_iscsi.c b/drivers/scsi/scsi_transport_iscsi.c index cfd491437239..97832a2876bd 100644 --- a/drivers/scsi/scsi_transport_iscsi.c +++ b/drivers/scsi/scsi_transport_iscsi.c | |||
@@ -2476,12 +2476,16 @@ iscsi_host_attr(netdev, ISCSI_HOST_PARAM_NETDEV_NAME); | |||
2476 | iscsi_host_attr(hwaddress, ISCSI_HOST_PARAM_HWADDRESS); | 2476 | iscsi_host_attr(hwaddress, ISCSI_HOST_PARAM_HWADDRESS); |
2477 | iscsi_host_attr(ipaddress, ISCSI_HOST_PARAM_IPADDRESS); | 2477 | iscsi_host_attr(ipaddress, ISCSI_HOST_PARAM_IPADDRESS); |
2478 | iscsi_host_attr(initiatorname, ISCSI_HOST_PARAM_INITIATOR_NAME); | 2478 | iscsi_host_attr(initiatorname, ISCSI_HOST_PARAM_INITIATOR_NAME); |
2479 | iscsi_host_attr(port_state, ISCSI_HOST_PARAM_PORT_STATE); | ||
2480 | iscsi_host_attr(port_speed, ISCSI_HOST_PARAM_PORT_SPEED); | ||
2479 | 2481 | ||
2480 | static struct attribute *iscsi_host_attrs[] = { | 2482 | static struct attribute *iscsi_host_attrs[] = { |
2481 | &dev_attr_host_netdev.attr, | 2483 | &dev_attr_host_netdev.attr, |
2482 | &dev_attr_host_hwaddress.attr, | 2484 | &dev_attr_host_hwaddress.attr, |
2483 | &dev_attr_host_ipaddress.attr, | 2485 | &dev_attr_host_ipaddress.attr, |
2484 | &dev_attr_host_initiatorname.attr, | 2486 | &dev_attr_host_initiatorname.attr, |
2487 | &dev_attr_host_port_state.attr, | ||
2488 | &dev_attr_host_port_speed.attr, | ||
2485 | NULL, | 2489 | NULL, |
2486 | }; | 2490 | }; |
2487 | 2491 | ||
@@ -2501,6 +2505,10 @@ static umode_t iscsi_host_attr_is_visible(struct kobject *kobj, | |||
2501 | param = ISCSI_HOST_PARAM_IPADDRESS; | 2505 | param = ISCSI_HOST_PARAM_IPADDRESS; |
2502 | else if (attr == &dev_attr_host_initiatorname.attr) | 2506 | else if (attr == &dev_attr_host_initiatorname.attr) |
2503 | param = ISCSI_HOST_PARAM_INITIATOR_NAME; | 2507 | param = ISCSI_HOST_PARAM_INITIATOR_NAME; |
2508 | else if (attr == &dev_attr_host_port_state.attr) | ||
2509 | param = ISCSI_HOST_PARAM_PORT_STATE; | ||
2510 | else if (attr == &dev_attr_host_port_speed.attr) | ||
2511 | param = ISCSI_HOST_PARAM_PORT_SPEED; | ||
2504 | else { | 2512 | else { |
2505 | WARN_ONCE(1, "Invalid host attr"); | 2513 | WARN_ONCE(1, "Invalid host attr"); |
2506 | return 0; | 2514 | return 0; |
@@ -2514,6 +2522,61 @@ static struct attribute_group iscsi_host_group = { | |||
2514 | .is_visible = iscsi_host_attr_is_visible, | 2522 | .is_visible = iscsi_host_attr_is_visible, |
2515 | }; | 2523 | }; |
2516 | 2524 | ||
2525 | /* convert iscsi_port_speed values to ascii string name */ | ||
2526 | static const struct { | ||
2527 | enum iscsi_port_speed value; | ||
2528 | char *name; | ||
2529 | } iscsi_port_speed_names[] = { | ||
2530 | {ISCSI_PORT_SPEED_UNKNOWN, "Unknown" }, | ||
2531 | {ISCSI_PORT_SPEED_10MBPS, "10 Mbps" }, | ||
2532 | {ISCSI_PORT_SPEED_100MBPS, "100 Mbps" }, | ||
2533 | {ISCSI_PORT_SPEED_1GBPS, "1 Gbps" }, | ||
2534 | {ISCSI_PORT_SPEED_10GBPS, "10 Gbps" }, | ||
2535 | }; | ||
2536 | |||
2537 | char *iscsi_get_port_speed_name(struct Scsi_Host *shost) | ||
2538 | { | ||
2539 | int i; | ||
2540 | char *speed = "Unknown!"; | ||
2541 | struct iscsi_cls_host *ihost = shost->shost_data; | ||
2542 | uint32_t port_speed = ihost->port_speed; | ||
2543 | |||
2544 | for (i = 0; i < ARRAY_SIZE(iscsi_port_speed_names); i++) { | ||
2545 | if (iscsi_port_speed_names[i].value & port_speed) { | ||
2546 | speed = iscsi_port_speed_names[i].name; | ||
2547 | break; | ||
2548 | } | ||
2549 | } | ||
2550 | return speed; | ||
2551 | } | ||
2552 | EXPORT_SYMBOL_GPL(iscsi_get_port_speed_name); | ||
2553 | |||
2554 | /* convert iscsi_port_state values to ascii string name */ | ||
2555 | static const struct { | ||
2556 | enum iscsi_port_state value; | ||
2557 | char *name; | ||
2558 | } iscsi_port_state_names[] = { | ||
2559 | {ISCSI_PORT_STATE_DOWN, "LINK DOWN" }, | ||
2560 | {ISCSI_PORT_STATE_UP, "LINK UP" }, | ||
2561 | }; | ||
2562 | |||
2563 | char *iscsi_get_port_state_name(struct Scsi_Host *shost) | ||
2564 | { | ||
2565 | int i; | ||
2566 | char *state = "Unknown!"; | ||
2567 | struct iscsi_cls_host *ihost = shost->shost_data; | ||
2568 | uint32_t port_state = ihost->port_state; | ||
2569 | |||
2570 | for (i = 0; i < ARRAY_SIZE(iscsi_port_state_names); i++) { | ||
2571 | if (iscsi_port_state_names[i].value & port_state) { | ||
2572 | state = iscsi_port_state_names[i].name; | ||
2573 | break; | ||
2574 | } | ||
2575 | } | ||
2576 | return state; | ||
2577 | } | ||
2578 | EXPORT_SYMBOL_GPL(iscsi_get_port_state_name); | ||
2579 | |||
2517 | static int iscsi_session_match(struct attribute_container *cont, | 2580 | static int iscsi_session_match(struct attribute_container *cont, |
2518 | struct device *dev) | 2581 | struct device *dev) |
2519 | { | 2582 | { |
diff --git a/include/scsi/iscsi_if.h b/include/scsi/iscsi_if.h index 2703e3bedbf5..e49b7c8dd217 100644 --- a/include/scsi/iscsi_if.h +++ b/include/scsi/iscsi_if.h | |||
@@ -416,9 +416,26 @@ enum iscsi_host_param { | |||
416 | ISCSI_HOST_PARAM_INITIATOR_NAME, | 416 | ISCSI_HOST_PARAM_INITIATOR_NAME, |
417 | ISCSI_HOST_PARAM_NETDEV_NAME, | 417 | ISCSI_HOST_PARAM_NETDEV_NAME, |
418 | ISCSI_HOST_PARAM_IPADDRESS, | 418 | ISCSI_HOST_PARAM_IPADDRESS, |
419 | ISCSI_HOST_PARAM_PORT_STATE, | ||
420 | ISCSI_HOST_PARAM_PORT_SPEED, | ||
419 | ISCSI_HOST_PARAM_MAX, | 421 | ISCSI_HOST_PARAM_MAX, |
420 | }; | 422 | }; |
421 | 423 | ||
424 | /* iSCSI port Speed */ | ||
425 | enum iscsi_port_speed { | ||
426 | ISCSI_PORT_SPEED_UNKNOWN = 0x1, | ||
427 | ISCSI_PORT_SPEED_10MBPS = 0x2, | ||
428 | ISCSI_PORT_SPEED_100MBPS = 0x4, | ||
429 | ISCSI_PORT_SPEED_1GBPS = 0x8, | ||
430 | ISCSI_PORT_SPEED_10GBPS = 0x10, | ||
431 | }; | ||
432 | |||
433 | /* iSCSI port state */ | ||
434 | enum iscsi_port_state { | ||
435 | ISCSI_PORT_STATE_DOWN = 0x1, | ||
436 | ISCSI_PORT_STATE_UP = 0x2, | ||
437 | }; | ||
438 | |||
422 | #define iscsi_ptr(_handle) ((void*)(unsigned long)_handle) | 439 | #define iscsi_ptr(_handle) ((void*)(unsigned long)_handle) |
423 | #define iscsi_handle(_ptr) ((uint64_t)(unsigned long)_ptr) | 440 | #define iscsi_handle(_ptr) ((uint64_t)(unsigned long)_ptr) |
424 | 441 | ||
diff --git a/include/scsi/scsi_transport_iscsi.h b/include/scsi/scsi_transport_iscsi.h index 2c3a46d102fd..fa7ca4e16020 100644 --- a/include/scsi/scsi_transport_iscsi.h +++ b/include/scsi/scsi_transport_iscsi.h | |||
@@ -238,6 +238,8 @@ struct iscsi_cls_host { | |||
238 | atomic_t nr_scans; | 238 | atomic_t nr_scans; |
239 | struct mutex mutex; | 239 | struct mutex mutex; |
240 | struct request_queue *bsg_q; | 240 | struct request_queue *bsg_q; |
241 | uint32_t port_speed; | ||
242 | uint32_t port_state; | ||
241 | }; | 243 | }; |
242 | 244 | ||
243 | #define iscsi_job_to_shost(_job) \ | 245 | #define iscsi_job_to_shost(_job) \ |
@@ -307,5 +309,7 @@ extern struct iscsi_iface *iscsi_create_iface(struct Scsi_Host *shost, | |||
307 | uint32_t iface_num, int dd_size); | 309 | uint32_t iface_num, int dd_size); |
308 | extern void iscsi_destroy_iface(struct iscsi_iface *iface); | 310 | extern void iscsi_destroy_iface(struct iscsi_iface *iface); |
309 | extern struct iscsi_iface *iscsi_lookup_iface(int handle); | 311 | extern struct iscsi_iface *iscsi_lookup_iface(int handle); |
312 | extern char *iscsi_get_port_speed_name(struct Scsi_Host *shost); | ||
313 | extern char *iscsi_get_port_state_name(struct Scsi_Host *shost); | ||
310 | 314 | ||
311 | #endif | 315 | #endif |