2 * Copyright (c) 2004, 2005 Topspin Communications. All rights reserved.
3 * Copyright (c) 2005 Mellanox Technologies Ltd. All rights reserved.
4 * Copyright (c) 2005 Sun Microsystems, Inc. All rights reserved.
6 * This software is available to you under a choice of one of two
7 * licenses. You may choose to be licensed under the terms of the GNU
8 * General Public License (GPL) Version 2, available from the file
9 * COPYING in the main directory of this source tree, or the
10 * OpenIB.org BSD license below:
12 * Redistribution and use in source and binary forms, with or
13 * without modification, are permitted provided that the following
16 * - Redistributions of source code must retain the above
17 * copyright notice, this list of conditions and the following
20 * - Redistributions in binary form must reproduce the above
21 * copyright notice, this list of conditions and the following
22 * disclaimer in the documentation and/or other materials
23 * provided with the distribution.
25 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
26 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
27 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
28 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
29 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
30 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
31 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
35 #include "core_priv.h"
37 #include <linux/slab.h>
38 #include <linux/stat.h>
39 #include <linux/string.h>
40 #include <linux/netdevice.h>
41 #include <linux/ethtool.h>
43 #include <rdma/ib_mad.h>
44 #include <rdma/ib_pma.h>
48 struct gid_attr_group
{
51 struct attribute_group ndev
;
52 struct attribute_group type
;
56 struct ib_device
*ibdev
;
57 struct gid_attr_group
*gid_attr_group
;
58 struct attribute_group gid_group
;
59 struct attribute_group pkey_group
;
60 struct attribute_group
*pma_table
;
61 struct attribute_group
*hw_stats_ag
;
62 struct rdma_hw_stats
*hw_stats
;
66 struct port_attribute
{
67 struct attribute attr
;
68 ssize_t (*show
)(struct ib_port
*, struct port_attribute
*, char *buf
);
69 ssize_t (*store
)(struct ib_port
*, struct port_attribute
*,
70 const char *buf
, size_t count
);
73 #define PORT_ATTR(_name, _mode, _show, _store) \
74 struct port_attribute port_attr_##_name = __ATTR(_name, _mode, _show, _store)
76 #define PORT_ATTR_RO(_name) \
77 struct port_attribute port_attr_##_name = __ATTR_RO(_name)
79 struct port_table_attribute
{
80 struct port_attribute attr
;
86 struct hw_stats_attribute
{
87 struct attribute attr
;
88 ssize_t (*show
)(struct kobject
*kobj
,
89 struct attribute
*attr
, char *buf
);
90 ssize_t (*store
)(struct kobject
*kobj
,
91 struct attribute
*attr
,
98 static ssize_t
port_attr_show(struct kobject
*kobj
,
99 struct attribute
*attr
, char *buf
)
101 struct port_attribute
*port_attr
=
102 container_of(attr
, struct port_attribute
, attr
);
103 struct ib_port
*p
= container_of(kobj
, struct ib_port
, kobj
);
105 if (!port_attr
->show
)
108 return port_attr
->show(p
, port_attr
, buf
);
111 static const struct sysfs_ops port_sysfs_ops
= {
112 .show
= port_attr_show
115 static ssize_t
gid_attr_show(struct kobject
*kobj
,
116 struct attribute
*attr
, char *buf
)
118 struct port_attribute
*port_attr
=
119 container_of(attr
, struct port_attribute
, attr
);
120 struct ib_port
*p
= container_of(kobj
, struct gid_attr_group
,
123 if (!port_attr
->show
)
126 return port_attr
->show(p
, port_attr
, buf
);
129 static const struct sysfs_ops gid_attr_sysfs_ops
= {
130 .show
= gid_attr_show
133 static ssize_t
state_show(struct ib_port
*p
, struct port_attribute
*unused
,
136 struct ib_port_attr attr
;
139 static const char *state_name
[] = {
140 [IB_PORT_NOP
] = "NOP",
141 [IB_PORT_DOWN
] = "DOWN",
142 [IB_PORT_INIT
] = "INIT",
143 [IB_PORT_ARMED
] = "ARMED",
144 [IB_PORT_ACTIVE
] = "ACTIVE",
145 [IB_PORT_ACTIVE_DEFER
] = "ACTIVE_DEFER"
148 ret
= ib_query_port(p
->ibdev
, p
->port_num
, &attr
);
152 return sprintf(buf
, "%d: %s\n", attr
.state
,
153 attr
.state
>= 0 && attr
.state
< ARRAY_SIZE(state_name
) ?
154 state_name
[attr
.state
] : "UNKNOWN");
157 static ssize_t
lid_show(struct ib_port
*p
, struct port_attribute
*unused
,
160 struct ib_port_attr attr
;
163 ret
= ib_query_port(p
->ibdev
, p
->port_num
, &attr
);
167 return sprintf(buf
, "0x%x\n", attr
.lid
);
170 static ssize_t
lid_mask_count_show(struct ib_port
*p
,
171 struct port_attribute
*unused
,
174 struct ib_port_attr attr
;
177 ret
= ib_query_port(p
->ibdev
, p
->port_num
, &attr
);
181 return sprintf(buf
, "%d\n", attr
.lmc
);
184 static ssize_t
sm_lid_show(struct ib_port
*p
, struct port_attribute
*unused
,
187 struct ib_port_attr attr
;
190 ret
= ib_query_port(p
->ibdev
, p
->port_num
, &attr
);
194 return sprintf(buf
, "0x%x\n", attr
.sm_lid
);
197 static ssize_t
sm_sl_show(struct ib_port
*p
, struct port_attribute
*unused
,
200 struct ib_port_attr attr
;
203 ret
= ib_query_port(p
->ibdev
, p
->port_num
, &attr
);
207 return sprintf(buf
, "%d\n", attr
.sm_sl
);
210 static ssize_t
cap_mask_show(struct ib_port
*p
, struct port_attribute
*unused
,
213 struct ib_port_attr attr
;
216 ret
= ib_query_port(p
->ibdev
, p
->port_num
, &attr
);
220 return sprintf(buf
, "0x%08x\n", attr
.port_cap_flags
);
223 static ssize_t
rate_show(struct ib_port
*p
, struct port_attribute
*unused
,
226 struct ib_port_attr attr
;
228 int rate
; /* in deci-Gb/sec */
231 ret
= ib_query_port(p
->ibdev
, p
->port_num
, &attr
);
235 switch (attr
.active_speed
) {
257 default: /* default to SDR for invalid rates */
262 rate
*= ib_width_enum_to_int(attr
.active_width
);
266 return sprintf(buf
, "%d%s Gb/sec (%dX%s)\n",
267 rate
/ 10, rate
% 10 ? ".5" : "",
268 ib_width_enum_to_int(attr
.active_width
), speed
);
271 static ssize_t
phys_state_show(struct ib_port
*p
, struct port_attribute
*unused
,
274 struct ib_port_attr attr
;
278 ret
= ib_query_port(p
->ibdev
, p
->port_num
, &attr
);
282 switch (attr
.phys_state
) {
283 case 1: return sprintf(buf
, "1: Sleep\n");
284 case 2: return sprintf(buf
, "2: Polling\n");
285 case 3: return sprintf(buf
, "3: Disabled\n");
286 case 4: return sprintf(buf
, "4: PortConfigurationTraining\n");
287 case 5: return sprintf(buf
, "5: LinkUp\n");
288 case 6: return sprintf(buf
, "6: LinkErrorRecovery\n");
289 case 7: return sprintf(buf
, "7: Phy Test\n");
290 default: return sprintf(buf
, "%d: <unknown>\n", attr
.phys_state
);
294 static ssize_t
link_layer_show(struct ib_port
*p
, struct port_attribute
*unused
,
297 switch (rdma_port_get_link_layer(p
->ibdev
, p
->port_num
)) {
298 case IB_LINK_LAYER_INFINIBAND
:
299 return sprintf(buf
, "%s\n", "InfiniBand");
300 case IB_LINK_LAYER_ETHERNET
:
301 return sprintf(buf
, "%s\n", "Ethernet");
303 return sprintf(buf
, "%s\n", "Unknown");
307 static PORT_ATTR_RO(state
);
308 static PORT_ATTR_RO(lid
);
309 static PORT_ATTR_RO(lid_mask_count
);
310 static PORT_ATTR_RO(sm_lid
);
311 static PORT_ATTR_RO(sm_sl
);
312 static PORT_ATTR_RO(cap_mask
);
313 static PORT_ATTR_RO(rate
);
314 static PORT_ATTR_RO(phys_state
);
315 static PORT_ATTR_RO(link_layer
);
317 static struct attribute
*port_default_attrs
[] = {
318 &port_attr_state
.attr
,
320 &port_attr_lid_mask_count
.attr
,
321 &port_attr_sm_lid
.attr
,
322 &port_attr_sm_sl
.attr
,
323 &port_attr_cap_mask
.attr
,
324 &port_attr_rate
.attr
,
325 &port_attr_phys_state
.attr
,
326 &port_attr_link_layer
.attr
,
330 static size_t print_ndev(struct ib_gid_attr
*gid_attr
, char *buf
)
335 return sprintf(buf
, "%s\n", gid_attr
->ndev
->name
);
338 static size_t print_gid_type(struct ib_gid_attr
*gid_attr
, char *buf
)
340 return sprintf(buf
, "%s\n", ib_cache_gid_type_str(gid_attr
->gid_type
));
343 static ssize_t
_show_port_gid_attr(struct ib_port
*p
,
344 struct port_attribute
*attr
,
346 size_t (*print
)(struct ib_gid_attr
*gid_attr
,
349 struct port_table_attribute
*tab_attr
=
350 container_of(attr
, struct port_table_attribute
, attr
);
352 struct ib_gid_attr gid_attr
= {};
355 ret
= ib_query_gid(p
->ibdev
, p
->port_num
, tab_attr
->index
, &gid
,
360 ret
= print(&gid_attr
, buf
);
364 dev_put(gid_attr
.ndev
);
368 static ssize_t
show_port_gid(struct ib_port
*p
, struct port_attribute
*attr
,
371 struct port_table_attribute
*tab_attr
=
372 container_of(attr
, struct port_table_attribute
, attr
);
376 ret
= ib_query_gid(p
->ibdev
, p
->port_num
, tab_attr
->index
, &gid
, NULL
);
380 return sprintf(buf
, "%pI6\n", gid
.raw
);
383 static ssize_t
show_port_gid_attr_ndev(struct ib_port
*p
,
384 struct port_attribute
*attr
, char *buf
)
386 return _show_port_gid_attr(p
, attr
, buf
, print_ndev
);
389 static ssize_t
show_port_gid_attr_gid_type(struct ib_port
*p
,
390 struct port_attribute
*attr
,
393 return _show_port_gid_attr(p
, attr
, buf
, print_gid_type
);
396 static ssize_t
show_port_pkey(struct ib_port
*p
, struct port_attribute
*attr
,
399 struct port_table_attribute
*tab_attr
=
400 container_of(attr
, struct port_table_attribute
, attr
);
404 ret
= ib_query_pkey(p
->ibdev
, p
->port_num
, tab_attr
->index
, &pkey
);
408 return sprintf(buf
, "0x%04x\n", pkey
);
411 #define PORT_PMA_ATTR(_name, _counter, _width, _offset) \
412 struct port_table_attribute port_pma_attr_##_name = { \
413 .attr = __ATTR(_name, S_IRUGO, show_pma_counter, NULL), \
414 .index = (_offset) | ((_width) << 16) | ((_counter) << 24), \
415 .attr_id = IB_PMA_PORT_COUNTERS , \
418 #define PORT_PMA_ATTR_EXT(_name, _width, _offset) \
419 struct port_table_attribute port_pma_attr_ext_##_name = { \
420 .attr = __ATTR(_name, S_IRUGO, show_pma_counter, NULL), \
421 .index = (_offset) | ((_width) << 16), \
422 .attr_id = IB_PMA_PORT_COUNTERS_EXT , \
426 * Get a Perfmgmt MAD block of data.
427 * Returns error code or the number of bytes retrieved.
429 static int get_perf_mad(struct ib_device
*dev
, int port_num
, __be16 attr
,
430 void *data
, int offset
, size_t size
)
432 struct ib_mad
*in_mad
;
433 struct ib_mad
*out_mad
;
434 size_t mad_size
= sizeof(*out_mad
);
435 u16 out_mad_pkey_index
= 0;
438 if (!dev
->process_mad
)
441 in_mad
= kzalloc(sizeof *in_mad
, GFP_KERNEL
);
442 out_mad
= kmalloc(sizeof *out_mad
, GFP_KERNEL
);
443 if (!in_mad
|| !out_mad
) {
448 in_mad
->mad_hdr
.base_version
= 1;
449 in_mad
->mad_hdr
.mgmt_class
= IB_MGMT_CLASS_PERF_MGMT
;
450 in_mad
->mad_hdr
.class_version
= 1;
451 in_mad
->mad_hdr
.method
= IB_MGMT_METHOD_GET
;
452 in_mad
->mad_hdr
.attr_id
= attr
;
454 if (attr
!= IB_PMA_CLASS_PORT_INFO
)
455 in_mad
->data
[41] = port_num
; /* PortSelect field */
457 if ((dev
->process_mad(dev
, IB_MAD_IGNORE_MKEY
,
458 port_num
, NULL
, NULL
,
459 (const struct ib_mad_hdr
*)in_mad
, mad_size
,
460 (struct ib_mad_hdr
*)out_mad
, &mad_size
,
461 &out_mad_pkey_index
) &
462 (IB_MAD_RESULT_SUCCESS
| IB_MAD_RESULT_REPLY
)) !=
463 (IB_MAD_RESULT_SUCCESS
| IB_MAD_RESULT_REPLY
)) {
467 memcpy(data
, out_mad
->data
+ offset
, size
);
475 static ssize_t
show_pma_counter(struct ib_port
*p
, struct port_attribute
*attr
,
478 struct port_table_attribute
*tab_attr
=
479 container_of(attr
, struct port_table_attribute
, attr
);
480 int offset
= tab_attr
->index
& 0xffff;
481 int width
= (tab_attr
->index
>> 16) & 0xff;
485 ret
= get_perf_mad(p
->ibdev
, p
->port_num
, tab_attr
->attr_id
, &data
,
486 40 + offset
/ 8, sizeof(data
));
488 return sprintf(buf
, "N/A (no PMA)\n");
492 ret
= sprintf(buf
, "%u\n", (*data
>>
493 (4 - (offset
% 8))) & 0xf);
496 ret
= sprintf(buf
, "%u\n", *data
);
499 ret
= sprintf(buf
, "%u\n",
500 be16_to_cpup((__be16
*)data
));
503 ret
= sprintf(buf
, "%u\n",
504 be32_to_cpup((__be32
*)data
));
507 ret
= sprintf(buf
, "%llu\n",
508 be64_to_cpup((__be64
*)data
));
518 static PORT_PMA_ATTR(symbol_error
, 0, 16, 32);
519 static PORT_PMA_ATTR(link_error_recovery
, 1, 8, 48);
520 static PORT_PMA_ATTR(link_downed
, 2, 8, 56);
521 static PORT_PMA_ATTR(port_rcv_errors
, 3, 16, 64);
522 static PORT_PMA_ATTR(port_rcv_remote_physical_errors
, 4, 16, 80);
523 static PORT_PMA_ATTR(port_rcv_switch_relay_errors
, 5, 16, 96);
524 static PORT_PMA_ATTR(port_xmit_discards
, 6, 16, 112);
525 static PORT_PMA_ATTR(port_xmit_constraint_errors
, 7, 8, 128);
526 static PORT_PMA_ATTR(port_rcv_constraint_errors
, 8, 8, 136);
527 static PORT_PMA_ATTR(local_link_integrity_errors
, 9, 4, 152);
528 static PORT_PMA_ATTR(excessive_buffer_overrun_errors
, 10, 4, 156);
529 static PORT_PMA_ATTR(VL15_dropped
, 11, 16, 176);
530 static PORT_PMA_ATTR(port_xmit_data
, 12, 32, 192);
531 static PORT_PMA_ATTR(port_rcv_data
, 13, 32, 224);
532 static PORT_PMA_ATTR(port_xmit_packets
, 14, 32, 256);
533 static PORT_PMA_ATTR(port_rcv_packets
, 15, 32, 288);
534 static PORT_PMA_ATTR(port_xmit_wait
, 0, 32, 320);
537 * Counters added by extended set
539 static PORT_PMA_ATTR_EXT(port_xmit_data
, 64, 64);
540 static PORT_PMA_ATTR_EXT(port_rcv_data
, 64, 128);
541 static PORT_PMA_ATTR_EXT(port_xmit_packets
, 64, 192);
542 static PORT_PMA_ATTR_EXT(port_rcv_packets
, 64, 256);
543 static PORT_PMA_ATTR_EXT(unicast_xmit_packets
, 64, 320);
544 static PORT_PMA_ATTR_EXT(unicast_rcv_packets
, 64, 384);
545 static PORT_PMA_ATTR_EXT(multicast_xmit_packets
, 64, 448);
546 static PORT_PMA_ATTR_EXT(multicast_rcv_packets
, 64, 512);
548 static struct attribute
*pma_attrs
[] = {
549 &port_pma_attr_symbol_error
.attr
.attr
,
550 &port_pma_attr_link_error_recovery
.attr
.attr
,
551 &port_pma_attr_link_downed
.attr
.attr
,
552 &port_pma_attr_port_rcv_errors
.attr
.attr
,
553 &port_pma_attr_port_rcv_remote_physical_errors
.attr
.attr
,
554 &port_pma_attr_port_rcv_switch_relay_errors
.attr
.attr
,
555 &port_pma_attr_port_xmit_discards
.attr
.attr
,
556 &port_pma_attr_port_xmit_constraint_errors
.attr
.attr
,
557 &port_pma_attr_port_rcv_constraint_errors
.attr
.attr
,
558 &port_pma_attr_local_link_integrity_errors
.attr
.attr
,
559 &port_pma_attr_excessive_buffer_overrun_errors
.attr
.attr
,
560 &port_pma_attr_VL15_dropped
.attr
.attr
,
561 &port_pma_attr_port_xmit_data
.attr
.attr
,
562 &port_pma_attr_port_rcv_data
.attr
.attr
,
563 &port_pma_attr_port_xmit_packets
.attr
.attr
,
564 &port_pma_attr_port_rcv_packets
.attr
.attr
,
565 &port_pma_attr_port_xmit_wait
.attr
.attr
,
569 static struct attribute
*pma_attrs_ext
[] = {
570 &port_pma_attr_symbol_error
.attr
.attr
,
571 &port_pma_attr_link_error_recovery
.attr
.attr
,
572 &port_pma_attr_link_downed
.attr
.attr
,
573 &port_pma_attr_port_rcv_errors
.attr
.attr
,
574 &port_pma_attr_port_rcv_remote_physical_errors
.attr
.attr
,
575 &port_pma_attr_port_rcv_switch_relay_errors
.attr
.attr
,
576 &port_pma_attr_port_xmit_discards
.attr
.attr
,
577 &port_pma_attr_port_xmit_constraint_errors
.attr
.attr
,
578 &port_pma_attr_port_rcv_constraint_errors
.attr
.attr
,
579 &port_pma_attr_local_link_integrity_errors
.attr
.attr
,
580 &port_pma_attr_excessive_buffer_overrun_errors
.attr
.attr
,
581 &port_pma_attr_VL15_dropped
.attr
.attr
,
582 &port_pma_attr_ext_port_xmit_data
.attr
.attr
,
583 &port_pma_attr_ext_port_rcv_data
.attr
.attr
,
584 &port_pma_attr_ext_port_xmit_packets
.attr
.attr
,
585 &port_pma_attr_port_xmit_wait
.attr
.attr
,
586 &port_pma_attr_ext_port_rcv_packets
.attr
.attr
,
587 &port_pma_attr_ext_unicast_rcv_packets
.attr
.attr
,
588 &port_pma_attr_ext_unicast_xmit_packets
.attr
.attr
,
589 &port_pma_attr_ext_multicast_rcv_packets
.attr
.attr
,
590 &port_pma_attr_ext_multicast_xmit_packets
.attr
.attr
,
594 static struct attribute
*pma_attrs_noietf
[] = {
595 &port_pma_attr_symbol_error
.attr
.attr
,
596 &port_pma_attr_link_error_recovery
.attr
.attr
,
597 &port_pma_attr_link_downed
.attr
.attr
,
598 &port_pma_attr_port_rcv_errors
.attr
.attr
,
599 &port_pma_attr_port_rcv_remote_physical_errors
.attr
.attr
,
600 &port_pma_attr_port_rcv_switch_relay_errors
.attr
.attr
,
601 &port_pma_attr_port_xmit_discards
.attr
.attr
,
602 &port_pma_attr_port_xmit_constraint_errors
.attr
.attr
,
603 &port_pma_attr_port_rcv_constraint_errors
.attr
.attr
,
604 &port_pma_attr_local_link_integrity_errors
.attr
.attr
,
605 &port_pma_attr_excessive_buffer_overrun_errors
.attr
.attr
,
606 &port_pma_attr_VL15_dropped
.attr
.attr
,
607 &port_pma_attr_ext_port_xmit_data
.attr
.attr
,
608 &port_pma_attr_ext_port_rcv_data
.attr
.attr
,
609 &port_pma_attr_ext_port_xmit_packets
.attr
.attr
,
610 &port_pma_attr_ext_port_rcv_packets
.attr
.attr
,
611 &port_pma_attr_port_xmit_wait
.attr
.attr
,
615 static struct attribute_group pma_group
= {
620 static struct attribute_group pma_group_ext
= {
622 .attrs
= pma_attrs_ext
625 static struct attribute_group pma_group_noietf
= {
627 .attrs
= pma_attrs_noietf
630 static void ib_port_release(struct kobject
*kobj
)
632 struct ib_port
*p
= container_of(kobj
, struct ib_port
, kobj
);
636 if (p
->gid_group
.attrs
) {
637 for (i
= 0; (a
= p
->gid_group
.attrs
[i
]); ++i
)
640 kfree(p
->gid_group
.attrs
);
643 if (p
->pkey_group
.attrs
) {
644 for (i
= 0; (a
= p
->pkey_group
.attrs
[i
]); ++i
)
647 kfree(p
->pkey_group
.attrs
);
653 static void ib_port_gid_attr_release(struct kobject
*kobj
)
655 struct gid_attr_group
*g
= container_of(kobj
, struct gid_attr_group
,
661 for (i
= 0; (a
= g
->ndev
.attrs
[i
]); ++i
)
664 kfree(g
->ndev
.attrs
);
668 for (i
= 0; (a
= g
->type
.attrs
[i
]); ++i
)
671 kfree(g
->type
.attrs
);
677 static struct kobj_type port_type
= {
678 .release
= ib_port_release
,
679 .sysfs_ops
= &port_sysfs_ops
,
680 .default_attrs
= port_default_attrs
683 static struct kobj_type gid_attr_type
= {
684 .sysfs_ops
= &gid_attr_sysfs_ops
,
685 .release
= ib_port_gid_attr_release
688 static struct attribute
**
689 alloc_group_attrs(ssize_t (*show
)(struct ib_port
*,
690 struct port_attribute
*, char *buf
),
693 struct attribute
**tab_attr
;
694 struct port_table_attribute
*element
;
697 tab_attr
= kcalloc(1 + len
, sizeof(struct attribute
*), GFP_KERNEL
);
701 for (i
= 0; i
< len
; i
++) {
702 element
= kzalloc(sizeof(struct port_table_attribute
),
707 if (snprintf(element
->name
, sizeof(element
->name
),
708 "%d", i
) >= sizeof(element
->name
)) {
713 element
->attr
.attr
.name
= element
->name
;
714 element
->attr
.attr
.mode
= S_IRUGO
;
715 element
->attr
.show
= show
;
717 sysfs_attr_init(&element
->attr
.attr
);
719 tab_attr
[i
] = &element
->attr
.attr
;
732 * Figure out which counter table to use depending on
733 * the device capabilities.
735 static struct attribute_group
*get_counter_table(struct ib_device
*dev
,
738 struct ib_class_port_info cpi
;
740 if (get_perf_mad(dev
, port_num
, IB_PMA_CLASS_PORT_INFO
,
741 &cpi
, 40, sizeof(cpi
)) >= 0) {
742 if (cpi
.capability_mask
& IB_PMA_CLASS_CAP_EXT_WIDTH
)
743 /* We have extended counters */
744 return &pma_group_ext
;
746 if (cpi
.capability_mask
& IB_PMA_CLASS_CAP_EXT_WIDTH_NOIETF
)
747 /* But not the IETF ones */
748 return &pma_group_noietf
;
751 /* Fall back to normal counters */
755 static int update_hw_stats(struct ib_device
*dev
, struct rdma_hw_stats
*stats
,
756 u8 port_num
, int index
)
760 if (time_is_after_eq_jiffies(stats
->timestamp
+ stats
->lifespan
))
762 ret
= dev
->get_hw_stats(dev
, stats
, port_num
, index
);
765 if (ret
== stats
->num_counters
)
766 stats
->timestamp
= jiffies
;
771 static ssize_t
print_hw_stat(struct rdma_hw_stats
*stats
, int index
, char *buf
)
773 return sprintf(buf
, "%llu\n", stats
->value
[index
]);
776 static ssize_t
show_hw_stats(struct kobject
*kobj
, struct attribute
*attr
,
779 struct ib_device
*dev
;
780 struct ib_port
*port
;
781 struct hw_stats_attribute
*hsa
;
782 struct rdma_hw_stats
*stats
;
785 hsa
= container_of(attr
, struct hw_stats_attribute
, attr
);
786 if (!hsa
->port_num
) {
787 dev
= container_of((struct device
*)kobj
,
788 struct ib_device
, dev
);
789 stats
= dev
->hw_stats
;
791 port
= container_of(kobj
, struct ib_port
, kobj
);
793 stats
= port
->hw_stats
;
795 ret
= update_hw_stats(dev
, stats
, hsa
->port_num
, hsa
->index
);
798 return print_hw_stat(stats
, hsa
->index
, buf
);
801 static ssize_t
show_stats_lifespan(struct kobject
*kobj
,
802 struct attribute
*attr
,
805 struct hw_stats_attribute
*hsa
;
808 hsa
= container_of(attr
, struct hw_stats_attribute
, attr
);
809 if (!hsa
->port_num
) {
810 struct ib_device
*dev
= container_of((struct device
*)kobj
,
811 struct ib_device
, dev
);
812 msecs
= jiffies_to_msecs(dev
->hw_stats
->lifespan
);
814 struct ib_port
*p
= container_of(kobj
, struct ib_port
, kobj
);
815 msecs
= jiffies_to_msecs(p
->hw_stats
->lifespan
);
817 return sprintf(buf
, "%d\n", msecs
);
820 static ssize_t
set_stats_lifespan(struct kobject
*kobj
,
821 struct attribute
*attr
,
822 const char *buf
, size_t count
)
824 struct hw_stats_attribute
*hsa
;
829 ret
= kstrtoint(buf
, 10, &msecs
);
832 if (msecs
< 0 || msecs
> 10000)
834 jiffies
= msecs_to_jiffies(msecs
);
835 hsa
= container_of(attr
, struct hw_stats_attribute
, attr
);
836 if (!hsa
->port_num
) {
837 struct ib_device
*dev
= container_of((struct device
*)kobj
,
838 struct ib_device
, dev
);
839 dev
->hw_stats
->lifespan
= jiffies
;
841 struct ib_port
*p
= container_of(kobj
, struct ib_port
, kobj
);
842 p
->hw_stats
->lifespan
= jiffies
;
847 static void free_hsag(struct kobject
*kobj
, struct attribute_group
*attr_group
)
849 struct attribute
**attr
;
851 sysfs_remove_group(kobj
, attr_group
);
853 for (attr
= attr_group
->attrs
; *attr
; attr
++)
858 static struct attribute
*alloc_hsa(int index
, u8 port_num
, const char *name
)
860 struct hw_stats_attribute
*hsa
;
862 hsa
= kmalloc(sizeof(*hsa
), GFP_KERNEL
);
866 hsa
->attr
.name
= (char *)name
;
867 hsa
->attr
.mode
= S_IRUGO
;
868 hsa
->show
= show_hw_stats
;
871 hsa
->port_num
= port_num
;
876 static struct attribute
*alloc_hsa_lifespan(char *name
, u8 port_num
)
878 struct hw_stats_attribute
*hsa
;
880 hsa
= kmalloc(sizeof(*hsa
), GFP_KERNEL
);
884 hsa
->attr
.name
= name
;
885 hsa
->attr
.mode
= S_IWUSR
| S_IRUGO
;
886 hsa
->show
= show_stats_lifespan
;
887 hsa
->store
= set_stats_lifespan
;
889 hsa
->port_num
= port_num
;
894 static void setup_hw_stats(struct ib_device
*device
, struct ib_port
*port
,
897 struct attribute_group
*hsag
;
898 struct rdma_hw_stats
*stats
;
901 stats
= device
->alloc_hw_stats(device
, port_num
);
906 if (!stats
->names
|| stats
->num_counters
<= 0)
910 * Two extra attribue elements here, one for the lifespan entry and
911 * one to NULL terminate the list for the sysfs core code
913 hsag
= kzalloc(sizeof(*hsag
) +
914 sizeof(void *) * (stats
->num_counters
+ 2),
919 ret
= device
->get_hw_stats(device
, stats
, port_num
,
920 stats
->num_counters
);
921 if (ret
!= stats
->num_counters
)
924 stats
->timestamp
= jiffies
;
926 hsag
->name
= "hw_counters";
927 hsag
->attrs
= (void *)hsag
+ sizeof(*hsag
);
929 for (i
= 0; i
< stats
->num_counters
; i
++) {
930 hsag
->attrs
[i
] = alloc_hsa(i
, port_num
, stats
->names
[i
]);
933 sysfs_attr_init(hsag
->attrs
[i
]);
936 /* treat an error here as non-fatal */
937 hsag
->attrs
[i
] = alloc_hsa_lifespan("lifespan", port_num
);
939 sysfs_attr_init(hsag
->attrs
[i
]);
942 struct kobject
*kobj
= &port
->kobj
;
943 ret
= sysfs_create_group(kobj
, hsag
);
946 port
->hw_stats_ag
= hsag
;
947 port
->hw_stats
= stats
;
949 struct kobject
*kobj
= &device
->dev
.kobj
;
950 ret
= sysfs_create_group(kobj
, hsag
);
953 device
->hw_stats_ag
= hsag
;
954 device
->hw_stats
= stats
;
961 kfree(hsag
->attrs
[i
]);
969 static int add_port(struct ib_device
*device
, int port_num
,
970 int (*port_callback
)(struct ib_device
*,
971 u8
, struct kobject
*))
974 struct ib_port_attr attr
;
978 ret
= ib_query_port(device
, port_num
, &attr
);
982 p
= kzalloc(sizeof *p
, GFP_KERNEL
);
987 p
->port_num
= port_num
;
989 ret
= kobject_init_and_add(&p
->kobj
, &port_type
,
990 device
->ports_parent
,
997 p
->gid_attr_group
= kzalloc(sizeof(*p
->gid_attr_group
), GFP_KERNEL
);
998 if (!p
->gid_attr_group
) {
1003 p
->gid_attr_group
->port
= p
;
1004 ret
= kobject_init_and_add(&p
->gid_attr_group
->kobj
, &gid_attr_type
,
1005 &p
->kobj
, "gid_attrs");
1007 kfree(p
->gid_attr_group
);
1011 p
->pma_table
= get_counter_table(device
, port_num
);
1012 ret
= sysfs_create_group(&p
->kobj
, p
->pma_table
);
1014 goto err_put_gid_attrs
;
1016 p
->gid_group
.name
= "gids";
1017 p
->gid_group
.attrs
= alloc_group_attrs(show_port_gid
, attr
.gid_tbl_len
);
1018 if (!p
->gid_group
.attrs
) {
1020 goto err_remove_pma
;
1023 ret
= sysfs_create_group(&p
->kobj
, &p
->gid_group
);
1027 p
->gid_attr_group
->ndev
.name
= "ndevs";
1028 p
->gid_attr_group
->ndev
.attrs
= alloc_group_attrs(show_port_gid_attr_ndev
,
1030 if (!p
->gid_attr_group
->ndev
.attrs
) {
1032 goto err_remove_gid
;
1035 ret
= sysfs_create_group(&p
->gid_attr_group
->kobj
,
1036 &p
->gid_attr_group
->ndev
);
1038 goto err_free_gid_ndev
;
1040 p
->gid_attr_group
->type
.name
= "types";
1041 p
->gid_attr_group
->type
.attrs
= alloc_group_attrs(show_port_gid_attr_gid_type
,
1043 if (!p
->gid_attr_group
->type
.attrs
) {
1045 goto err_remove_gid_ndev
;
1048 ret
= sysfs_create_group(&p
->gid_attr_group
->kobj
,
1049 &p
->gid_attr_group
->type
);
1051 goto err_free_gid_type
;
1053 p
->pkey_group
.name
= "pkeys";
1054 p
->pkey_group
.attrs
= alloc_group_attrs(show_port_pkey
,
1056 if (!p
->pkey_group
.attrs
) {
1058 goto err_remove_gid_type
;
1061 ret
= sysfs_create_group(&p
->kobj
, &p
->pkey_group
);
1065 if (port_callback
) {
1066 ret
= port_callback(device
, port_num
, &p
->kobj
);
1068 goto err_remove_pkey
;
1072 * If port == 0, it means we have only one port and the parent
1073 * device, not this port device, should be the holder of the
1076 if (device
->alloc_hw_stats
&& port_num
)
1077 setup_hw_stats(device
, p
, port_num
);
1079 list_add_tail(&p
->kobj
.entry
, &device
->port_list
);
1081 kobject_uevent(&p
->kobj
, KOBJ_ADD
);
1085 sysfs_remove_group(&p
->kobj
, &p
->pkey_group
);
1088 for (i
= 0; i
< attr
.pkey_tbl_len
; ++i
)
1089 kfree(p
->pkey_group
.attrs
[i
]);
1091 kfree(p
->pkey_group
.attrs
);
1092 p
->pkey_group
.attrs
= NULL
;
1094 err_remove_gid_type
:
1095 sysfs_remove_group(&p
->gid_attr_group
->kobj
,
1096 &p
->gid_attr_group
->type
);
1099 for (i
= 0; i
< attr
.gid_tbl_len
; ++i
)
1100 kfree(p
->gid_attr_group
->type
.attrs
[i
]);
1102 kfree(p
->gid_attr_group
->type
.attrs
);
1103 p
->gid_attr_group
->type
.attrs
= NULL
;
1105 err_remove_gid_ndev
:
1106 sysfs_remove_group(&p
->gid_attr_group
->kobj
,
1107 &p
->gid_attr_group
->ndev
);
1110 for (i
= 0; i
< attr
.gid_tbl_len
; ++i
)
1111 kfree(p
->gid_attr_group
->ndev
.attrs
[i
]);
1113 kfree(p
->gid_attr_group
->ndev
.attrs
);
1114 p
->gid_attr_group
->ndev
.attrs
= NULL
;
1117 sysfs_remove_group(&p
->kobj
, &p
->gid_group
);
1120 for (i
= 0; i
< attr
.gid_tbl_len
; ++i
)
1121 kfree(p
->gid_group
.attrs
[i
]);
1123 kfree(p
->gid_group
.attrs
);
1124 p
->gid_group
.attrs
= NULL
;
1127 sysfs_remove_group(&p
->kobj
, p
->pma_table
);
1130 kobject_put(&p
->gid_attr_group
->kobj
);
1133 kobject_put(&p
->kobj
);
1137 static ssize_t
show_node_type(struct device
*device
,
1138 struct device_attribute
*attr
, char *buf
)
1140 struct ib_device
*dev
= container_of(device
, struct ib_device
, dev
);
1142 switch (dev
->node_type
) {
1143 case RDMA_NODE_IB_CA
: return sprintf(buf
, "%d: CA\n", dev
->node_type
);
1144 case RDMA_NODE_RNIC
: return sprintf(buf
, "%d: RNIC\n", dev
->node_type
);
1145 case RDMA_NODE_USNIC
: return sprintf(buf
, "%d: usNIC\n", dev
->node_type
);
1146 case RDMA_NODE_USNIC_UDP
: return sprintf(buf
, "%d: usNIC UDP\n", dev
->node_type
);
1147 case RDMA_NODE_IB_SWITCH
: return sprintf(buf
, "%d: switch\n", dev
->node_type
);
1148 case RDMA_NODE_IB_ROUTER
: return sprintf(buf
, "%d: router\n", dev
->node_type
);
1149 default: return sprintf(buf
, "%d: <unknown>\n", dev
->node_type
);
1153 static ssize_t
show_sys_image_guid(struct device
*device
,
1154 struct device_attribute
*dev_attr
, char *buf
)
1156 struct ib_device
*dev
= container_of(device
, struct ib_device
, dev
);
1158 return sprintf(buf
, "%04x:%04x:%04x:%04x\n",
1159 be16_to_cpu(((__be16
*) &dev
->attrs
.sys_image_guid
)[0]),
1160 be16_to_cpu(((__be16
*) &dev
->attrs
.sys_image_guid
)[1]),
1161 be16_to_cpu(((__be16
*) &dev
->attrs
.sys_image_guid
)[2]),
1162 be16_to_cpu(((__be16
*) &dev
->attrs
.sys_image_guid
)[3]));
1165 static ssize_t
show_node_guid(struct device
*device
,
1166 struct device_attribute
*attr
, char *buf
)
1168 struct ib_device
*dev
= container_of(device
, struct ib_device
, dev
);
1170 return sprintf(buf
, "%04x:%04x:%04x:%04x\n",
1171 be16_to_cpu(((__be16
*) &dev
->node_guid
)[0]),
1172 be16_to_cpu(((__be16
*) &dev
->node_guid
)[1]),
1173 be16_to_cpu(((__be16
*) &dev
->node_guid
)[2]),
1174 be16_to_cpu(((__be16
*) &dev
->node_guid
)[3]));
1177 static ssize_t
show_node_desc(struct device
*device
,
1178 struct device_attribute
*attr
, char *buf
)
1180 struct ib_device
*dev
= container_of(device
, struct ib_device
, dev
);
1182 return sprintf(buf
, "%.64s\n", dev
->node_desc
);
1185 static ssize_t
set_node_desc(struct device
*device
,
1186 struct device_attribute
*attr
,
1187 const char *buf
, size_t count
)
1189 struct ib_device
*dev
= container_of(device
, struct ib_device
, dev
);
1190 struct ib_device_modify desc
= {};
1193 if (!dev
->modify_device
)
1196 memcpy(desc
.node_desc
, buf
, min_t(int, count
, IB_DEVICE_NODE_DESC_MAX
));
1197 ret
= ib_modify_device(dev
, IB_DEVICE_MODIFY_NODE_DESC
, &desc
);
1204 static ssize_t
show_fw_ver(struct device
*device
, struct device_attribute
*attr
,
1207 struct ib_device
*dev
= container_of(device
, struct ib_device
, dev
);
1209 ib_get_device_fw_str(dev
, buf
, PAGE_SIZE
);
1210 strlcat(buf
, "\n", PAGE_SIZE
);
1214 static DEVICE_ATTR(node_type
, S_IRUGO
, show_node_type
, NULL
);
1215 static DEVICE_ATTR(sys_image_guid
, S_IRUGO
, show_sys_image_guid
, NULL
);
1216 static DEVICE_ATTR(node_guid
, S_IRUGO
, show_node_guid
, NULL
);
1217 static DEVICE_ATTR(node_desc
, S_IRUGO
| S_IWUSR
, show_node_desc
, set_node_desc
);
1218 static DEVICE_ATTR(fw_ver
, S_IRUGO
, show_fw_ver
, NULL
);
1220 static struct device_attribute
*ib_class_attributes
[] = {
1221 &dev_attr_node_type
,
1222 &dev_attr_sys_image_guid
,
1223 &dev_attr_node_guid
,
1224 &dev_attr_node_desc
,
1228 static void free_port_list_attributes(struct ib_device
*device
)
1230 struct kobject
*p
, *t
;
1232 list_for_each_entry_safe(p
, t
, &device
->port_list
, entry
) {
1233 struct ib_port
*port
= container_of(p
, struct ib_port
, kobj
);
1234 list_del(&p
->entry
);
1235 if (port
->hw_stats
) {
1236 kfree(port
->hw_stats
);
1237 free_hsag(&port
->kobj
, port
->hw_stats_ag
);
1239 sysfs_remove_group(p
, port
->pma_table
);
1240 sysfs_remove_group(p
, &port
->pkey_group
);
1241 sysfs_remove_group(p
, &port
->gid_group
);
1242 sysfs_remove_group(&port
->gid_attr_group
->kobj
,
1243 &port
->gid_attr_group
->ndev
);
1244 sysfs_remove_group(&port
->gid_attr_group
->kobj
,
1245 &port
->gid_attr_group
->type
);
1246 kobject_put(&port
->gid_attr_group
->kobj
);
1250 kobject_put(device
->ports_parent
);
1253 int ib_device_register_sysfs(struct ib_device
*device
,
1254 int (*port_callback
)(struct ib_device
*,
1255 u8
, struct kobject
*))
1257 struct device
*class_dev
= &device
->dev
;
1261 device
->dev
.parent
= device
->dma_device
;
1262 ret
= dev_set_name(class_dev
, "%s", device
->name
);
1266 ret
= device_add(class_dev
);
1270 for (i
= 0; i
< ARRAY_SIZE(ib_class_attributes
); ++i
) {
1271 ret
= device_create_file(class_dev
, ib_class_attributes
[i
]);
1273 goto err_unregister
;
1276 device
->ports_parent
= kobject_create_and_add("ports",
1278 if (!device
->ports_parent
) {
1283 if (rdma_cap_ib_switch(device
)) {
1284 ret
= add_port(device
, 0, port_callback
);
1288 for (i
= 1; i
<= device
->phys_port_cnt
; ++i
) {
1289 ret
= add_port(device
, i
, port_callback
);
1295 if (device
->alloc_hw_stats
)
1296 setup_hw_stats(device
, NULL
, 0);
1301 free_port_list_attributes(device
);
1304 device_unregister(class_dev
);
1310 void ib_device_unregister_sysfs(struct ib_device
*device
)
1314 /* Hold kobject until ib_dealloc_device() */
1315 kobject_get(&device
->dev
.kobj
);
1317 free_port_list_attributes(device
);
1319 if (device
->hw_stats
) {
1320 kfree(device
->hw_stats
);
1321 free_hsag(&device
->dev
.kobj
, device
->hw_stats_ag
);
1324 for (i
= 0; i
< ARRAY_SIZE(ib_class_attributes
); ++i
)
1325 device_remove_file(&device
->dev
, ib_class_attributes
[i
]);
1327 device_unregister(&device
->dev
);