xref: /freebsd/contrib/ofed/libibmad/mad.h (revision d6b92ffa)
1 /*
2  * Copyright (c) 2004-2009 Voltaire Inc.  All rights reserved.
3  * Copyright (c) 2009 HNR Consulting.  All rights reserved.
4  * Copyright (c) 2009-2011 Mellanox Technologies LTD.  All rights reserved.
5  *
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:
11  *
12  *     Redistribution and use in source and binary forms, with or
13  *     without modification, are permitted provided that the following
14  *     conditions are met:
15  *
16  *      - Redistributions of source code must retain the above
17  *        copyright notice, this list of conditions and the following
18  *        disclaimer.
19  *
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.
24  *
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
32  * SOFTWARE.
33  *
34  */
35 #ifndef _MAD_H_
36 #define _MAD_H_
37 
38 #include <infiniband/mad_osd.h>
39 
40 #ifdef __cplusplus
41 #  define BEGIN_C_DECLS extern "C" {
42 #  define END_C_DECLS   }
43 #else				/* !__cplusplus */
44 #  define BEGIN_C_DECLS
45 #  define END_C_DECLS
46 #endif				/* __cplusplus */
47 
48 BEGIN_C_DECLS
49 #define IB_MAD_RPC_VERSION_MASK	0x0f00
50 #define IB_MAD_RPC_VERSION1	(1<<8)
51 
52 #define IB_SUBNET_PATH_HOPS_MAX	64
53 #define IB_DEFAULT_SUBN_PREFIX	0xfe80000000000000ULL
54 #define IB_DEFAULT_QP1_QKEY	0x80010000
55 #define IB_MAD_SIZE		256
56 #define IB_SMP_DATA_OFFS	64
57 #define IB_SMP_DATA_SIZE	64
58 #define IB_VENDOR_RANGE1_DATA_OFFS	24
59 #define IB_VENDOR_RANGE1_DATA_SIZE	(IB_MAD_SIZE - IB_VENDOR_RANGE1_DATA_OFFS)
60 #define IB_VENDOR_RANGE2_DATA_OFFS	40
61 #define IB_VENDOR_RANGE2_DATA_SIZE	(IB_MAD_SIZE - IB_VENDOR_RANGE2_DATA_OFFS)
62 #define IB_SA_DATA_SIZE		200
63 #define IB_SA_DATA_OFFS		56
64 #define IB_PC_DATA_OFFS		64
65 #define IB_PC_DATA_SZ		(IB_MAD_SIZE - IB_PC_DATA_OFFS)
66 #define IB_SA_MCM_RECSZ		53
67 #define IB_SA_PR_RECSZ		64
68 #define IB_SA_NR_RECSZ		108
69 #define IB_SA_GIR_RECSZ		72
70 #define IB_BM_DATA_OFFS		64
71 #define IB_BM_DATA_SZ		(IB_MAD_SIZE - IB_BM_DATA_OFFS)
72 #define IB_BM_BKEY_OFFS		24
73 #define IB_BM_BKEY_AND_DATA_SZ	(IB_MAD_SIZE - IB_BM_BKEY_OFFS)
74 #define IB_CC_DATA_OFFS         64
75 #define IB_CC_DATA_SZ           (IB_MAD_SIZE - IB_CC_DATA_OFFS)
76 #define IB_CC_LOG_DATA_OFFS     32
77 #define IB_CC_LOG_DATA_SZ       (IB_MAD_SIZE - IB_CC_LOG_DATA_OFFS)
78 
79 enum MAD_CLASSES {
80 	IB_SMI_CLASS = 0x1,
81 	IB_SMI_DIRECT_CLASS = 0x81,
82 	IB_SA_CLASS = 0x3,
83 	IB_PERFORMANCE_CLASS = 0x4,
84 	IB_BOARD_MGMT_CLASS = 0x5,
85 	IB_DEVICE_MGMT_CLASS = 0x6,
86 	IB_CM_CLASS = 0x7,
87 	IB_SNMP_CLASS = 0x8,
88 	IB_VENDOR_RANGE1_START_CLASS = 0x9,
89 	IB_VENDOR_RANGE1_END_CLASS = 0x0f,
90 	IB_CC_CLASS = 0x21,
91 	IB_VENDOR_RANGE2_START_CLASS = 0x30,
92 	IB_VENDOR_RANGE2_END_CLASS = 0x4f,
93 };
94 
95 enum MAD_METHODS {
96 	IB_MAD_METHOD_GET = 0x1,
97 	IB_MAD_METHOD_SET = 0x2,
98 	IB_MAD_METHOD_GET_RESPONSE = 0x81,
99 
100 	IB_MAD_METHOD_SEND = 0x3,
101 	IB_MAD_METHOD_TRAP = 0x5,
102 	IB_MAD_METHOD_TRAP_REPRESS = 0x7,
103 
104 	IB_MAD_METHOD_REPORT = 0x6,
105 	IB_MAD_METHOD_REPORT_RESPONSE = 0x86,
106 	IB_MAD_METHOD_GET_TABLE = 0x12,
107 	IB_MAD_METHOD_GET_TABLE_RESPONSE = 0x92,
108 	IB_MAD_METHOD_GET_TRACE_TABLE = 0x13,
109 	IB_MAD_METHOD_GET_TRACE_TABLE_RESPONSE = 0x93,
110 	IB_MAD_METHOD_GETMULTI = 0x14,
111 	IB_MAD_METHOD_GETMULTI_RESPONSE = 0x94,
112 	IB_MAD_METHOD_DELETE = 0x15,
113 	IB_MAD_METHOD_DELETE_RESPONSE = 0x95,
114 
115 	IB_MAD_RESPONSE = 0x80,
116 };
117 
118 enum MAD_ATTR_ID {
119 	CLASS_PORT_INFO = 0x1,
120 	NOTICE = 0x2,
121 	INFORM_INFO = 0x3,
122 };
123 
124 enum MAD_STATUS {
125 	IB_MAD_STS_OK = (0 << 2),
126 	IB_MAD_STS_BUSY = (1 << 0),
127 	IB_MAD_STS_REDIRECT = (1 << 1),
128 	IB_MAD_STS_BAD_BASE_VER_OR_CLASS = (1 << 2),
129 	IB_MAD_STS_METHOD_NOT_SUPPORTED = (2 << 2),
130 	IB_MAD_STS_METHOD_ATTR_NOT_SUPPORTED = (3 << 2),
131 	IB_MAD_STS_INV_ATTR_VALUE = (7 << 2),
132 };
133 
134 enum SMI_ATTR_ID {
135 	IB_ATTR_NODE_DESC = 0x10,
136 	IB_ATTR_NODE_INFO = 0x11,
137 	IB_ATTR_SWITCH_INFO = 0x12,
138 	IB_ATTR_GUID_INFO = 0x14,
139 	IB_ATTR_PORT_INFO = 0x15,
140 	IB_ATTR_PKEY_TBL = 0x16,
141 	IB_ATTR_SLVL_TABLE = 0x17,
142 	IB_ATTR_VL_ARBITRATION = 0x18,
143 	IB_ATTR_LINEARFORWTBL = 0x19,
144 	IB_ATTR_MULTICASTFORWTBL = 0x1b,
145 	IB_ATTR_LINKSPEEDWIDTHPAIRSTBL = 0x1c,
146 	IB_ATTR_VENDORMADSTBL = 0x1d,
147 	IB_ATTR_SMINFO = 0x20,
148 	IB_ATTR_PORT_INFO_EXT = 0x33,
149 	IB_ATTR_LAST,
150 
151 	IB_ATTR_MLNX_EXT_PORT_INFO = 0xff90,
152 };
153 
154 enum SA_ATTR_ID {
155 	IB_SA_ATTR_NOTICE = 0x02,
156 	IB_SA_ATTR_INFORMINFO = 0x03,
157 	IB_SA_ATTR_NODERECORD = 0x11,
158 	IB_SA_ATTR_PORTINFORECORD = 0x12,
159 	IB_SA_ATTR_SL2VLTABLERECORD = 0x13,
160 	IB_SA_ATTR_SWITCHINFORECORD = 0x14,
161 	IB_SA_ATTR_LFTRECORD = 0x15,
162 	IB_SA_ATTR_RFTRECORD = 0x16,
163 	IB_SA_ATTR_MFTRECORD = 0x17,
164 	IB_SA_ATTR_SMINFORECORD = 0x18,
165 	IB_SA_ATTR_LINKRECORD = 0x20,
166 	IB_SA_ATTR_GUIDINFORECORD = 0x30,
167 	IB_SA_ATTR_SERVICERECORD = 0x31,
168 	IB_SA_ATTR_PKEYTABLERECORD = 0x33,
169 	IB_SA_ATTR_PATHRECORD = 0x35,
170 	IB_SA_ATTR_VLARBTABLERECORD = 0x36,
171 	IB_SA_ATTR_MCRECORD = 0x38,
172 	IB_SA_ATTR_MULTIPATH = 0x3a,
173 	IB_SA_ATTR_INFORMINFORECORD = 0xf3,
174 
175 	IB_SA_ATTR_LAST
176 };
177 
178 enum GSI_ATTR_ID {
179 	IB_GSI_PORT_SAMPLES_CONTROL = 0x10,
180 	IB_GSI_PORT_SAMPLES_RESULT = 0x11,
181 	IB_GSI_PORT_COUNTERS = 0x12,
182 	IB_GSI_PORT_RCV_ERROR_DETAILS = 0x15,
183 	IB_GSI_PORT_XMIT_DISCARD_DETAILS = 0x16,
184 	IB_GSI_PORT_PORT_OP_RCV_COUNTERS = 0x17,
185 	IB_GSI_PORT_PORT_FLOW_CTL_COUNTERS = 0x18,
186 	IB_GSI_PORT_PORT_VL_OP_PACKETS = 0x19,
187 	IB_GSI_PORT_PORT_VL_OP_DATA = 0x1A,
188 	IB_GSI_PORT_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS = 0x1B,
189 	IB_GSI_PORT_PORT_VL_XMIT_WAIT_COUNTERS = 0x1C,
190 	IB_GSI_PORT_COUNTERS_EXT = 0x1D,
191 	IB_GSI_PORT_EXT_SPEEDS_COUNTERS = 0x1F,
192 	IB_GSI_SW_PORT_VL_CONGESTION = 0x30,
193 	IB_GSI_PORT_RCV_CON_CTRL = 0x31,
194 	IB_GSI_PORT_SL_RCV_FECN = 0x32,
195 	IB_GSI_PORT_SL_RCV_BECN = 0x33,
196 	IB_GSI_PORT_XMIT_CON_CTRL = 0x34,
197 	IB_GSI_PORT_VL_XMIT_TIME_CONG = 0x35,
198 	IB_GSI_PORT_XMIT_DATA_SL = 0x36,
199 	IB_GSI_PORT_RCV_DATA_SL = 0x37,
200 	IB_GSI_ATTR_LAST
201 };
202 
203 enum BM_ATTR_ID {
204 	IB_BM_ATTR_BKEYINFO = 0x10,
205 	IB_BM_ATTR_WRITE_VPD = 0x20,
206 	IB_BM_ATTR_READ_VPD = 0x21,
207 	IB_BM_ATTR_RESET_IBML = 0x22,
208 	IB_BM_ATTR_SET_MODULE_PM_CONTROL = 0x23,
209 	IB_BM_ATTR_GET_MODULE_PM_CONTROL = 0x24,
210 	IB_BM_ATTR_SET_UNIT_PM_CONTROL = 0x25,
211 	IB_BM_ATTR_GET_UNIT_PM_CONTROL = 0x26,
212 	IB_BM_ATTR_SET_IOC_PM_CONTROL = 0x27,
213 	IB_BM_ATTR_GET_IOC_PM_CONTROL = 0x28,
214 	IB_BM_ATTR_SET_MODULE_STATE = 0x29,
215 	IB_BM_ATTR_SET_MODULE_ATTENTION = 0x2A,
216 	IB_BM_ATTR_GET_MODULE_STATUS = 0x2B,
217 	IB_BM_ATTR_IB2IBML = 0x2C,
218 	IB_BM_ATTR_IB2CME = 0x2D,
219 	IB_BM_ATTR_IB2MME = 0x2E,
220 	IB_BM_ATTR_OEM = 0x2F,
221 
222 	IB_BM_ATTR_LAST
223 };
224 
225 enum CC_ATTRI_ID {
226 	IB_CC_ATTR_CONGESTION_INFO = 0x11,
227 	IB_CC_ATTR_CONGESTION_KEY_INFO = 0x12,
228 	IB_CC_ATTR_CONGESTION_LOG = 0x13,
229 	IB_CC_ATTR_SWITCH_CONGESTION_SETTING = 0x14,
230 	IB_CC_ATTR_SWITCH_PORT_CONGESTION_SETTING = 0x15,
231 	IB_CC_ATTR_CA_CONGESTION_SETTING = 0x16,
232 	IB_CC_ATTR_CONGESTION_CONTROL_TABLE = 0x17,
233 	IB_CC_ATTR_TIMESTAMP = 0x18,
234 };
235 
236 #define IB_VENDOR_OPENIB_PING_CLASS	(IB_VENDOR_RANGE2_START_CLASS + 2)
237 #define IB_VENDOR_OPENIB_SYSSTAT_CLASS	(IB_VENDOR_RANGE2_START_CLASS + 3)
238 #define IB_OPENIB_OUI			(0x001405)
239 
240 typedef uint8_t ibmad_gid_t[16];
241 #ifdef USE_DEPRECATED_IB_GID_T
242 typedef ibmad_gid_t ib_gid_t __attribute__ ((deprecated));
243 #endif
244 
245 typedef struct {
246 	int cnt;
247 	uint8_t p[IB_SUBNET_PATH_HOPS_MAX];
248 	uint16_t drslid;
249 	uint16_t drdlid;
250 } ib_dr_path_t;
251 
252 typedef struct {
253 	unsigned id;
254 	unsigned mod;
255 } ib_attr_t;
256 
257 typedef struct {
258 	int mgtclass;
259 	int method;
260 	ib_attr_t attr;
261 	uint32_t rstatus;	/* return status */
262 	int dataoffs;
263 	int datasz;
264 	uint64_t mkey;
265 	uint64_t trid;		/* used for out mad if nonzero, return real val */
266 	uint64_t mask;		/* for sa mads */
267 	unsigned recsz;		/* for sa mads (attribute offset) */
268 	int timeout;
269 	uint32_t oui;		/* for vendor range 2 mads */
270 } ib_rpc_t;
271 
272 typedef struct {
273 	int mgtclass;
274 	int method;
275 	ib_attr_t attr;
276 	uint32_t rstatus;	/* return status */
277 	int dataoffs;
278 	int datasz;
279 	uint64_t mkey;
280 	uint64_t trid;		/* used for out mad if nonzero, return real val */
281 	uint64_t mask;		/* for sa mads */
282 	unsigned recsz;		/* for sa mads (attribute offset) */
283 	int timeout;
284 	uint32_t oui;		/* for vendor range 2 mads */
285 	int error;		/* errno */
286 } ib_rpc_v1_t;
287 
288 typedef struct {
289 	int mgtclass;
290 	int method;
291 	ib_attr_t attr;
292 	uint32_t rstatus;       /* return status */
293 	int dataoffs;
294 	int datasz;
295 	uint64_t mkey;
296 	uint64_t trid;          /* used for out mad if nonzero, return real val */
297 	uint64_t mask;          /* for sa mads */
298 	unsigned recsz;         /* for sa mads (attribute offset) */
299 	int timeout;
300 	uint32_t oui;           /* for vendor range 2 mads */
301 	int error;		/* errno */
302 	uint64_t cckey;
303 } ib_rpc_cc_t;
304 
305 typedef struct portid {
306 	int lid;		/* lid or 0 if directed route */
307 	ib_dr_path_t drpath;
308 	int grh_present;	/* flag */
309 	ibmad_gid_t gid;
310 	uint32_t qp;
311 	uint32_t qkey;
312 	uint8_t sl;
313 	unsigned pkey_idx;
314 } ib_portid_t;
315 
316 typedef void (ib_mad_dump_fn) (char *buf, int bufsz, void *val, int valsz);
317 
318 #define IB_FIELD_NAME_LEN	32
319 
320 typedef struct ib_field {
321 	int bitoffs;
322 	int bitlen;
323 	char name[IB_FIELD_NAME_LEN];
324 	ib_mad_dump_fn *def_dump_fn;
325 } ib_field_t;
326 
327 enum MAD_FIELDS {
328 	IB_NO_FIELD,
329 
330 	IB_GID_PREFIX_F,
331 	IB_GID_GUID_F,
332 
333 	/* first MAD word (0-3 bytes) */
334 	IB_MAD_METHOD_F,
335 	IB_MAD_RESPONSE_F,
336 	IB_MAD_CLASSVER_F,
337 	IB_MAD_MGMTCLASS_F,
338 	IB_MAD_BASEVER_F,
339 
340 	/* second MAD word (4-7 bytes) */
341 	IB_MAD_STATUS_F,
342 
343 	/* DRSMP only */
344 	IB_DRSMP_HOPCNT_F,
345 	IB_DRSMP_HOPPTR_F,
346 	IB_DRSMP_STATUS_F,
347 	IB_DRSMP_DIRECTION_F,
348 
349 	/* words 3,4,5,6 (8-23 bytes) */
350 	IB_MAD_TRID_F,
351 	IB_MAD_ATTRID_F,
352 	IB_MAD_ATTRMOD_F,
353 
354 	/* word 7,8 (24-31 bytes) */
355 	IB_MAD_MKEY_F,
356 
357 	/* word 9 (32-37 bytes) */
358 	IB_DRSMP_DRDLID_F,
359 	IB_DRSMP_DRSLID_F,
360 
361 	/* word 10,11 (36-43 bytes) */
362 	IB_SA_MKEY_F,
363 
364 	/* word 12 (44-47 bytes) */
365 	IB_SA_ATTROFFS_F,
366 
367 	/* word 13,14 (48-55 bytes) */
368 	IB_SA_COMPMASK_F,
369 
370 	/* word 13,14 (56-255 bytes) */
371 	IB_SA_DATA_F,
372 
373 	/* bytes 64 - 127 */
374 	IB_SM_DATA_F,
375 
376 	/* bytes 64 - 256 */
377 	IB_GS_DATA_F,
378 
379 	/* bytes 128 - 191 */
380 	IB_DRSMP_PATH_F,
381 
382 	/* bytes 192 - 255 */
383 	IB_DRSMP_RPATH_F,
384 
385 	/*
386 	 * PortInfo fields
387 	 */
388 	IB_PORT_FIRST_F,
389 	IB_PORT_MKEY_F = IB_PORT_FIRST_F,
390 	IB_PORT_GID_PREFIX_F,
391 	IB_PORT_LID_F,
392 	IB_PORT_SMLID_F,
393 	IB_PORT_CAPMASK_F,
394 	IB_PORT_DIAG_F,
395 	IB_PORT_MKEY_LEASE_F,
396 	IB_PORT_LOCAL_PORT_F,
397 	IB_PORT_LINK_WIDTH_ENABLED_F,
398 	IB_PORT_LINK_WIDTH_SUPPORTED_F,
399 	IB_PORT_LINK_WIDTH_ACTIVE_F,
400 	IB_PORT_LINK_SPEED_SUPPORTED_F,
401 	IB_PORT_STATE_F,
402 	IB_PORT_PHYS_STATE_F,
403 	IB_PORT_LINK_DOWN_DEF_F,
404 	IB_PORT_MKEY_PROT_BITS_F,
405 	IB_PORT_LMC_F,
406 	IB_PORT_LINK_SPEED_ACTIVE_F,
407 	IB_PORT_LINK_SPEED_ENABLED_F,
408 	IB_PORT_NEIGHBOR_MTU_F,
409 	IB_PORT_SMSL_F,
410 	IB_PORT_VL_CAP_F,
411 	IB_PORT_INIT_TYPE_F,
412 	IB_PORT_VL_HIGH_LIMIT_F,
413 	IB_PORT_VL_ARBITRATION_HIGH_CAP_F,
414 	IB_PORT_VL_ARBITRATION_LOW_CAP_F,
415 	IB_PORT_INIT_TYPE_REPLY_F,
416 	IB_PORT_MTU_CAP_F,
417 	IB_PORT_VL_STALL_COUNT_F,
418 	IB_PORT_HOQ_LIFE_F,
419 	IB_PORT_OPER_VLS_F,
420 	IB_PORT_PART_EN_INB_F,
421 	IB_PORT_PART_EN_OUTB_F,
422 	IB_PORT_FILTER_RAW_INB_F,
423 	IB_PORT_FILTER_RAW_OUTB_F,
424 	IB_PORT_MKEY_VIOL_F,
425 	IB_PORT_PKEY_VIOL_F,
426 	IB_PORT_QKEY_VIOL_F,
427 	IB_PORT_GUID_CAP_F,
428 	IB_PORT_CLIENT_REREG_F,
429 	IB_PORT_MCAST_PKEY_SUPR_ENAB_F,
430 	IB_PORT_SUBN_TIMEOUT_F,
431 	IB_PORT_RESP_TIME_VAL_F,
432 	IB_PORT_LOCAL_PHYS_ERR_F,
433 	IB_PORT_OVERRUN_ERR_F,
434 	IB_PORT_MAX_CREDIT_HINT_F,
435 	IB_PORT_LINK_ROUND_TRIP_F,
436 	IB_PORT_LAST_F,
437 
438 	/*
439 	 * NodeInfo fields
440 	 */
441 	IB_NODE_FIRST_F,
442 	IB_NODE_BASE_VERS_F = IB_NODE_FIRST_F,
443 	IB_NODE_CLASS_VERS_F,
444 	IB_NODE_TYPE_F,
445 	IB_NODE_NPORTS_F,
446 	IB_NODE_SYSTEM_GUID_F,
447 	IB_NODE_GUID_F,
448 	IB_NODE_PORT_GUID_F,
449 	IB_NODE_PARTITION_CAP_F,
450 	IB_NODE_DEVID_F,
451 	IB_NODE_REVISION_F,
452 	IB_NODE_LOCAL_PORT_F,
453 	IB_NODE_VENDORID_F,
454 	IB_NODE_LAST_F,
455 
456 	/*
457 	 * SwitchInfo fields
458 	 */
459 	IB_SW_FIRST_F,
460 	IB_SW_LINEAR_FDB_CAP_F = IB_SW_FIRST_F,
461 	IB_SW_RANDOM_FDB_CAP_F,
462 	IB_SW_MCAST_FDB_CAP_F,
463 	IB_SW_LINEAR_FDB_TOP_F,
464 	IB_SW_DEF_PORT_F,
465 	IB_SW_DEF_MCAST_PRIM_F,
466 	IB_SW_DEF_MCAST_NOT_PRIM_F,
467 	IB_SW_LIFE_TIME_F,
468 	IB_SW_STATE_CHANGE_F,
469 	IB_SW_OPT_SLTOVL_MAPPING_F,
470 	IB_SW_LIDS_PER_PORT_F,
471 	IB_SW_PARTITION_ENFORCE_CAP_F,
472 	IB_SW_PARTITION_ENF_INB_F,
473 	IB_SW_PARTITION_ENF_OUTB_F,
474 	IB_SW_FILTER_RAW_INB_F,
475 	IB_SW_FILTER_RAW_OUTB_F,
476 	IB_SW_ENHANCED_PORT0_F,
477 	IB_SW_MCAST_FDB_TOP_F,
478 	IB_SW_LAST_F,
479 
480 	/*
481 	 * SwitchLinearForwardingTable fields
482 	 */
483 	IB_LINEAR_FORW_TBL_F,
484 
485 	/*
486 	 * SwitchMulticastForwardingTable fields
487 	 */
488 	IB_MULTICAST_FORW_TBL_F,
489 
490 	/*
491 	 * NodeDescription fields
492 	 */
493 	IB_NODE_DESC_F,
494 
495 	/*
496 	 * Notice/Trap fields
497 	 */
498 	IB_NOTICE_IS_GENERIC_F,
499 	IB_NOTICE_TYPE_F,
500 	IB_NOTICE_PRODUCER_F,
501 	IB_NOTICE_TRAP_NUMBER_F,
502 	IB_NOTICE_ISSUER_LID_F,
503 	IB_NOTICE_TOGGLE_F,
504 	IB_NOTICE_COUNT_F,
505 	IB_NOTICE_DATA_DETAILS_F,
506 	IB_NOTICE_DATA_LID_F,
507 	IB_NOTICE_DATA_144_LID_F,
508 	IB_NOTICE_DATA_144_CAPMASK_F,
509 
510 	/*
511 	 * GS Performance
512 	 */
513 	IB_PC_FIRST_F,
514 	IB_PC_PORT_SELECT_F = IB_PC_FIRST_F,
515 	IB_PC_COUNTER_SELECT_F,
516 	IB_PC_ERR_SYM_F,
517 	IB_PC_LINK_RECOVERS_F,
518 	IB_PC_LINK_DOWNED_F,
519 	IB_PC_ERR_RCV_F,
520 	IB_PC_ERR_PHYSRCV_F,
521 	IB_PC_ERR_SWITCH_REL_F,
522 	IB_PC_XMT_DISCARDS_F,
523 	IB_PC_ERR_XMTCONSTR_F,
524 	IB_PC_ERR_RCVCONSTR_F,
525 	IB_PC_COUNTER_SELECT2_F,
526 	IB_PC_ERR_LOCALINTEG_F,
527 	IB_PC_ERR_EXCESS_OVR_F,
528 	IB_PC_VL15_DROPPED_F,
529 	IB_PC_XMT_BYTES_F,
530 	IB_PC_RCV_BYTES_F,
531 	IB_PC_XMT_PKTS_F,
532 	IB_PC_RCV_PKTS_F,
533 	IB_PC_XMT_WAIT_F,
534 	IB_PC_LAST_F,
535 
536 	/*
537 	 * SMInfo
538 	 */
539 	IB_SMINFO_GUID_F,
540 	IB_SMINFO_KEY_F,
541 	IB_SMINFO_ACT_F,
542 	IB_SMINFO_PRIO_F,
543 	IB_SMINFO_STATE_F,
544 
545 	/*
546 	 * SA RMPP
547 	 */
548 	IB_SA_RMPP_VERS_F,
549 	IB_SA_RMPP_TYPE_F,
550 	IB_SA_RMPP_RESP_F,
551 	IB_SA_RMPP_FLAGS_F,
552 	IB_SA_RMPP_STATUS_F,
553 
554 	/* data1 */
555 	IB_SA_RMPP_D1_F,
556 	IB_SA_RMPP_SEGNUM_F,
557 	/* data2 */
558 	IB_SA_RMPP_D2_F,
559 	IB_SA_RMPP_LEN_F,	/* DATA: Payload len */
560 	IB_SA_RMPP_NEWWIN_F,	/* ACK: new window last */
561 
562 	/*
563 	 * SA Multi Path rec
564 	 */
565 	IB_SA_MP_NPATH_F,
566 	IB_SA_MP_NSRC_F,
567 	IB_SA_MP_NDEST_F,
568 	IB_SA_MP_GID0_F,
569 
570 	/*
571 	 * SA Path rec
572 	 */
573 	IB_SA_PR_DGID_F,
574 	IB_SA_PR_SGID_F,
575 	IB_SA_PR_DLID_F,
576 	IB_SA_PR_SLID_F,
577 	IB_SA_PR_NPATH_F,
578 	IB_SA_PR_SL_F,
579 
580 	/*
581 	 * MC Member rec
582 	 */
583 	IB_SA_MCM_MGID_F,
584 	IB_SA_MCM_PORTGID_F,
585 	IB_SA_MCM_QKEY_F,
586 	IB_SA_MCM_MLID_F,
587 	IB_SA_MCM_SL_F,
588 	IB_SA_MCM_MTU_F,
589 	IB_SA_MCM_RATE_F,
590 	IB_SA_MCM_TCLASS_F,
591 	IB_SA_MCM_PKEY_F,
592 	IB_SA_MCM_FLOW_LABEL_F,
593 	IB_SA_MCM_JOIN_STATE_F,
594 	IB_SA_MCM_PROXY_JOIN_F,
595 
596 	/*
597 	 * Service record
598 	 */
599 	IB_SA_SR_ID_F,
600 	IB_SA_SR_GID_F,
601 	IB_SA_SR_PKEY_F,
602 	IB_SA_SR_LEASE_F,
603 	IB_SA_SR_KEY_F,
604 	IB_SA_SR_NAME_F,
605 	IB_SA_SR_DATA_F,
606 
607 	/*
608 	 * ATS SM record - within SA_SR_DATA
609 	 */
610 	IB_ATS_SM_NODE_ADDR_F,
611 	IB_ATS_SM_MAGIC_KEY_F,
612 	IB_ATS_SM_NODE_TYPE_F,
613 	IB_ATS_SM_NODE_NAME_F,
614 
615 	/*
616 	 * SLTOVL MAPPING TABLE
617 	 */
618 	IB_SLTOVL_MAPPING_TABLE_F,
619 
620 	/*
621 	 * VL ARBITRATION TABLE
622 	 */
623 	IB_VL_ARBITRATION_TABLE_F,
624 
625 	/*
626 	 * IB vendor class range 2
627 	 */
628 	IB_VEND2_OUI_F,
629 	IB_VEND2_DATA_F,
630 
631 	/*
632 	 * PortCountersExtended
633 	 */
634 	IB_PC_EXT_FIRST_F,
635 	IB_PC_EXT_PORT_SELECT_F = IB_PC_EXT_FIRST_F,
636 	IB_PC_EXT_COUNTER_SELECT_F,
637 	IB_PC_EXT_XMT_BYTES_F,
638 	IB_PC_EXT_RCV_BYTES_F,
639 	IB_PC_EXT_XMT_PKTS_F,
640 	IB_PC_EXT_RCV_PKTS_F,
641 	IB_PC_EXT_XMT_UPKTS_F,
642 	IB_PC_EXT_RCV_UPKTS_F,
643 	IB_PC_EXT_XMT_MPKTS_F,
644 	IB_PC_EXT_RCV_MPKTS_F,
645 	IB_PC_EXT_LAST_F,
646 
647 	/*
648 	 * GUIDInfo fields
649 	 */
650 	IB_GUID_GUID0_F, /* Obsolete, kept for compatibility
651 			    Use IB_GI_GUID0_F going forward */
652 
653 	/*
654 	 * ClassPortInfo fields
655 	 */
656 	IB_CPI_BASEVER_F,
657 	IB_CPI_CLASSVER_F,
658 	IB_CPI_CAPMASK_F,
659 	IB_CPI_CAPMASK2_F,
660 	IB_CPI_RESP_TIME_VALUE_F,
661 	IB_CPI_REDIRECT_GID_F,
662 	IB_CPI_REDIRECT_TC_F,
663 	IB_CPI_REDIRECT_SL_F,
664 	IB_CPI_REDIRECT_FL_F,
665 	IB_CPI_REDIRECT_LID_F,
666 	IB_CPI_REDIRECT_PKEY_F,
667 	IB_CPI_REDIRECT_QP_F,
668 	IB_CPI_REDIRECT_QKEY_F,
669 	IB_CPI_TRAP_GID_F,
670 	IB_CPI_TRAP_TC_F,
671 	IB_CPI_TRAP_SL_F,
672 	IB_CPI_TRAP_FL_F,
673 	IB_CPI_TRAP_LID_F,
674 	IB_CPI_TRAP_PKEY_F,
675 	IB_CPI_TRAP_HL_F,
676 	IB_CPI_TRAP_QP_F,
677 	IB_CPI_TRAP_QKEY_F,
678 
679 	/*
680 	 * PortXmitDataSL fields
681 	 */
682 	IB_PC_XMT_DATA_SL_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
683 	IB_PC_XMT_DATA_SL0_F = IB_PC_XMT_DATA_SL_FIRST_F,
684 	IB_PC_XMT_DATA_SL1_F,
685 	IB_PC_XMT_DATA_SL2_F,
686 	IB_PC_XMT_DATA_SL3_F,
687 	IB_PC_XMT_DATA_SL4_F,
688 	IB_PC_XMT_DATA_SL5_F,
689 	IB_PC_XMT_DATA_SL6_F,
690 	IB_PC_XMT_DATA_SL7_F,
691 	IB_PC_XMT_DATA_SL8_F,
692 	IB_PC_XMT_DATA_SL9_F,
693 	IB_PC_XMT_DATA_SL10_F,
694 	IB_PC_XMT_DATA_SL11_F,
695 	IB_PC_XMT_DATA_SL12_F,
696 	IB_PC_XMT_DATA_SL13_F,
697 	IB_PC_XMT_DATA_SL14_F,
698 	IB_PC_XMT_DATA_SL15_F,
699 	IB_PC_XMT_DATA_SL_LAST_F,
700 
701 	/*
702 	 * PortRcvDataSL fields
703 	 */
704 	IB_PC_RCV_DATA_SL_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
705 	IB_PC_RCV_DATA_SL0_F = IB_PC_RCV_DATA_SL_FIRST_F,
706 	IB_PC_RCV_DATA_SL1_F,
707 	IB_PC_RCV_DATA_SL2_F,
708 	IB_PC_RCV_DATA_SL3_F,
709 	IB_PC_RCV_DATA_SL4_F,
710 	IB_PC_RCV_DATA_SL5_F,
711 	IB_PC_RCV_DATA_SL6_F,
712 	IB_PC_RCV_DATA_SL7_F,
713 	IB_PC_RCV_DATA_SL8_F,
714 	IB_PC_RCV_DATA_SL9_F,
715 	IB_PC_RCV_DATA_SL10_F,
716 	IB_PC_RCV_DATA_SL11_F,
717 	IB_PC_RCV_DATA_SL12_F,
718 	IB_PC_RCV_DATA_SL13_F,
719 	IB_PC_RCV_DATA_SL14_F,
720 	IB_PC_RCV_DATA_SL15_F,
721 	IB_PC_RCV_DATA_SL_LAST_F,
722 
723 	/*
724 	 * PortXmitDiscardDetails fields
725 	 */
726 	/* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
727 	IB_PC_XMT_INACT_DISC_F,
728 	IB_PC_XMT_NEIGH_MTU_DISC_F,
729 	IB_PC_XMT_SW_LIFE_DISC_F,
730 	IB_PC_XMT_SW_HOL_DISC_F,
731 	IB_PC_XMT_DISC_LAST_F,
732 
733 	/*
734 	 * PortRcvErrorDetails fields
735 	 */
736 	/* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
737 	IB_PC_RCV_LOCAL_PHY_ERR_F,
738 	IB_PC_RCV_MALFORMED_PKT_ERR_F,
739 	IB_PC_RCV_BUF_OVR_ERR_F,
740 	IB_PC_RCV_DLID_MAP_ERR_F,
741 	IB_PC_RCV_VL_MAP_ERR_F,
742 	IB_PC_RCV_LOOPING_ERR_F,
743 	IB_PC_RCV_ERR_LAST_F,
744 
745 	/*
746 	 * PortSamplesControl fields
747 	 */
748 	IB_PSC_OPCODE_F,
749 	IB_PSC_PORT_SELECT_F,
750 	IB_PSC_TICK_F,
751 	IB_PSC_COUNTER_WIDTH_F,
752 	IB_PSC_COUNTER_MASK0_F,
753 	IB_PSC_COUNTER_MASKS1TO9_F,
754 	IB_PSC_COUNTER_MASKS10TO14_F,
755 	IB_PSC_SAMPLE_MECHS_F,
756 	IB_PSC_SAMPLE_STATUS_F,
757 	IB_PSC_OPTION_MASK_F,
758 	IB_PSC_VENDOR_MASK_F,
759 	IB_PSC_SAMPLE_START_F,
760 	IB_PSC_SAMPLE_INTVL_F,
761 	IB_PSC_TAG_F,
762 	IB_PSC_COUNTER_SEL0_F,
763 	IB_PSC_COUNTER_SEL1_F,
764 	IB_PSC_COUNTER_SEL2_F,
765 	IB_PSC_COUNTER_SEL3_F,
766 	IB_PSC_COUNTER_SEL4_F,
767 	IB_PSC_COUNTER_SEL5_F,
768 	IB_PSC_COUNTER_SEL6_F,
769 	IB_PSC_COUNTER_SEL7_F,
770 	IB_PSC_COUNTER_SEL8_F,
771 	IB_PSC_COUNTER_SEL9_F,
772 	IB_PSC_COUNTER_SEL10_F,
773 	IB_PSC_COUNTER_SEL11_F,
774 	IB_PSC_COUNTER_SEL12_F,
775 	IB_PSC_COUNTER_SEL13_F,
776 	IB_PSC_COUNTER_SEL14_F,
777 	IB_PSC_SAMPLES_ONLY_OPT_MASK_F,
778 	IB_PSC_LAST_F,
779 
780 	/*
781 	 * GUIDInfo fields
782 	 */
783 	IB_GI_GUID0_F, /* a duplicate of IB_GUID_GUID0_F for backwards
784 			  compatibility */
785 	IB_GI_GUID1_F,
786 	IB_GI_GUID2_F,
787 	IB_GI_GUID3_F,
788 	IB_GI_GUID4_F,
789 	IB_GI_GUID5_F,
790 	IB_GI_GUID6_F,
791 	IB_GI_GUID7_F,
792 
793 	/*
794 	 * GUID Info Record
795 	 */
796 	IB_SA_GIR_LID_F,
797 	IB_SA_GIR_BLOCKNUM_F,
798 	IB_SA_GIR_GUID0_F,
799 	IB_SA_GIR_GUID1_F,
800 	IB_SA_GIR_GUID2_F,
801 	IB_SA_GIR_GUID3_F,
802 	IB_SA_GIR_GUID4_F,
803 	IB_SA_GIR_GUID5_F,
804 	IB_SA_GIR_GUID6_F,
805 	IB_SA_GIR_GUID7_F,
806 
807 	/*
808 	 * More PortInfo fields
809 	 */
810 	IB_PORT_CAPMASK2_F,
811 	IB_PORT_LINK_SPEED_EXT_ACTIVE_F,
812 	IB_PORT_LINK_SPEED_EXT_SUPPORTED_F,
813 	IB_PORT_LINK_SPEED_EXT_ENABLED_F,
814 	IB_PORT_LINK_SPEED_EXT_LAST_F,
815 
816 	/*
817 	 * PortExtendedSpeedsCounters fields
818 	 */
819 	IB_PESC_PORT_SELECT_F,
820 	IB_PESC_COUNTER_SELECT_F,
821 	IB_PESC_SYNC_HDR_ERR_CTR_F,
822 	IB_PESC_UNK_BLOCK_CTR_F,
823 	IB_PESC_ERR_DET_CTR_LANE0_F,
824 	IB_PESC_ERR_DET_CTR_LANE1_F,
825 	IB_PESC_ERR_DET_CTR_LANE2_F,
826 	IB_PESC_ERR_DET_CTR_LANE3_F,
827 	IB_PESC_ERR_DET_CTR_LANE4_F,
828 	IB_PESC_ERR_DET_CTR_LANE5_F,
829 	IB_PESC_ERR_DET_CTR_LANE6_F,
830 	IB_PESC_ERR_DET_CTR_LANE7_F,
831 	IB_PESC_ERR_DET_CTR_LANE8_F,
832 	IB_PESC_ERR_DET_CTR_LANE9_F,
833 	IB_PESC_ERR_DET_CTR_LANE10_F,
834 	IB_PESC_ERR_DET_CTR_LANE11_F,
835 	IB_PESC_FEC_CORR_BLOCK_CTR_LANE0_F,
836 	IB_PESC_FEC_CORR_BLOCK_CTR_LANE1_F,
837 	IB_PESC_FEC_CORR_BLOCK_CTR_LANE2_F,
838 	IB_PESC_FEC_CORR_BLOCK_CTR_LANE3_F,
839 	IB_PESC_FEC_CORR_BLOCK_CTR_LANE4_F,
840 	IB_PESC_FEC_CORR_BLOCK_CTR_LANE5_F,
841 	IB_PESC_FEC_CORR_BLOCK_CTR_LANE6_F,
842 	IB_PESC_FEC_CORR_BLOCK_CTR_LANE7_F,
843 	IB_PESC_FEC_CORR_BLOCK_CTR_LANE8_F,
844 	IB_PESC_FEC_CORR_BLOCK_CTR_LANE9_F,
845 	IB_PESC_FEC_CORR_BLOCK_CTR_LANE10_F,
846 	IB_PESC_FEC_CORR_BLOCK_CTR_LANE11_F,
847 	IB_PESC_FEC_UNCORR_BLOCK_CTR_LANE0_F,
848 	IB_PESC_FEC_UNCORR_BLOCK_CTR_LANE1_F,
849 	IB_PESC_FEC_UNCORR_BLOCK_CTR_LANE2_F,
850 	IB_PESC_FEC_UNCORR_BLOCK_CTR_LANE3_F,
851 	IB_PESC_FEC_UNCORR_BLOCK_CTR_LANE4_F,
852 	IB_PESC_FEC_UNCORR_BLOCK_CTR_LANE5_F,
853 	IB_PESC_FEC_UNCORR_BLOCK_CTR_LANE6_F,
854 	IB_PESC_FEC_UNCORR_BLOCK_CTR_LANE7_F,
855 	IB_PESC_FEC_UNCORR_BLOCK_CTR_LANE8_F,
856 	IB_PESC_FEC_UNCORR_BLOCK_CTR_LANE9_F,
857 	IB_PESC_FEC_UNCORR_BLOCK_CTR_LANE10_F,
858 	IB_PESC_FEC_UNCORR_BLOCK_CTR_LANE11_F,
859 	IB_PESC_LAST_F,
860 
861 	/*
862 	 * PortOpRcvCounters fields
863 	 */
864 	IB_PC_PORT_OP_RCV_COUNTERS_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
865 	IB_PC_PORT_OP_RCV_PKTS_F = IB_PC_PORT_OP_RCV_COUNTERS_FIRST_F,
866 	IB_PC_PORT_OP_RCV_DATA_F,
867 	IB_PC_PORT_OP_RCV_COUNTERS_LAST_F,
868 
869 	/*
870 	 * PortFlowCtlCounters fields
871 	 */
872 	IB_PC_PORT_FLOW_CTL_COUNTERS_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
873 	IB_PC_PORT_XMIT_FLOW_PKTS_F = IB_PC_PORT_FLOW_CTL_COUNTERS_FIRST_F,
874 	IB_PC_PORT_RCV_FLOW_PKTS_F,
875 	IB_PC_PORT_FLOW_CTL_COUNTERS_LAST_F,
876 
877 	/*
878 	 * PortVLOpPackets fields
879 	 */
880 	IB_PC_PORT_VL_OP_PACKETS_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
881 	IB_PC_PORT_VL_OP_PACKETS0_F = IB_PC_PORT_VL_OP_PACKETS_FIRST_F,
882 	IB_PC_PORT_VL_OP_PACKETS1_F,
883 	IB_PC_PORT_VL_OP_PACKETS2_F,
884 	IB_PC_PORT_VL_OP_PACKETS3_F,
885 	IB_PC_PORT_VL_OP_PACKETS4_F,
886 	IB_PC_PORT_VL_OP_PACKETS5_F,
887 	IB_PC_PORT_VL_OP_PACKETS6_F,
888 	IB_PC_PORT_VL_OP_PACKETS7_F,
889 	IB_PC_PORT_VL_OP_PACKETS8_F,
890 	IB_PC_PORT_VL_OP_PACKETS9_F,
891 	IB_PC_PORT_VL_OP_PACKETS10_F,
892 	IB_PC_PORT_VL_OP_PACKETS11_F,
893 	IB_PC_PORT_VL_OP_PACKETS12_F,
894 	IB_PC_PORT_VL_OP_PACKETS13_F,
895 	IB_PC_PORT_VL_OP_PACKETS14_F,
896 	IB_PC_PORT_VL_OP_PACKETS15_F,
897 	IB_PC_PORT_VL_OP_PACKETS_LAST_F,
898 
899 	/*
900 	 * PortVLOpData fields
901 	 */
902 	IB_PC_PORT_VL_OP_DATA_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
903 	IB_PC_PORT_VL_OP_DATA0_F = IB_PC_PORT_VL_OP_DATA_FIRST_F,
904 	IB_PC_PORT_VL_OP_DATA1_F,
905 	IB_PC_PORT_VL_OP_DATA2_F,
906 	IB_PC_PORT_VL_OP_DATA3_F,
907 	IB_PC_PORT_VL_OP_DATA4_F,
908 	IB_PC_PORT_VL_OP_DATA5_F,
909 	IB_PC_PORT_VL_OP_DATA6_F,
910 	IB_PC_PORT_VL_OP_DATA7_F,
911 	IB_PC_PORT_VL_OP_DATA8_F,
912 	IB_PC_PORT_VL_OP_DATA9_F,
913 	IB_PC_PORT_VL_OP_DATA10_F,
914 	IB_PC_PORT_VL_OP_DATA11_F,
915 	IB_PC_PORT_VL_OP_DATA12_F,
916 	IB_PC_PORT_VL_OP_DATA13_F,
917 	IB_PC_PORT_VL_OP_DATA14_F,
918 	IB_PC_PORT_VL_OP_DATA15_F,
919 	IB_PC_PORT_VL_OP_DATA_LAST_F,
920 
921 	/*
922 	 * PortVLXmitFlowCtlUpdateErrors fields
923 	 */
924 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
925 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS0_F = IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS_FIRST_F,
926 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS1_F,
927 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS2_F,
928 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS3_F,
929 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS4_F,
930 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS5_F,
931 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS6_F,
932 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS7_F,
933 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS8_F,
934 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS9_F,
935 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS10_F,
936 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS11_F,
937 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS12_F,
938 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS13_F,
939 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS14_F,
940 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS15_F,
941 	IB_PC_PORT_VL_XMIT_FLOW_CTL_UPDATE_ERRORS_LAST_F,
942 
943 	/*
944 	 * PortVLXmitWaitCounters fields
945 	 */
946 	IB_PC_PORT_VL_XMIT_WAIT_COUNTERS_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
947 	IB_PC_PORT_VL_XMIT_WAIT0_F = IB_PC_PORT_VL_XMIT_WAIT_COUNTERS_FIRST_F,
948 	IB_PC_PORT_VL_XMIT_WAIT1_F,
949 	IB_PC_PORT_VL_XMIT_WAIT2_F,
950 	IB_PC_PORT_VL_XMIT_WAIT3_F,
951 	IB_PC_PORT_VL_XMIT_WAIT4_F,
952 	IB_PC_PORT_VL_XMIT_WAIT5_F,
953 	IB_PC_PORT_VL_XMIT_WAIT6_F,
954 	IB_PC_PORT_VL_XMIT_WAIT7_F,
955 	IB_PC_PORT_VL_XMIT_WAIT8_F,
956 	IB_PC_PORT_VL_XMIT_WAIT9_F,
957 	IB_PC_PORT_VL_XMIT_WAIT10_F,
958 	IB_PC_PORT_VL_XMIT_WAIT11_F,
959 	IB_PC_PORT_VL_XMIT_WAIT12_F,
960 	IB_PC_PORT_VL_XMIT_WAIT13_F,
961 	IB_PC_PORT_VL_XMIT_WAIT14_F,
962 	IB_PC_PORT_VL_XMIT_WAIT15_F,
963 	IB_PC_PORT_VL_XMIT_WAIT_COUNTERS_LAST_F,
964 
965 	/*
966 	 * SwPortVLCongestion fields
967 	 */
968 	IB_PC_SW_PORT_VL_CONGESTION_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
969 	IB_PC_SW_PORT_VL_CONGESTION0_F = IB_PC_SW_PORT_VL_CONGESTION_FIRST_F,
970 	IB_PC_SW_PORT_VL_CONGESTION1_F,
971 	IB_PC_SW_PORT_VL_CONGESTION2_F,
972 	IB_PC_SW_PORT_VL_CONGESTION3_F,
973 	IB_PC_SW_PORT_VL_CONGESTION4_F,
974 	IB_PC_SW_PORT_VL_CONGESTION5_F,
975 	IB_PC_SW_PORT_VL_CONGESTION6_F,
976 	IB_PC_SW_PORT_VL_CONGESTION7_F,
977 	IB_PC_SW_PORT_VL_CONGESTION8_F,
978 	IB_PC_SW_PORT_VL_CONGESTION9_F,
979 	IB_PC_SW_PORT_VL_CONGESTION10_F,
980 	IB_PC_SW_PORT_VL_CONGESTION11_F,
981 	IB_PC_SW_PORT_VL_CONGESTION12_F,
982 	IB_PC_SW_PORT_VL_CONGESTION13_F,
983 	IB_PC_SW_PORT_VL_CONGESTION14_F,
984 	IB_PC_SW_PORT_VL_CONGESTION15_F,
985 	IB_PC_SW_PORT_VL_CONGESTION_LAST_F,
986 
987 	/*
988 	 * PortRcvConCtrl fields
989 	 */
990 	IB_PC_RCV_CON_CTRL_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
991 	IB_PC_RCV_CON_CTRL_PKT_RCV_FECN_F = IB_PC_RCV_CON_CTRL_FIRST_F,
992 	IB_PC_RCV_CON_CTRL_PKT_RCV_BECN_F,
993 	IB_PC_RCV_CON_CTRL_LAST_F,
994 
995 	/*
996 	 * PortSLRcvFECN fields
997 	 */
998 	IB_PC_SL_RCV_FECN_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
999 	IB_PC_SL_RCV_FECN0_F = IB_PC_SL_RCV_FECN_FIRST_F,
1000 	IB_PC_SL_RCV_FECN1_F,
1001 	IB_PC_SL_RCV_FECN2_F,
1002 	IB_PC_SL_RCV_FECN3_F,
1003 	IB_PC_SL_RCV_FECN4_F,
1004 	IB_PC_SL_RCV_FECN5_F,
1005 	IB_PC_SL_RCV_FECN6_F,
1006 	IB_PC_SL_RCV_FECN7_F,
1007 	IB_PC_SL_RCV_FECN8_F,
1008 	IB_PC_SL_RCV_FECN9_F,
1009 	IB_PC_SL_RCV_FECN10_F,
1010 	IB_PC_SL_RCV_FECN11_F,
1011 	IB_PC_SL_RCV_FECN12_F,
1012 	IB_PC_SL_RCV_FECN13_F,
1013 	IB_PC_SL_RCV_FECN14_F,
1014 	IB_PC_SL_RCV_FECN15_F,
1015 	IB_PC_SL_RCV_FECN_LAST_F,
1016 
1017 	/*
1018 	 * PortSLRcvBECN fields
1019 	 */
1020 	IB_PC_SL_RCV_BECN_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
1021 	IB_PC_SL_RCV_BECN0_F = IB_PC_SL_RCV_BECN_FIRST_F,
1022 	IB_PC_SL_RCV_BECN1_F,
1023 	IB_PC_SL_RCV_BECN2_F,
1024 	IB_PC_SL_RCV_BECN3_F,
1025 	IB_PC_SL_RCV_BECN4_F,
1026 	IB_PC_SL_RCV_BECN5_F,
1027 	IB_PC_SL_RCV_BECN6_F,
1028 	IB_PC_SL_RCV_BECN7_F,
1029 	IB_PC_SL_RCV_BECN8_F,
1030 	IB_PC_SL_RCV_BECN9_F,
1031 	IB_PC_SL_RCV_BECN10_F,
1032 	IB_PC_SL_RCV_BECN11_F,
1033 	IB_PC_SL_RCV_BECN12_F,
1034 	IB_PC_SL_RCV_BECN13_F,
1035 	IB_PC_SL_RCV_BECN14_F,
1036 	IB_PC_SL_RCV_BECN15_F,
1037 	IB_PC_SL_RCV_BECN_LAST_F,
1038 
1039 	/*
1040 	 * PortXmitConCtrl fields
1041 	 */
1042 	IB_PC_XMIT_CON_CTRL_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
1043 	IB_PC_XMIT_CON_CTRL_TIME_CONG_F = IB_PC_XMIT_CON_CTRL_FIRST_F,
1044 	IB_PC_XMIT_CON_CTRL_LAST_F,
1045 
1046 	/*
1047 	 * PortVLXmitTimeCong fields
1048 	 */
1049 	IB_PC_VL_XMIT_TIME_CONG_FIRST_F, /* for PortSelect and CounterSelect, use IB_PC_PORT_SELECT_F and IB_PC_COUNTER_SELECT_F */
1050 	IB_PC_VL_XMIT_TIME_CONG0_F = IB_PC_VL_XMIT_TIME_CONG_FIRST_F,
1051 	IB_PC_VL_XMIT_TIME_CONG1_F,
1052 	IB_PC_VL_XMIT_TIME_CONG2_F,
1053 	IB_PC_VL_XMIT_TIME_CONG3_F,
1054 	IB_PC_VL_XMIT_TIME_CONG4_F,
1055 	IB_PC_VL_XMIT_TIME_CONG5_F,
1056 	IB_PC_VL_XMIT_TIME_CONG6_F,
1057 	IB_PC_VL_XMIT_TIME_CONG7_F,
1058 	IB_PC_VL_XMIT_TIME_CONG8_F,
1059 	IB_PC_VL_XMIT_TIME_CONG9_F,
1060 	IB_PC_VL_XMIT_TIME_CONG10_F,
1061 	IB_PC_VL_XMIT_TIME_CONG11_F,
1062 	IB_PC_VL_XMIT_TIME_CONG12_F,
1063 	IB_PC_VL_XMIT_TIME_CONG13_F,
1064 	IB_PC_VL_XMIT_TIME_CONG14_F,
1065 	IB_PC_VL_XMIT_TIME_CONG_LAST_F,
1066 
1067 	/*
1068 	 * Mellanox ExtendedPortInfo fields
1069 	 */
1070 	IB_MLNX_EXT_PORT_STATE_CHG_ENABLE_F,
1071 	IB_MLNX_EXT_PORT_LINK_SPEED_SUPPORTED_F,
1072 	IB_MLNX_EXT_PORT_LINK_SPEED_ENABLED_F,
1073 	IB_MLNX_EXT_PORT_LINK_SPEED_ACTIVE_F,
1074 	IB_MLNX_EXT_PORT_LAST_F,
1075 
1076 	/*
1077 	 * Congestion Control Mad fields
1078 	 * bytes 24-31 of congestion control mad
1079 	 */
1080 	IB_CC_CCKEY_F,
1081 
1082 	/*
1083 	 * CongestionInfo fields
1084 	 */
1085 	IB_CC_CONGESTION_INFO_FIRST_F,
1086 	IB_CC_CONGESTION_INFO_F = IB_CC_CONGESTION_INFO_FIRST_F,
1087 	IB_CC_CONGESTION_INFO_CONTROL_TABLE_CAP_F,
1088 	IB_CC_CONGESTION_INFO_LAST_F,
1089 
1090 	/*
1091 	 * CongestionKeyInfo fields
1092 	 */
1093 	IB_CC_CONGESTION_KEY_INFO_FIRST_F,
1094 	IB_CC_CONGESTION_KEY_INFO_CC_KEY_F = IB_CC_CONGESTION_KEY_INFO_FIRST_F,
1095 	IB_CC_CONGESTION_KEY_INFO_CC_KEY_PROTECT_BIT_F,
1096 	IB_CC_CONGESTION_KEY_INFO_CC_KEY_LEASE_PERIOD_F,
1097 	IB_CC_CONGESTION_KEY_INFO_CC_KEY_VIOLATIONS_F,
1098 	IB_CC_CONGESTION_KEY_INFO_LAST_F,
1099 
1100 	/*
1101 	 * CongestionLog (common) fields
1102 	 */
1103 	IB_CC_CONGESTION_LOG_FIRST_F,
1104 	IB_CC_CONGESTION_LOG_LOGTYPE_F = IB_CC_CONGESTION_LOG_FIRST_F,
1105 	IB_CC_CONGESTION_LOG_CONGESTION_FLAGS_F,
1106 	IB_CC_CONGESTION_LOG_LAST_F,
1107 
1108 	/*
1109 	 * CongestionLog (Switch) fields
1110 	 */
1111 	IB_CC_CONGESTION_LOG_SWITCH_FIRST_F,
1112 	IB_CC_CONGESTION_LOG_SWITCH_LOG_EVENTS_COUNTER_F = IB_CC_CONGESTION_LOG_SWITCH_FIRST_F,
1113 	IB_CC_CONGESTION_LOG_SWITCH_CURRENT_TIME_STAMP_F,
1114 	IB_CC_CONGESTION_LOG_SWITCH_PORTMAP_F,
1115 	IB_CC_CONGESTION_LOG_SWITCH_LAST_F,
1116 
1117 	/*
1118 	 * CongestionLogEvent (Switch) fields
1119 	 */
1120 	IB_CC_CONGESTION_LOG_ENTRY_SWITCH_FIRST_F,
1121 	IB_CC_CONGESTION_LOG_ENTRY_SWITCH_SLID_F = IB_CC_CONGESTION_LOG_ENTRY_SWITCH_FIRST_F,
1122 	IB_CC_CONGESTION_LOG_ENTRY_SWITCH_DLID_F,
1123 	IB_CC_CONGESTION_LOG_ENTRY_SWITCH_SL_F,
1124 	IB_CC_CONGESTION_LOG_ENTRY_SWITCH_TIMESTAMP_F,
1125 	IB_CC_CONGESTION_LOG_ENTRY_SWITCH_LAST_F,
1126 
1127 	/*
1128 	 * CongestionLog (CA) fields
1129 	 */
1130 	IB_CC_CONGESTION_LOG_CA_FIRST_F,
1131 	IB_CC_CONGESTION_LOG_CA_THRESHOLD_EVENT_COUNTER_F = IB_CC_CONGESTION_LOG_CA_FIRST_F,
1132 	IB_CC_CONGESTION_LOG_CA_THRESHOLD_CONGESTION_EVENT_MAP_F,
1133 	IB_CC_CONGESTION_LOG_CA_CURRENT_TIMESTAMP_F,
1134 	IB_CC_CONGESTION_LOG_CA_LAST_F,
1135 
1136 	/*
1137 	 * CongestionLogEvent (CA) fields
1138 	 */
1139 	IB_CC_CONGESTION_LOG_ENTRY_CA_FIRST_F,
1140 	IB_CC_CONGESTION_LOG_ENTRY_CA_LOCAL_QP_CN_ENTRY_F = IB_CC_CONGESTION_LOG_ENTRY_CA_FIRST_F,
1141 	IB_CC_CONGESTION_LOG_ENTRY_CA_SL_CN_ENTRY_F,
1142 	IB_CC_CONGESTION_LOG_ENTRY_CA_SERVICE_TYPE_CN_ENTRY_F,
1143 	IB_CC_CONGESTION_LOG_ENTRY_CA_REMOTE_QP_NUMBER_CN_ENTRY_F,
1144 	IB_CC_CONGESTION_LOG_ENTRY_CA_LOCAL_LID_CN_F,
1145 	IB_CC_CONGESTION_LOG_ENTRY_CA_REMOTE_LID_CN_ENTRY_F,
1146 	IB_CC_CONGESTION_LOG_ENTRY_CA_TIMESTAMP_CN_ENTRY_F,
1147 	IB_CC_CONGESTION_LOG_ENTRY_CA_LAST_F,
1148 
1149 	/*
1150 	 * SwitchCongestionSetting fields
1151 	 */
1152 	IB_CC_SWITCH_CONGESTION_SETTING_FIRST_F,
1153 	IB_CC_SWITCH_CONGESTION_SETTING_CONTROL_MAP_F = IB_CC_SWITCH_CONGESTION_SETTING_FIRST_F,
1154 	IB_CC_SWITCH_CONGESTION_SETTING_VICTIM_MASK_F,
1155 	IB_CC_SWITCH_CONGESTION_SETTING_CREDIT_MASK_F,
1156 	IB_CC_SWITCH_CONGESTION_SETTING_THRESHOLD_F,
1157 	IB_CC_SWITCH_CONGESTION_SETTING_PACKET_SIZE_F,
1158 	IB_CC_SWITCH_CONGESTION_SETTING_CS_THRESHOLD_F,
1159 	IB_CC_SWITCH_CONGESTION_SETTING_CS_RETURN_DELAY_F,
1160 	IB_CC_SWITCH_CONGESTION_SETTING_MARKING_RATE_F,
1161 	IB_CC_SWITCH_CONGESTION_SETTING_LAST_F,
1162 
1163 	/*
1164 	 * SwitchPortCongestionSettingElement fields
1165 	 */
1166 	IB_CC_SWITCH_PORT_CONGESTION_SETTING_ELEMENT_FIRST_F,
1167 	IB_CC_SWITCH_PORT_CONGESTION_SETTING_ELEMENT_VALID_F = IB_CC_SWITCH_PORT_CONGESTION_SETTING_ELEMENT_FIRST_F,
1168 	IB_CC_SWITCH_PORT_CONGESTION_SETTING_ELEMENT_CONTROL_TYPE_F,
1169 	IB_CC_SWITCH_PORT_CONGESTION_SETTING_ELEMENT_THRESHOLD_F,
1170 	IB_CC_SWITCH_PORT_CONGESTION_SETTING_ELEMENT_PACKET_SIZE_F,
1171 	IB_CC_SWITCH_PORT_CONGESTION_SETTING_ELEMENT_CONG_PARM_MARKING_RATE_F,
1172 	IB_CC_SWITCH_PORT_CONGESTION_SETTING_ELEMENT_LAST_F,
1173 
1174 	/*
1175 	 * CACongestionSetting fields
1176 	 */
1177 	IB_CC_CA_CONGESTION_SETTING_FIRST_F,
1178 	IB_CC_CA_CONGESTION_SETTING_PORT_CONTROL_F = IB_CC_CA_CONGESTION_SETTING_FIRST_F,
1179 	IB_CC_CA_CONGESTION_SETTING_CONTROL_MAP_F,
1180 	IB_CC_CA_CONGESTION_SETTING_LAST_F,
1181 
1182 	/*
1183 	 * CACongestionEntry fields
1184 	 */
1185 	IB_CC_CA_CONGESTION_ENTRY_FIRST_F,
1186 	IB_CC_CA_CONGESTION_ENTRY_CCTI_TIMER_F = IB_CC_CA_CONGESTION_ENTRY_FIRST_F,
1187 	IB_CC_CA_CONGESTION_ENTRY_CCTI_INCREASE_F,
1188 	IB_CC_CA_CONGESTION_ENTRY_TRIGGER_THRESHOLD_F,
1189 	IB_CC_CA_CONGESTION_ENTRY_CCTI_MIN_F,
1190 	IB_CC_CA_CONGESTION_ENTRY_LAST_F,
1191 
1192 	/*
1193 	 * CongestionControlTable fields
1194 	 */
1195 	IB_CC_CONGESTION_CONTROL_TABLE_FIRST_F,
1196 	IB_CC_CONGESTION_CONTROL_TABLE_CCTI_LIMIT_F = IB_CC_CONGESTION_CONTROL_TABLE_FIRST_F,
1197 	IB_CC_CONGESTION_CONTROL_TABLE_LAST_F,
1198 
1199 	/*
1200 	 * CongestionControlTableEntry fields
1201 	 */
1202 	IB_CC_CONGESTION_CONTROL_TABLE_ENTRY_FIRST_F,
1203 	IB_CC_CONGESTION_CONTROL_TABLE_ENTRY_CCT_SHIFT_F = IB_CC_CONGESTION_CONTROL_TABLE_ENTRY_FIRST_F,
1204 	IB_CC_CONGESTION_CONTROL_TABLE_ENTRY_CCT_MULTIPLIER_F,
1205 	IB_CC_CONGESTION_CONTROL_TABLE_ENTRY_LAST_F,
1206 
1207 	/*
1208 	 * Timestamp fields
1209 	 */
1210 	IB_CC_TIMESTAMP_FIRST_F,
1211 	IB_CC_TIMESTAMP_F = IB_CC_TIMESTAMP_FIRST_F,
1212 	IB_CC_TIMESTAMP_LAST_F,
1213 
1214 	/*
1215 	 * Node Record
1216 	 */
1217 	IB_SA_NR_FIRST_F,
1218 	IB_SA_NR_LID_F = IB_SA_NR_FIRST_F,
1219 	IB_SA_NR_BASEVER_F,
1220 	IB_SA_NR_CLASSVER_F,
1221 	IB_SA_NR_TYPE_F,
1222 	IB_SA_NR_NPORTS_F,
1223 	IB_SA_NR_SYSTEM_GUID_F,
1224 	IB_SA_NR_GUID_F,
1225 	IB_SA_NR_PORT_GUID_F,
1226 	IB_SA_NR_PARTITION_CAP_F,
1227 	IB_SA_NR_DEVID_F,
1228 	IB_SA_NR_REVISION_F,
1229 	IB_SA_NR_LOCAL_PORT_F,
1230 	IB_SA_NR_VENDORID_F,
1231 	IB_SA_NR_NODEDESC_F,
1232 	IB_SA_NR_LAST_F,
1233 
1234 	/*
1235 	 * PortMirrorRoute fields
1236 	 */
1237 	IB_PMR_FIRST_F,
1238 	IB_PMR_ENCAP_RAW_ETH_TYPE_F = IB_PMR_FIRST_F,
1239 	IB_PMR_MAX_MIRROR_LEN_F,
1240 	IB_PMR_MT_F,
1241 	IB_PMR_BF_F,
1242 	IB_PMR_NM_PORT_F,
1243 	IB_PMR_LRH_VL_F,
1244 	IB_PMR_LRH_LVER_F,
1245 	IB_PMR_LRH_SL_F,
1246 	IB_PMR_LRH_LNH_F,
1247 	IB_PMR_LRH_DLID_F,
1248 	IB_PMR_LRH_LEN_F,
1249 	IB_PMR_LRH_SLID_F,
1250 	IB_PMR_LAST_F,
1251 
1252 	/*
1253 	 * PortMirrorFilter fields
1254 	 */
1255 	IB_PMF_FIRST_F,
1256 	IB_PMF_MIRROR_FILTER0_F = IB_PMF_FIRST_F,
1257 	IB_PMF_MIRROR_FILTER1_F,
1258 	IB_PMF_MIRROR_MASK0_F,
1259 	IB_PMF_MIRROR_MASK1_F,
1260 	IB_PMF_MIRROR_MASK2_F,
1261 	IB_PMF_MIRROR_MASK3_F,
1262 	IB_PMF_B0_F,
1263 	IB_PMF_MIRROR_MASK_OFFS_0,
1264 	IB_PMF_B1_F,
1265 	IB_PMF_MIRROR_MASK_OFFS_1,
1266 	IB_PMF_B2_F,
1267 	IB_PMF_MIRROR_MASK_OFFS_2,
1268 	IB_PMF_B3_F,
1269 	IB_PMF_MIRROR_MASK_OFFS_3,
1270 	IB_PMF_LAST_F,
1271 
1272 	/*
1273 	 * PortMirrorPorts fields
1274 	 */
1275 	IB_PMP_FIRST_F,
1276 	IB_PMP_TQ_1_F = IB_PMP_FIRST_F,
1277 	IB_PMP_RQ_1_F,
1278 	IB_PMP_TQ_2_F,
1279 	IB_PMP_RQ_2_F,
1280 	IB_PMP_TQ_3_F,
1281 	IB_PMP_RQ_3_F,
1282 	IB_PMP_TQ_4_F,
1283 	IB_PMP_RQ_4_F,
1284 	IB_PMP_TQ_5_F,
1285 	IB_PMP_RQ_5_F,
1286 	IB_PMP_TQ_6_F,
1287 	IB_PMP_RQ_6_F,
1288 	IB_PMP_TQ_7_F,
1289 	IB_PMP_RQ_7_F,
1290 	IB_PMP_TQ_8_F,
1291 	IB_PMP_RQ_8_F,
1292 	IB_PMP_TQ_9_F,
1293 	IB_PMP_RQ_9_F,
1294 	IB_PMP_TQ_10_F,
1295 	IB_PMP_RQ_10_F,
1296 	IB_PMP_TQ_11_F,
1297 	IB_PMP_RQ_11_F,
1298 	IB_PMP_TQ_12_F,
1299 	IB_PMP_RQ_12_F,
1300 	IB_PMP_TQ_13_F,
1301 	IB_PMP_RQ_13_F,
1302 	IB_PMP_TQ_14_F,
1303 	IB_PMP_RQ_14_F,
1304 	IB_PMP_TQ_15_F,
1305 	IB_PMP_RQ_15_F,
1306 	IB_PMP_TQ_16_F,
1307 	IB_PMP_RQ_16_F,
1308 	IB_PMP_TQ_17_F,
1309 	IB_PMP_RQ_17_F,
1310 	IB_PMP_TQ_18_F,
1311 	IB_PMP_RQ_18_F,
1312 	IB_PMP_TQ_19_F,
1313 	IB_PMP_RQ_19_F,
1314 	IB_PMP_TQ_20_F,
1315 	IB_PMP_RQ_20_F,
1316 	IB_PMP_TQ_21_F,
1317 	IB_PMP_RQ_21_F,
1318 	IB_PMP_TQ_22_F,
1319 	IB_PMP_RQ_22_F,
1320 	IB_PMP_TQ_23_F,
1321 	IB_PMP_RQ_23_F,
1322 	IB_PMP_TQ_24_F,
1323 	IB_PMP_RQ_24_F,
1324 	IB_PMP_TQ_25_F,
1325 	IB_PMP_RQ_25_F,
1326 	IB_PMP_TQ_26_F,
1327 	IB_PMP_RQ_26_F,
1328 	IB_PMP_TQ_27_F,
1329 	IB_PMP_RQ_27_F,
1330 	IB_PMP_TQ_28_F,
1331 	IB_PMP_RQ_28_F,
1332 	IB_PMP_TQ_29_F,
1333 	IB_PMP_RQ_29_F,
1334 	IB_PMP_TQ_30_F,
1335 	IB_PMP_RQ_30_F,
1336 	IB_PMP_TQ_31_F,
1337 	IB_PMP_RQ_31_F,
1338 	IB_PMP_TQ_32_F,
1339 	IB_PMP_RQ_32_F,
1340 	IB_PMP_TQ_33_F,
1341 	IB_PMP_RQ_33_F,
1342 	IB_PMP_TQ_34_F,
1343 	IB_PMP_RQ_34_F,
1344 	IB_PMP_TQ_35_F,
1345 	IB_PMP_RQ_35_F,
1346 	IB_PMP_TQ_36_F,
1347 	IB_PMP_RQ_36_F,
1348 	IB_PMP_LAST_F,
1349 
1350 	/*
1351 	 * PortSamplesResult fields
1352 	 */
1353 	IB_PSR_TAG_F,
1354 	IB_PSR_SAMPLE_STATUS_F,
1355 	IB_PSR_COUNTER0_F,
1356 	IB_PSR_COUNTER1_F,
1357 	IB_PSR_COUNTER2_F,
1358 	IB_PSR_COUNTER3_F,
1359 	IB_PSR_COUNTER4_F,
1360 	IB_PSR_COUNTER5_F,
1361 	IB_PSR_COUNTER6_F,
1362 	IB_PSR_COUNTER7_F,
1363 	IB_PSR_COUNTER8_F,
1364 	IB_PSR_COUNTER9_F,
1365 	IB_PSR_COUNTER10_F,
1366 	IB_PSR_COUNTER11_F,
1367 	IB_PSR_COUNTER12_F,
1368 	IB_PSR_COUNTER13_F,
1369 	IB_PSR_COUNTER14_F,
1370 	IB_PSR_LAST_F,
1371 
1372 	/*
1373 	 * PortInfoExtended fields
1374 	 */
1375 	IB_PORT_EXT_FIRST_F,
1376 	IB_PORT_EXT_CAPMASK_F = IB_PORT_EXT_FIRST_F,
1377 	IB_PORT_EXT_FEC_MODE_ACTIVE_F,
1378 	IB_PORT_EXT_FDR_FEC_MODE_SUPPORTED_F,
1379 	IB_PORT_EXT_FDR_FEC_MODE_ENABLED_F,
1380 	IB_PORT_EXT_EDR_FEC_MODE_SUPPORTED_F,
1381 	IB_PORT_EXT_EDR_FEC_MODE_ENABLED_F,
1382 	IB_PORT_EXT_LAST_F,
1383 
1384 	/*
1385 	 * PortExtendedSpeedsCounters RSFEC active fields
1386 	 */
1387 	IB_PESC_RSFEC_PORT_SELECT_F,
1388 	IB_PESC_RSFEC_COUNTER_SELECT_F,
1389 	IB_PESC_RSFEC_SYNC_HDR_ERR_CTR_F,
1390 	IB_PESC_RSFEC_UNK_BLOCK_CTR_F,
1391 	IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE0_F,
1392 	IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE1_F,
1393 	IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE2_F,
1394 	IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE3_F,
1395 	IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE4_F,
1396 	IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE5_F,
1397 	IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE6_F,
1398 	IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE7_F,
1399 	IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE8_F,
1400 	IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE9_F,
1401 	IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE10_F,
1402 	IB_PESC_RSFEC_FEC_CORR_SYMBOL_CTR_LANE11_F,
1403 	IB_PESC_PORT_FEC_CORR_BLOCK_CTR_F,
1404 	IB_PESC_PORT_FEC_UNCORR_BLOCK_CTR_F,
1405 	IB_PESC_PORT_FEC_CORR_SYMBOL_CTR_F,
1406 	IB_PESC_RSFEC_LAST_F,
1407 
1408 	/*
1409 	 * More PortCountersExtended fields
1410 	 */
1411 	IB_PC_EXT_COUNTER_SELECT2_F,
1412 	IB_PC_EXT_ERR_SYM_F,
1413 	IB_PC_EXT_LINK_RECOVERS_F,
1414 	IB_PC_EXT_LINK_DOWNED_F,
1415 	IB_PC_EXT_ERR_RCV_F,
1416 	IB_PC_EXT_ERR_PHYSRCV_F,
1417 	IB_PC_EXT_ERR_SWITCH_REL_F,
1418 	IB_PC_EXT_XMT_DISCARDS_F,
1419 	IB_PC_EXT_ERR_XMTCONSTR_F,
1420 	IB_PC_EXT_ERR_RCVCONSTR_F,
1421 	IB_PC_EXT_ERR_LOCALINTEG_F,
1422 	IB_PC_EXT_ERR_EXCESS_OVR_F,
1423 	IB_PC_EXT_VL15_DROPPED_F,
1424 	IB_PC_EXT_XMT_WAIT_F,
1425 	IB_PC_EXT_QP1_DROP_F,
1426 	IB_PC_EXT_ERR_LAST_F,
1427 
1428 	/*
1429 	 * Another PortCounters field
1430 	 */
1431 	IB_PC_QP1_DROP_F,
1432 
1433 	IB_FIELD_LAST_		/* must be last */
1434 };
1435 
1436 /*
1437  * SA RMPP section
1438  */
1439 enum RMPP_TYPE_ENUM {
1440 	IB_RMPP_TYPE_NONE,
1441 	IB_RMPP_TYPE_DATA,
1442 	IB_RMPP_TYPE_ACK,
1443 	IB_RMPP_TYPE_STOP,
1444 	IB_RMPP_TYPE_ABORT,
1445 };
1446 
1447 enum RMPP_FLAGS_ENUM {
1448 	IB_RMPP_FLAG_ACTIVE = 1 << 0,
1449 	IB_RMPP_FLAG_FIRST = 1 << 1,
1450 	IB_RMPP_FLAG_LAST = 1 << 2,
1451 };
1452 
1453 typedef struct {
1454 	int type;
1455 	int flags;
1456 	int status;
1457 	union {
1458 		uint32_t u;
1459 		uint32_t segnum;
1460 	} d1;
1461 	union {
1462 		uint32_t u;
1463 		uint32_t len;
1464 		uint32_t newwin;
1465 	} d2;
1466 } ib_rmpp_hdr_t;
1467 
1468 enum SA_SIZES_ENUM {
1469 	SA_HEADER_SZ = 20,
1470 };
1471 
1472 typedef struct ib_sa_call {
1473 	unsigned attrid;
1474 	unsigned mod;
1475 	uint64_t mask;
1476 	unsigned method;
1477 
1478 	uint64_t trid;		/* used for out mad if nonzero, return real val */
1479 	unsigned recsz;		/* return field */
1480 	ib_rmpp_hdr_t rmpp;
1481 } ib_sa_call_t;
1482 
1483 typedef struct ib_vendor_call {
1484 	unsigned method;
1485 	unsigned mgmt_class;
1486 	unsigned attrid;
1487 	unsigned mod;
1488 	uint32_t oui;
1489 	unsigned timeout;
1490 	ib_rmpp_hdr_t rmpp;
1491 } ib_vendor_call_t;
1492 
1493 typedef struct ib_bm_call {
1494 	unsigned method;
1495 	unsigned attrid;
1496 	unsigned mod;
1497 	unsigned timeout;
1498 	uint64_t bkey;
1499 } ib_bm_call_t;
1500 
1501 #define IB_MIN_UCAST_LID	1
1502 #define IB_MAX_UCAST_LID	(0xc000-1)
1503 #define IB_MIN_MCAST_LID	0xc000
1504 #define IB_MAX_MCAST_LID	(0xffff-1)
1505 
1506 #define IB_LID_VALID(lid)	((lid) >= IB_MIN_UCAST_LID && lid <= IB_MAX_UCAST_LID)
1507 #define IB_MLID_VALID(lid)	((lid) >= IB_MIN_MCAST_LID && lid <= IB_MAX_MCAST_LID)
1508 
1509 #define MAD_DEF_RETRIES		3
1510 #define MAD_DEF_TIMEOUT_MS	1000
1511 
1512 enum MAD_DEST {
1513 	IB_DEST_LID,
1514 	IB_DEST_DRPATH,
1515 	IB_DEST_GUID,
1516 	IB_DEST_DRSLID,
1517 	IB_DEST_GID
1518 };
1519 
1520 enum MAD_NODE_TYPE {
1521 	IB_NODE_CA = 1,
1522 	IB_NODE_SWITCH,
1523 	IB_NODE_ROUTER,
1524 	NODE_RNIC,
1525 
1526 	IB_NODE_MAX = NODE_RNIC
1527 };
1528 
1529 /******************************************************************************/
1530 
1531 /* portid.c */
1532 MAD_EXPORT char *portid2str(ib_portid_t * portid);
1533 MAD_EXPORT int portid2portnum(ib_portid_t * portid);
1534 MAD_EXPORT int str2drpath(ib_dr_path_t * path, char *routepath, int drslid,
1535 			  int drdlid);
1536 MAD_EXPORT char *drpath2str(ib_dr_path_t * path, char *dstr, size_t dstr_size);
1537 
ib_portid_set(ib_portid_t * portid,int lid,int qp,int qkey)1538 static inline int ib_portid_set(ib_portid_t * portid, int lid, int qp, int qkey)
1539 {
1540 	portid->lid = lid;
1541 	portid->qp = qp;
1542 	portid->qkey = qkey;
1543 	portid->grh_present = 0;
1544 
1545 	return 0;
1546 }
1547 
1548 /* fields.c */
1549 MAD_EXPORT uint32_t mad_get_field(void *buf, int base_offs,
1550 				  enum MAD_FIELDS field);
1551 MAD_EXPORT void mad_set_field(void *buf, int base_offs, enum MAD_FIELDS field,
1552 			      uint32_t val);
1553 /* field must be byte aligned */
1554 MAD_EXPORT uint64_t mad_get_field64(void *buf, int base_offs,
1555 				    enum MAD_FIELDS field);
1556 MAD_EXPORT void mad_set_field64(void *buf, int base_offs, enum MAD_FIELDS field,
1557 				uint64_t val);
1558 MAD_EXPORT void mad_set_array(void *buf, int base_offs, enum MAD_FIELDS field,
1559 			      void *val);
1560 MAD_EXPORT void mad_get_array(void *buf, int base_offs, enum MAD_FIELDS field,
1561 			      void *val);
1562 MAD_EXPORT void mad_decode_field(uint8_t * buf, enum MAD_FIELDS field,
1563 				 void *val);
1564 MAD_EXPORT void mad_encode_field(uint8_t * buf, enum MAD_FIELDS field,
1565 				 void *val);
1566 MAD_EXPORT int mad_print_field(enum MAD_FIELDS field, const char *name,
1567 			       void *val);
1568 MAD_EXPORT char *mad_dump_field(enum MAD_FIELDS field, char *buf, int bufsz,
1569 				void *val);
1570 MAD_EXPORT char *mad_dump_val(enum MAD_FIELDS field, char *buf, int bufsz,
1571 			      void *val);
1572 MAD_EXPORT const char *mad_field_name(enum MAD_FIELDS field);
1573 
1574 /* mad.c */
1575 MAD_EXPORT void *mad_encode(void *buf, ib_rpc_t * rpc, ib_dr_path_t * drpath,
1576 			    void *data);
1577 MAD_EXPORT uint64_t mad_trid(void);
1578 MAD_EXPORT int mad_build_pkt(void *umad, ib_rpc_t * rpc, ib_portid_t * dport,
1579 			     ib_rmpp_hdr_t * rmpp, void *data);
1580 
1581 /* New interface */
1582 MAD_EXPORT void madrpc_show_errors(int set);
1583 MAD_EXPORT int madrpc_set_retries(int retries);
1584 MAD_EXPORT int madrpc_set_timeout(int timeout);
1585 MAD_EXPORT struct ibmad_port *mad_rpc_open_port(char *dev_name, int dev_port,
1586 						int *mgmt_classes,
1587 						int num_classes);
1588 MAD_EXPORT void mad_rpc_close_port(struct ibmad_port *srcport);
1589 
1590 /*
1591  * On redirection, the dport argument is updated with the redirection target,
1592  * so subsequent MADs will not go through the redirection process again but
1593  * reach the target directly.
1594  */
1595 MAD_EXPORT void *mad_rpc(const struct ibmad_port *srcport, ib_rpc_t * rpc,
1596 			 ib_portid_t * dport, void *payload, void *rcvdata);
1597 
1598 MAD_EXPORT void *mad_rpc_rmpp(const struct ibmad_port *srcport, ib_rpc_t * rpc,
1599 			      ib_portid_t * dport, ib_rmpp_hdr_t * rmpp,
1600 			      void *data);
1601 MAD_EXPORT int mad_rpc_portid(struct ibmad_port *srcport);
1602 MAD_EXPORT void mad_rpc_set_retries(struct ibmad_port *port, int retries);
1603 MAD_EXPORT void mad_rpc_set_timeout(struct ibmad_port *port, int timeout);
1604 MAD_EXPORT int mad_rpc_class_agent(struct ibmad_port *srcport, int cls);
1605 
1606 MAD_EXPORT int mad_get_timeout(const struct ibmad_port *srcport,
1607 			       int override_ms);
1608 MAD_EXPORT int mad_get_retries(const struct ibmad_port *srcport);
1609 
1610 /* register.c */
1611 MAD_EXPORT int mad_register_port_client(int port_id, int mgmt,
1612 					uint8_t rmpp_version);
1613 MAD_EXPORT int mad_register_client(int mgmt, uint8_t rmpp_version) DEPRECATED;
1614 MAD_EXPORT int mad_register_server(int mgmt, uint8_t rmpp_version,
1615 				   long method_mask[16 / sizeof(long)],
1616 				   uint32_t class_oui) DEPRECATED;
1617 /* register.c new interface */
1618 MAD_EXPORT int mad_register_client_via(int mgmt, uint8_t rmpp_version,
1619 				       struct ibmad_port *srcport);
1620 MAD_EXPORT int mad_register_server_via(int mgmt, uint8_t rmpp_version,
1621 				       long method_mask[16 / sizeof(long)],
1622 				       uint32_t class_oui,
1623 				       struct ibmad_port *srcport);
1624 MAD_EXPORT int mad_class_agent(int mgmt) DEPRECATED;
1625 
1626 /* serv.c */
1627 MAD_EXPORT int mad_send(ib_rpc_t * rpc, ib_portid_t * dport,
1628 			ib_rmpp_hdr_t * rmpp, void *data) DEPRECATED;
1629 MAD_EXPORT void *mad_receive(void *umad, int timeout) DEPRECATED;
1630 MAD_EXPORT int mad_respond(void *umad, ib_portid_t * portid, uint32_t rstatus)
1631     DEPRECATED;
1632 
1633 /* serv.c new interface */
1634 MAD_EXPORT int mad_send_via(ib_rpc_t * rpc, ib_portid_t * dport,
1635 			    ib_rmpp_hdr_t * rmpp, void *data,
1636 			    struct ibmad_port *srcport);
1637 MAD_EXPORT void *mad_receive_via(void *umad, int timeout,
1638 				 struct ibmad_port *srcport);
1639 MAD_EXPORT int mad_respond_via(void *umad, ib_portid_t * portid,
1640 			       uint32_t rstatus, struct ibmad_port *srcport);
1641 MAD_EXPORT void *mad_alloc(void);
1642 MAD_EXPORT void mad_free(void *umad);
1643 
1644 /* vendor.c */
1645 MAD_EXPORT uint8_t *ib_vendor_call(void *data, ib_portid_t * portid,
1646 				   ib_vendor_call_t * call) DEPRECATED;
1647 
1648 /* vendor.c new interface */
1649 MAD_EXPORT uint8_t *ib_vendor_call_via(void *data, ib_portid_t * portid,
1650 				       ib_vendor_call_t * call,
1651 				       struct ibmad_port *srcport);
1652 
mad_is_vendor_range1(int mgmt)1653 static inline int mad_is_vendor_range1(int mgmt)
1654 {
1655 	return mgmt >= 0x9 && mgmt <= 0xf;
1656 }
1657 
mad_is_vendor_range2(int mgmt)1658 static inline int mad_is_vendor_range2(int mgmt)
1659 {
1660 	return mgmt >= 0x30 && mgmt <= 0x4f;
1661 }
1662 
1663 /* rpc.c */
1664 MAD_EXPORT int madrpc_portid(void) DEPRECATED;
1665 void *madrpc(ib_rpc_t * rpc, ib_portid_t * dport, void *payload, void *rcvdata)
1666     DEPRECATED;
1667 void *madrpc_rmpp(ib_rpc_t * rpc, ib_portid_t * dport, ib_rmpp_hdr_t * rmpp,
1668 		  void *data) DEPRECATED;
1669 MAD_EXPORT void madrpc_init(char *dev_name, int dev_port, int *mgmt_classes,
1670 			    int num_classes) DEPRECATED;
1671 void madrpc_save_mad(void *madbuf, int len) DEPRECATED;
1672 
1673 /* smp.c */
1674 MAD_EXPORT uint8_t *smp_query(void *buf, ib_portid_t * id, unsigned attrid,
1675 			      unsigned mod, unsigned timeout) DEPRECATED;
1676 MAD_EXPORT uint8_t *smp_set(void *buf, ib_portid_t * id, unsigned attrid,
1677 			    unsigned mod, unsigned timeout) DEPRECATED;
1678 
1679 /* smp.c new interface */
1680 MAD_EXPORT uint8_t *smp_query_via(void *buf, ib_portid_t * id, unsigned attrid,
1681 				  unsigned mod, unsigned timeout,
1682 				  const struct ibmad_port *srcport);
1683 MAD_EXPORT uint8_t *smp_set_via(void *buf, ib_portid_t * id, unsigned attrid,
1684 				unsigned mod, unsigned timeout,
1685 				const struct ibmad_port *srcport);
1686 MAD_EXPORT uint8_t *smp_query_status_via(void *rcvbuf, ib_portid_t * portid,
1687 					 unsigned attrid, unsigned mod,
1688 					 unsigned timeout, int *rstatus,
1689 					 const struct ibmad_port *srcport);
1690 MAD_EXPORT uint8_t *smp_set_status_via(void *data, ib_portid_t * portid,
1691 				       unsigned attrid, unsigned mod,
1692 				       unsigned timeout, int *rstatus,
1693 				       const struct ibmad_port *srcport);
1694 MAD_EXPORT void smp_mkey_set(struct ibmad_port *srcport, uint64_t mkey);
1695 MAD_EXPORT uint64_t smp_mkey_get(const struct ibmad_port *srcport);
1696 
1697 /* cc.c */
1698 MAD_EXPORT void *cc_query_status_via(void *rcvbuf, ib_portid_t * portid,
1699 				     unsigned attrid, unsigned mod, unsigned timeout,
1700 				     int *rstatus, const struct ibmad_port * srcport,
1701 				     uint64_t cckey);
1702 
1703 MAD_EXPORT void *cc_config_status_via(void *payload, void *rcvbuf, ib_portid_t * portid,
1704 				      unsigned attrid, unsigned mod, unsigned timeout,
1705 				      int *rstatus, const struct ibmad_port * srcport,
1706 				      uint64_t cckey);
1707 
1708 /* sa.c */
1709 uint8_t *sa_call(void *rcvbuf, ib_portid_t * portid, ib_sa_call_t * sa,
1710 		 unsigned timeout) DEPRECATED;
1711 MAD_EXPORT int ib_path_query(ibmad_gid_t srcgid, ibmad_gid_t destgid,
1712 			     ib_portid_t * sm_id, void *buf) DEPRECATED;
1713 
1714 /* sa.c new interface */
1715 MAD_EXPORT uint8_t *sa_rpc_call(const struct ibmad_port *srcport, void *rcvbuf,
1716 				ib_portid_t * portid, ib_sa_call_t * sa,
1717 				unsigned timeout);
1718 MAD_EXPORT int ib_path_query_via(const struct ibmad_port *srcport,
1719 				 ibmad_gid_t srcgid, ibmad_gid_t destgid,
1720 				 ib_portid_t * sm_id, void *buf);
1721 	/* returns lid */
1722 MAD_EXPORT int ib_node_query_via(const struct ibmad_port *srcport,
1723 				 uint64_t guid, ib_portid_t * sm_id,
1724 				 void *buf);
1725 
1726 /* resolve.c */
1727 MAD_EXPORT int ib_resolve_smlid(ib_portid_t * sm_id, int timeout) DEPRECATED;
1728 MAD_EXPORT int ib_resolve_portid_str(ib_portid_t * portid, char *addr_str,
1729 				     enum MAD_DEST dest, ib_portid_t * sm_id)
1730     DEPRECATED;
1731 MAD_EXPORT int ib_resolve_self(ib_portid_t * portid, int *portnum,
1732 			       ibmad_gid_t * gid) DEPRECATED;
1733 
1734 /* resolve.c new interface */
1735 MAD_EXPORT int ib_resolve_smlid_via(ib_portid_t * sm_id, int timeout,
1736 				    const struct ibmad_port *srcport);
1737 MAD_EXPORT int ib_resolve_guid_via(ib_portid_t * portid, uint64_t * guid,
1738 				   ib_portid_t * sm_id, int timeout,
1739 				   const struct ibmad_port *srcport);
1740 MAD_EXPORT int ib_resolve_gid_via(ib_portid_t * portid, ibmad_gid_t gid,
1741 				  ib_portid_t * sm_id, int timeout,
1742 				  const struct ibmad_port *srcport);
1743 MAD_EXPORT int ib_resolve_portid_str_via(ib_portid_t * portid, char *addr_str,
1744 					 enum MAD_DEST dest,
1745 					 ib_portid_t * sm_id,
1746 					 const struct ibmad_port *srcport);
1747 MAD_EXPORT int ib_resolve_self_via(ib_portid_t * portid, int *portnum,
1748 				   ibmad_gid_t * gid,
1749 				   const struct ibmad_port *srcport);
1750 
1751 /* gs.c new interface */
1752 MAD_EXPORT uint8_t *pma_query_via(void *rcvbuf, ib_portid_t * dest, int port,
1753 				  unsigned timeout, unsigned id,
1754 				  const struct ibmad_port *srcport);
1755 MAD_EXPORT uint8_t *performance_reset_via(void *rcvbuf, ib_portid_t * dest,
1756 					  int port, unsigned mask,
1757 					  unsigned timeout, unsigned id,
1758 					  const struct ibmad_port *srcport);
1759 
1760 /* bm.c */
1761 MAD_EXPORT uint8_t *bm_call_via(void *data, ib_portid_t * portid,
1762 				ib_bm_call_t * call,
1763 				struct ibmad_port *srcport);
1764 
1765 /* dump.c */
1766 MAD_EXPORT ib_mad_dump_fn
1767     mad_dump_int, mad_dump_uint, mad_dump_hex, mad_dump_rhex,
1768     mad_dump_bitfield, mad_dump_array, mad_dump_string,
1769     mad_dump_linkwidth, mad_dump_linkwidthsup, mad_dump_linkwidthen,
1770     mad_dump_linkdowndefstate,
1771     mad_dump_linkspeed, mad_dump_linkspeedsup, mad_dump_linkspeeden,
1772     mad_dump_linkspeedext, mad_dump_linkspeedextsup, mad_dump_linkspeedexten,
1773     mad_dump_portstate, mad_dump_portstates,
1774     mad_dump_physportstate, mad_dump_portcapmask, mad_dump_portcapmask2,
1775     mad_dump_mtu, mad_dump_vlcap, mad_dump_opervls,
1776     mad_dump_node_type, mad_dump_sltovl, mad_dump_vlarbitration,
1777     mad_dump_nodedesc, mad_dump_nodeinfo, mad_dump_portinfo,
1778     mad_dump_switchinfo, mad_dump_perfcounters, mad_dump_perfcounters_ext,
1779     mad_dump_perfcounters_xmt_sl, mad_dump_perfcounters_rcv_sl,
1780     mad_dump_perfcounters_xmt_disc, mad_dump_perfcounters_rcv_err,
1781     mad_dump_portsamples_control, mad_dump_port_ext_speeds_counters,
1782     mad_dump_perfcounters_port_op_rcv_counters, mad_dump_perfcounters_port_flow_ctl_counters,
1783     mad_dump_perfcounters_port_vl_op_packet, mad_dump_perfcounters_port_vl_op_data,
1784     mad_dump_perfcounters_port_vl_xmit_flow_ctl_update_errors, mad_dump_perfcounters_port_vl_xmit_wait_counters,
1785     mad_dump_perfcounters_sw_port_vl_congestion, mad_dump_perfcounters_rcv_con_ctrl,
1786     mad_dump_perfcounters_sl_rcv_fecn, mad_dump_perfcounters_sl_rcv_becn,
1787     mad_dump_perfcounters_xmit_con_ctrl, mad_dump_perfcounters_vl_xmit_time_cong,
1788     mad_dump_mlnx_ext_port_info, mad_dump_cc_congestioninfo, mad_dump_cc_congestionkeyinfo,
1789     mad_dump_cc_congestionlog, mad_dump_cc_congestionlogswitch,
1790     mad_dump_cc_congestionlogentryswitch, mad_dump_cc_congestionlogca,
1791     mad_dump_cc_congestionlogentryca, mad_dump_cc_switchcongestionsetting,
1792     mad_dump_cc_switchportcongestionsettingelement, mad_dump_cc_cacongestionsetting,
1793     mad_dump_cc_cacongestionentry, mad_dump_cc_congestioncontroltable,
1794     mad_dump_cc_congestioncontroltableentry, mad_dump_cc_timestamp,
1795     mad_dump_classportinfo,  mad_dump_portmirror_route,
1796     mad_dump_portmirror_ports, mad_dump_portsamples_result,
1797     mad_dump_portinfo_ext, mad_dump_port_ext_speeds_counters_rsfec_active;
1798 
1799 MAD_EXPORT void mad_dump_fields(char *buf, int bufsz, void *val, int valsz,
1800 				int start, int end);
1801 
1802 extern MAD_EXPORT int ibdebug;
1803 
1804 #if __BYTE_ORDER == __LITTLE_ENDIAN
1805 #ifndef ntohll
1806 #define ntohll bswap_64
1807 #endif
1808 #ifndef htonll
1809 #define htonll bswap_64
1810 #endif
1811 #elif __BYTE_ORDER == __BIG_ENDIAN
1812 #ifndef ntohll
1813 #define ntohll(x) (x)
1814 #endif
1815 #ifndef htonll
1816 #define htonll(x) (x)
1817 #endif
1818 #endif				/* __BYTE_ORDER == __BIG_ENDIAN */
1819 
1820 /* Misc. macros: */
1821 /** align value \a l to \a size (ceil) */
1822 #define ALIGN(l, size) (((l) + ((size) - 1)) / (size) * (size))
1823 
1824 /** printf style warning MACRO, includes name of function and pid */
1825 #define IBWARN(fmt, ...) fprintf(stderr, "ibwarn: [%d] %s: " fmt "\n", \
1826 (int)getpid(), __func__, ## __VA_ARGS__)
1827 
1828 #define IBDEBUG(fmt, ...) fprintf(stdout, "ibdebug: [%d] %s: " fmt "\n", \
1829 (int)getpid(), __func__, ## __VA_ARGS__)
1830 
1831 #define IBVERBOSE(fmt, ...) fprintf(stdout, "[%d] %s: " fmt "\n", \
1832 (int)getpid(), __func__, ## __VA_ARGS__)
1833 
1834 #define IBPANIC(fmt, ...) do { \
1835 	fprintf(stderr, "ibpanic: [%d] %s: " fmt ": %m\n", \
1836 	(int)getpid(), __func__, ## __VA_ARGS__); \
1837 	exit(-1); \
1838 } while(0)
1839 
1840 MAD_EXPORT void xdump(FILE * file, char *msg, void *p, int size);
1841 
1842 END_C_DECLS
1843 #endif				/* _MAD_H_ */
1844