ib_pma.h 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. /*
  2. * Copyright (c) 2006, 2007, 2008, 2009, 2010 QLogic Corporation.
  3. * All rights reserved.
  4. * Copyright (c) 2005, 2006 PathScale, Inc. 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. #if !defined(IB_PMA_H)
  35. #define IB_PMA_H
  36. #include <rdma/ib_mad.h>
  37. /*
  38. * PMA class portinfo capability mask bits
  39. */
  40. #define IB_PMA_CLASS_CAP_ALLPORTSELECT cpu_to_be16(1 << 8)
  41. #define IB_PMA_CLASS_CAP_EXT_WIDTH cpu_to_be16(1 << 9)
  42. #define IB_PMA_CLASS_CAP_EXT_WIDTH_NOIETF cpu_to_be16(1 << 10)
  43. #define IB_PMA_CLASS_CAP_XMIT_WAIT cpu_to_be16(1 << 12)
  44. #define IB_PMA_CLASS_PORT_INFO cpu_to_be16(0x0001)
  45. #define IB_PMA_PORT_SAMPLES_CONTROL cpu_to_be16(0x0010)
  46. #define IB_PMA_PORT_SAMPLES_RESULT cpu_to_be16(0x0011)
  47. #define IB_PMA_PORT_COUNTERS cpu_to_be16(0x0012)
  48. #define IB_PMA_PORT_COUNTERS_EXT cpu_to_be16(0x001D)
  49. #define IB_PMA_PORT_SAMPLES_RESULT_EXT cpu_to_be16(0x001E)
  50. struct ib_pma_mad {
  51. struct ib_mad_hdr mad_hdr;
  52. u8 reserved[40];
  53. u8 data[192];
  54. } __packed;
  55. struct ib_pma_portsamplescontrol {
  56. u8 opcode;
  57. u8 port_select;
  58. u8 tick;
  59. u8 counter_width; /* resv: 7:3, counter width: 2:0 */
  60. __be32 counter_mask0_9; /* 2, 10 3-bit fields */
  61. __be16 counter_mask10_14; /* 1, 5 3-bit fields */
  62. u8 sample_mechanisms;
  63. u8 sample_status; /* only lower 2 bits */
  64. __be64 option_mask;
  65. __be64 vendor_mask;
  66. __be32 sample_start;
  67. __be32 sample_interval;
  68. __be16 tag;
  69. __be16 counter_select[15];
  70. __be32 reserved1;
  71. __be64 samples_only_option_mask;
  72. __be32 reserved2[28];
  73. };
  74. struct ib_pma_portsamplesresult {
  75. __be16 tag;
  76. __be16 sample_status; /* only lower 2 bits */
  77. __be32 counter[15];
  78. };
  79. struct ib_pma_portsamplesresult_ext {
  80. __be16 tag;
  81. __be16 sample_status; /* only lower 2 bits */
  82. __be32 extended_width; /* only upper 2 bits */
  83. __be64 counter[15];
  84. };
  85. struct ib_pma_portcounters {
  86. u8 reserved;
  87. u8 port_select;
  88. __be16 counter_select;
  89. __be16 symbol_error_counter;
  90. u8 link_error_recovery_counter;
  91. u8 link_downed_counter;
  92. __be16 port_rcv_errors;
  93. __be16 port_rcv_remphys_errors;
  94. __be16 port_rcv_switch_relay_errors;
  95. __be16 port_xmit_discards;
  96. u8 port_xmit_constraint_errors;
  97. u8 port_rcv_constraint_errors;
  98. u8 reserved1;
  99. u8 link_overrun_errors; /* LocalLink: 7:4, BufferOverrun: 3:0 */
  100. __be16 reserved2;
  101. __be16 vl15_dropped;
  102. __be32 port_xmit_data;
  103. __be32 port_rcv_data;
  104. __be32 port_xmit_packets;
  105. __be32 port_rcv_packets;
  106. __be32 port_xmit_wait;
  107. } __packed;
  108. #define IB_PMA_SEL_SYMBOL_ERROR cpu_to_be16(0x0001)
  109. #define IB_PMA_SEL_LINK_ERROR_RECOVERY cpu_to_be16(0x0002)
  110. #define IB_PMA_SEL_LINK_DOWNED cpu_to_be16(0x0004)
  111. #define IB_PMA_SEL_PORT_RCV_ERRORS cpu_to_be16(0x0008)
  112. #define IB_PMA_SEL_PORT_RCV_REMPHYS_ERRORS cpu_to_be16(0x0010)
  113. #define IB_PMA_SEL_PORT_XMIT_DISCARDS cpu_to_be16(0x0040)
  114. #define IB_PMA_SEL_LOCAL_LINK_INTEGRITY_ERRORS cpu_to_be16(0x0200)
  115. #define IB_PMA_SEL_EXCESSIVE_BUFFER_OVERRUNS cpu_to_be16(0x0400)
  116. #define IB_PMA_SEL_PORT_VL15_DROPPED cpu_to_be16(0x0800)
  117. #define IB_PMA_SEL_PORT_XMIT_DATA cpu_to_be16(0x1000)
  118. #define IB_PMA_SEL_PORT_RCV_DATA cpu_to_be16(0x2000)
  119. #define IB_PMA_SEL_PORT_XMIT_PACKETS cpu_to_be16(0x4000)
  120. #define IB_PMA_SEL_PORT_RCV_PACKETS cpu_to_be16(0x8000)
  121. struct ib_pma_portcounters_ext {
  122. u8 reserved;
  123. u8 port_select;
  124. __be16 counter_select;
  125. __be32 reserved1;
  126. __be64 port_xmit_data;
  127. __be64 port_rcv_data;
  128. __be64 port_xmit_packets;
  129. __be64 port_rcv_packets;
  130. __be64 port_unicast_xmit_packets;
  131. __be64 port_unicast_rcv_packets;
  132. __be64 port_multicast_xmit_packets;
  133. __be64 port_multicast_rcv_packets;
  134. } __packed;
  135. #define IB_PMA_SELX_PORT_XMIT_DATA cpu_to_be16(0x0001)
  136. #define IB_PMA_SELX_PORT_RCV_DATA cpu_to_be16(0x0002)
  137. #define IB_PMA_SELX_PORT_XMIT_PACKETS cpu_to_be16(0x0004)
  138. #define IB_PMA_SELX_PORT_RCV_PACKETS cpu_to_be16(0x0008)
  139. #define IB_PMA_SELX_PORT_UNI_XMIT_PACKETS cpu_to_be16(0x0010)
  140. #define IB_PMA_SELX_PORT_UNI_RCV_PACKETS cpu_to_be16(0x0020)
  141. #define IB_PMA_SELX_PORT_MULTI_XMIT_PACKETS cpu_to_be16(0x0040)
  142. #define IB_PMA_SELX_PORT_MULTI_RCV_PACKETS cpu_to_be16(0x0080)
  143. #endif /* IB_PMA_H */