opa_port_info.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433
  1. /*
  2. * Copyright (c) 2014 Intel Corporation. All rights reserved.
  3. *
  4. * This software is available to you under a choice of one of two
  5. * licenses. You may choose to be licensed under the terms of the GNU
  6. * General Public License (GPL) Version 2, available from the file
  7. * COPYING in the main directory of this source tree, or the
  8. * OpenIB.org BSD license below:
  9. *
  10. * Redistribution and use in source and binary forms, with or
  11. * without modification, are permitted provided that the following
  12. * conditions are met:
  13. *
  14. * - Redistributions of source code must retain the above
  15. * copyright notice, this list of conditions and the following
  16. * disclaimer.
  17. *
  18. * - Redistributions in binary form must reproduce the above
  19. * copyright notice, this list of conditions and the following
  20. * disclaimer in the documentation and/or other materials
  21. * provided with the distribution.
  22. *
  23. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  24. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  25. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  26. * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
  27. * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  28. * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  29. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  30. * SOFTWARE.
  31. */
  32. #if !defined(OPA_PORT_INFO_H)
  33. #define OPA_PORT_INFO_H
  34. /* Temporary until HFI driver is updated */
  35. #ifndef USE_PI_LED_ENABLE
  36. #define USE_PI_LED_ENABLE 0
  37. #endif
  38. #define OPA_PORT_LINK_MODE_NOP 0 /* No change */
  39. #define OPA_PORT_LINK_MODE_OPA 4 /* Port mode is OPA */
  40. #define OPA_PORT_PACKET_FORMAT_NOP 0 /* No change */
  41. #define OPA_PORT_PACKET_FORMAT_8B 1 /* Format 8B */
  42. #define OPA_PORT_PACKET_FORMAT_9B 2 /* Format 9B */
  43. #define OPA_PORT_PACKET_FORMAT_10B 4 /* Format 10B */
  44. #define OPA_PORT_PACKET_FORMAT_16B 8 /* Format 16B */
  45. #define OPA_PORT_LTP_CRC_MODE_NONE 0 /* No change */
  46. #define OPA_PORT_LTP_CRC_MODE_14 1 /* 14-bit LTP CRC mode (optional) */
  47. #define OPA_PORT_LTP_CRC_MODE_16 2 /* 16-bit LTP CRC mode */
  48. #define OPA_PORT_LTP_CRC_MODE_48 4 /* 48-bit LTP CRC mode (optional) */
  49. #define OPA_PORT_LTP_CRC_MODE_PER_LANE 8 /* 12/16-bit per lane LTP CRC mode */
  50. /* Link Down / Neighbor Link Down Reason; indicated as follows: */
  51. #define OPA_LINKDOWN_REASON_NONE 0 /* No specified reason */
  52. #define OPA_LINKDOWN_REASON_RCV_ERROR_0 1
  53. #define OPA_LINKDOWN_REASON_BAD_PKT_LEN 2
  54. #define OPA_LINKDOWN_REASON_PKT_TOO_LONG 3
  55. #define OPA_LINKDOWN_REASON_PKT_TOO_SHORT 4
  56. #define OPA_LINKDOWN_REASON_BAD_SLID 5
  57. #define OPA_LINKDOWN_REASON_BAD_DLID 6
  58. #define OPA_LINKDOWN_REASON_BAD_L2 7
  59. #define OPA_LINKDOWN_REASON_BAD_SC 8
  60. #define OPA_LINKDOWN_REASON_RCV_ERROR_8 9
  61. #define OPA_LINKDOWN_REASON_BAD_MID_TAIL 10
  62. #define OPA_LINKDOWN_REASON_RCV_ERROR_10 11
  63. #define OPA_LINKDOWN_REASON_PREEMPT_ERROR 12
  64. #define OPA_LINKDOWN_REASON_PREEMPT_VL15 13
  65. #define OPA_LINKDOWN_REASON_BAD_VL_MARKER 14
  66. #define OPA_LINKDOWN_REASON_RCV_ERROR_14 15
  67. #define OPA_LINKDOWN_REASON_RCV_ERROR_15 16
  68. #define OPA_LINKDOWN_REASON_BAD_HEAD_DIST 17
  69. #define OPA_LINKDOWN_REASON_BAD_TAIL_DIST 18
  70. #define OPA_LINKDOWN_REASON_BAD_CTRL_DIST 19
  71. #define OPA_LINKDOWN_REASON_BAD_CREDIT_ACK 20
  72. #define OPA_LINKDOWN_REASON_UNSUPPORTED_VL_MARKER 21
  73. #define OPA_LINKDOWN_REASON_BAD_PREEMPT 22
  74. #define OPA_LINKDOWN_REASON_BAD_CONTROL_FLIT 23
  75. #define OPA_LINKDOWN_REASON_EXCEED_MULTICAST_LIMIT 24
  76. #define OPA_LINKDOWN_REASON_RCV_ERROR_24 25
  77. #define OPA_LINKDOWN_REASON_RCV_ERROR_25 26
  78. #define OPA_LINKDOWN_REASON_RCV_ERROR_26 27
  79. #define OPA_LINKDOWN_REASON_RCV_ERROR_27 28
  80. #define OPA_LINKDOWN_REASON_RCV_ERROR_28 29
  81. #define OPA_LINKDOWN_REASON_RCV_ERROR_29 30
  82. #define OPA_LINKDOWN_REASON_RCV_ERROR_30 31
  83. #define OPA_LINKDOWN_REASON_EXCESSIVE_BUFFER_OVERRUN 32
  84. #define OPA_LINKDOWN_REASON_UNKNOWN 33
  85. /* 34 -reserved */
  86. #define OPA_LINKDOWN_REASON_REBOOT 35
  87. #define OPA_LINKDOWN_REASON_NEIGHBOR_UNKNOWN 36
  88. /* 37-38 reserved */
  89. #define OPA_LINKDOWN_REASON_FM_BOUNCE 39
  90. #define OPA_LINKDOWN_REASON_SPEED_POLICY 40
  91. #define OPA_LINKDOWN_REASON_WIDTH_POLICY 41
  92. /* 42-48 reserved */
  93. #define OPA_LINKDOWN_REASON_DISCONNECTED 49
  94. #define OPA_LINKDOWN_REASONLOCAL_MEDIA_NOT_INSTALLED 50
  95. #define OPA_LINKDOWN_REASON_NOT_INSTALLED 51
  96. #define OPA_LINKDOWN_REASON_CHASSIS_CONFIG 52
  97. /* 53 reserved */
  98. #define OPA_LINKDOWN_REASON_END_TO_END_NOT_INSTALLED 54
  99. /* 55 reserved */
  100. #define OPA_LINKDOWN_REASON_POWER_POLICY 56
  101. #define OPA_LINKDOWN_REASON_LINKSPEED_POLICY 57
  102. #define OPA_LINKDOWN_REASON_LINKWIDTH_POLICY 58
  103. /* 59 reserved */
  104. #define OPA_LINKDOWN_REASON_SWITCH_MGMT 60
  105. #define OPA_LINKDOWN_REASON_SMA_DISABLED 61
  106. /* 62 reserved */
  107. #define OPA_LINKDOWN_REASON_TRANSIENT 63
  108. /* 64-255 reserved */
  109. /* OPA Link Init reason; indicated as follows: */
  110. /* 3-7; 11-15 reserved; 8-15 cleared on Polling->LinkUp */
  111. #define OPA_LINKINIT_REASON_NOP 0
  112. #define OPA_LINKINIT_REASON_LINKUP (1 << 4)
  113. #define OPA_LINKINIT_REASON_FLAPPING (2 << 4)
  114. #define OPA_LINKINIT_REASON_CLEAR (8 << 4)
  115. #define OPA_LINKINIT_OUTSIDE_POLICY (8 << 4)
  116. #define OPA_LINKINIT_QUARANTINED (9 << 4)
  117. #define OPA_LINKINIT_INSUFIC_CAPABILITY (10 << 4)
  118. #define OPA_LINK_SPEED_NOP 0x0000 /* Reserved (1-5 Gbps) */
  119. #define OPA_LINK_SPEED_12_5G 0x0001 /* 12.5 Gbps */
  120. #define OPA_LINK_SPEED_25G 0x0002 /* 25.78125? Gbps (EDR) */
  121. #define OPA_LINK_WIDTH_1X 0x0001
  122. #define OPA_LINK_WIDTH_2X 0x0002
  123. #define OPA_LINK_WIDTH_3X 0x0004
  124. #define OPA_LINK_WIDTH_4X 0x0008
  125. #define OPA_CAP_MASK3_IsSnoopSupported (1 << 7)
  126. #define OPA_CAP_MASK3_IsAsyncSC2VLSupported (1 << 6)
  127. #define OPA_CAP_MASK3_IsAddrRangeConfigSupported (1 << 5)
  128. #define OPA_CAP_MASK3_IsPassThroughSupported (1 << 4)
  129. #define OPA_CAP_MASK3_IsSharedSpaceSupported (1 << 3)
  130. /* reserved (1 << 2) */
  131. #define OPA_CAP_MASK3_IsVLMarkerSupported (1 << 1)
  132. #define OPA_CAP_MASK3_IsVLrSupported (1 << 0)
  133. /**
  134. * new MTU values
  135. */
  136. enum {
  137. OPA_MTU_8192 = 6,
  138. OPA_MTU_10240 = 7,
  139. };
  140. enum {
  141. OPA_PORT_PHYS_CONF_DISCONNECTED = 0,
  142. OPA_PORT_PHYS_CONF_STANDARD = 1,
  143. OPA_PORT_PHYS_CONF_FIXED = 2,
  144. OPA_PORT_PHYS_CONF_VARIABLE = 3,
  145. OPA_PORT_PHYS_CONF_SI_PHOTO = 4
  146. };
  147. enum port_info_field_masks {
  148. /* vl.cap */
  149. OPA_PI_MASK_VL_CAP = 0x1F,
  150. /* port_states.ledenable_offlinereason */
  151. OPA_PI_MASK_OFFLINE_REASON = 0x0F,
  152. OPA_PI_MASK_LED_ENABLE = 0x40,
  153. /* port_states.unsleepstate_downdefstate */
  154. OPA_PI_MASK_UNSLEEP_STATE = 0xF0,
  155. OPA_PI_MASK_DOWNDEF_STATE = 0x0F,
  156. /* port_states.portphysstate_portstate */
  157. OPA_PI_MASK_PORT_PHYSICAL_STATE = 0xF0,
  158. OPA_PI_MASK_PORT_STATE = 0x0F,
  159. /* port_phys_conf */
  160. OPA_PI_MASK_PORT_PHYSICAL_CONF = 0x0F,
  161. /* collectivemask_multicastmask */
  162. OPA_PI_MASK_COLLECT_MASK = 0x38,
  163. OPA_PI_MASK_MULTICAST_MASK = 0x07,
  164. /* mkeyprotect_lmc */
  165. OPA_PI_MASK_MKEY_PROT_BIT = 0xC0,
  166. OPA_PI_MASK_LMC = 0x0F,
  167. /* smsl */
  168. OPA_PI_MASK_SMSL = 0x1F,
  169. /* partenforce_filterraw */
  170. /* Filter Raw In/Out bits 1 and 2 were removed */
  171. OPA_PI_MASK_LINKINIT_REASON = 0xF0,
  172. OPA_PI_MASK_PARTITION_ENFORCE_IN = 0x08,
  173. OPA_PI_MASK_PARTITION_ENFORCE_OUT = 0x04,
  174. /* operational_vls */
  175. OPA_PI_MASK_OPERATIONAL_VL = 0x1F,
  176. /* sa_qp */
  177. OPA_PI_MASK_SA_QP = 0x00FFFFFF,
  178. /* sm_trap_qp */
  179. OPA_PI_MASK_SM_TRAP_QP = 0x00FFFFFF,
  180. /* localphy_overrun_errors */
  181. OPA_PI_MASK_LOCAL_PHY_ERRORS = 0xF0,
  182. OPA_PI_MASK_OVERRUN_ERRORS = 0x0F,
  183. /* clientrereg_subnettimeout */
  184. OPA_PI_MASK_CLIENT_REREGISTER = 0x80,
  185. OPA_PI_MASK_SUBNET_TIMEOUT = 0x1F,
  186. /* port_link_mode */
  187. OPA_PI_MASK_PORT_LINK_SUPPORTED = (0x001F << 10),
  188. OPA_PI_MASK_PORT_LINK_ENABLED = (0x001F << 5),
  189. OPA_PI_MASK_PORT_LINK_ACTIVE = (0x001F << 0),
  190. /* port_link_crc_mode */
  191. OPA_PI_MASK_PORT_LINK_CRC_SUPPORTED = 0x0F00,
  192. OPA_PI_MASK_PORT_LINK_CRC_ENABLED = 0x00F0,
  193. OPA_PI_MASK_PORT_LINK_CRC_ACTIVE = 0x000F,
  194. /* port_mode */
  195. OPA_PI_MASK_PORT_MODE_SECURITY_CHECK = 0x0001,
  196. OPA_PI_MASK_PORT_MODE_16B_TRAP_QUERY = 0x0002,
  197. OPA_PI_MASK_PORT_MODE_PKEY_CONVERT = 0x0004,
  198. OPA_PI_MASK_PORT_MODE_SC2SC_MAPPING = 0x0008,
  199. OPA_PI_MASK_PORT_MODE_VL_MARKER = 0x0010,
  200. OPA_PI_MASK_PORT_PASS_THROUGH = 0x0020,
  201. OPA_PI_MASK_PORT_ACTIVE_OPTOMIZE = 0x0040,
  202. /* flit_control.interleave */
  203. OPA_PI_MASK_INTERLEAVE_DIST_SUP = (0x0003 << 12),
  204. OPA_PI_MASK_INTERLEAVE_DIST_ENABLE = (0x0003 << 10),
  205. OPA_PI_MASK_INTERLEAVE_MAX_NEST_TX = (0x001F << 5),
  206. OPA_PI_MASK_INTERLEAVE_MAX_NEST_RX = (0x001F << 0),
  207. /* port_error_action */
  208. OPA_PI_MASK_EX_BUFFER_OVERRUN = 0x80000000,
  209. /* 7 bits reserved */
  210. OPA_PI_MASK_FM_CFG_ERR_EXCEED_MULTICAST_LIMIT = 0x00800000,
  211. OPA_PI_MASK_FM_CFG_BAD_CONTROL_FLIT = 0x00400000,
  212. OPA_PI_MASK_FM_CFG_BAD_PREEMPT = 0x00200000,
  213. OPA_PI_MASK_FM_CFG_UNSUPPORTED_VL_MARKER = 0x00100000,
  214. OPA_PI_MASK_FM_CFG_BAD_CRDT_ACK = 0x00080000,
  215. OPA_PI_MASK_FM_CFG_BAD_CTRL_DIST = 0x00040000,
  216. OPA_PI_MASK_FM_CFG_BAD_TAIL_DIST = 0x00020000,
  217. OPA_PI_MASK_FM_CFG_BAD_HEAD_DIST = 0x00010000,
  218. /* 2 bits reserved */
  219. OPA_PI_MASK_PORT_RCV_BAD_VL_MARKER = 0x00002000,
  220. OPA_PI_MASK_PORT_RCV_PREEMPT_VL15 = 0x00001000,
  221. OPA_PI_MASK_PORT_RCV_PREEMPT_ERROR = 0x00000800,
  222. /* 1 bit reserved */
  223. OPA_PI_MASK_PORT_RCV_BAD_MidTail = 0x00000200,
  224. /* 1 bit reserved */
  225. OPA_PI_MASK_PORT_RCV_BAD_SC = 0x00000080,
  226. OPA_PI_MASK_PORT_RCV_BAD_L2 = 0x00000040,
  227. OPA_PI_MASK_PORT_RCV_BAD_DLID = 0x00000020,
  228. OPA_PI_MASK_PORT_RCV_BAD_SLID = 0x00000010,
  229. OPA_PI_MASK_PORT_RCV_PKTLEN_TOOSHORT = 0x00000008,
  230. OPA_PI_MASK_PORT_RCV_PKTLEN_TOOLONG = 0x00000004,
  231. OPA_PI_MASK_PORT_RCV_BAD_PKTLEN = 0x00000002,
  232. OPA_PI_MASK_PORT_RCV_BAD_LT = 0x00000001,
  233. /* pass_through.res_drctl */
  234. OPA_PI_MASK_PASS_THROUGH_DR_CONTROL = 0x01,
  235. /* buffer_units */
  236. OPA_PI_MASK_BUF_UNIT_VL15_INIT = (0x00000FFF << 11),
  237. OPA_PI_MASK_BUF_UNIT_VL15_CREDIT_RATE = (0x0000001F << 6),
  238. OPA_PI_MASK_BUF_UNIT_CREDIT_ACK = (0x00000003 << 3),
  239. OPA_PI_MASK_BUF_UNIT_BUF_ALLOC = (0x00000003 << 0),
  240. /* neigh_mtu.pvlx_to_mtu */
  241. OPA_PI_MASK_NEIGH_MTU_PVL0 = 0xF0,
  242. OPA_PI_MASK_NEIGH_MTU_PVL1 = 0x0F,
  243. /* neigh_mtu.vlstall_hoq_life */
  244. OPA_PI_MASK_VL_STALL = (0x03 << 5),
  245. OPA_PI_MASK_HOQ_LIFE = (0x1F << 0),
  246. /* port_neigh_mode */
  247. OPA_PI_MASK_NEIGH_MGMT_ALLOWED = (0x01 << 3),
  248. OPA_PI_MASK_NEIGH_FW_AUTH_BYPASS = (0x01 << 2),
  249. OPA_PI_MASK_NEIGH_NODE_TYPE = (0x03 << 0),
  250. /* resptime_value */
  251. OPA_PI_MASK_RESPONSE_TIME_VALUE = 0x1F,
  252. /* mtucap */
  253. OPA_PI_MASK_MTU_CAP = 0x0F,
  254. };
  255. #if USE_PI_LED_ENABLE
  256. struct opa_port_states {
  257. u8 reserved;
  258. u8 ledenable_offlinereason; /* 1 res, 1 bit, 6 bits */
  259. u8 reserved2;
  260. u8 portphysstate_portstate; /* 4 bits, 4 bits */
  261. };
  262. #define PI_LED_ENABLE_SUP 1
  263. #else
  264. struct opa_port_states {
  265. u8 reserved;
  266. u8 offline_reason; /* 2 res, 6 bits */
  267. u8 reserved2;
  268. u8 portphysstate_portstate; /* 4 bits, 4 bits */
  269. };
  270. #define PI_LED_ENABLE_SUP 0
  271. #endif
  272. struct opa_port_state_info {
  273. struct opa_port_states port_states;
  274. u16 link_width_downgrade_tx_active;
  275. u16 link_width_downgrade_rx_active;
  276. };
  277. struct opa_port_info {
  278. __be32 lid;
  279. __be32 flow_control_mask;
  280. struct {
  281. u8 res; /* was inittype */
  282. u8 cap; /* 3 res, 5 bits */
  283. __be16 high_limit;
  284. __be16 preempt_limit;
  285. u8 arb_high_cap;
  286. u8 arb_low_cap;
  287. } vl;
  288. struct opa_port_states port_states;
  289. u8 port_phys_conf; /* 4 res, 4 bits */
  290. u8 collectivemask_multicastmask; /* 2 res, 3, 3 */
  291. u8 mkeyprotect_lmc; /* 2 bits, 2 res, 4 bits */
  292. u8 smsl; /* 3 res, 5 bits */
  293. u8 partenforce_filterraw; /* bit fields */
  294. u8 operational_vls; /* 3 res, 5 bits */
  295. __be16 pkey_8b;
  296. __be16 pkey_10b;
  297. __be16 mkey_violations;
  298. __be16 pkey_violations;
  299. __be16 qkey_violations;
  300. __be32 sm_trap_qp; /* 8 bits, 24 bits */
  301. __be32 sa_qp; /* 8 bits, 24 bits */
  302. u8 neigh_port_num;
  303. u8 link_down_reason;
  304. u8 neigh_link_down_reason;
  305. u8 clientrereg_subnettimeout; /* 1 bit, 2 bits, 5 */
  306. struct {
  307. __be16 supported;
  308. __be16 enabled;
  309. __be16 active;
  310. } link_speed;
  311. struct {
  312. __be16 supported;
  313. __be16 enabled;
  314. __be16 active;
  315. } link_width;
  316. struct {
  317. __be16 supported;
  318. __be16 enabled;
  319. __be16 tx_active;
  320. __be16 rx_active;
  321. } link_width_downgrade;
  322. __be16 port_link_mode; /* 1 res, 5 bits, 5 bits, 5 bits */
  323. __be16 port_ltp_crc_mode; /* 4 res, 4 bits, 4 bits, 4 bits */
  324. __be16 port_mode; /* 9 res, bit fields */
  325. struct {
  326. __be16 supported;
  327. __be16 enabled;
  328. } port_packet_format;
  329. struct {
  330. __be16 interleave; /* 2 res, 2,2,5,5 */
  331. struct {
  332. __be16 min_initial;
  333. __be16 min_tail;
  334. u8 large_pkt_limit;
  335. u8 small_pkt_limit;
  336. u8 max_small_pkt_limit;
  337. u8 preemption_limit;
  338. } preemption;
  339. } flit_control;
  340. __be32 reserved4;
  341. __be32 port_error_action; /* bit field */
  342. struct {
  343. u8 egress_port;
  344. u8 res_drctl; /* 7 res, 1 */
  345. } pass_through;
  346. __be16 mkey_lease_period;
  347. __be32 buffer_units; /* 9 res, 12, 5, 3, 3 */
  348. __be32 reserved5;
  349. __be32 sm_lid;
  350. __be64 mkey;
  351. __be64 subnet_prefix;
  352. struct {
  353. u8 pvlx_to_mtu[OPA_MAX_VLS/2]; /* 4 bits, 4 bits */
  354. } neigh_mtu;
  355. struct {
  356. u8 vlstall_hoqlife; /* 3 bits, 5 bits */
  357. } xmit_q[OPA_MAX_VLS];
  358. struct {
  359. u8 addr[16];
  360. } ipaddr_ipv6;
  361. struct {
  362. u8 addr[4];
  363. } ipaddr_ipv4;
  364. u32 reserved6;
  365. u32 reserved7;
  366. u32 reserved8;
  367. __be64 neigh_node_guid;
  368. __be32 ib_cap_mask;
  369. __be16 reserved9; /* was ib_cap_mask2 */
  370. __be16 opa_cap_mask;
  371. __be32 reserved10; /* was link_roundtrip_latency */
  372. __be16 overall_buffer_space;
  373. __be16 reserved11; /* was max_credit_hint */
  374. __be16 diag_code;
  375. struct {
  376. u8 buffer;
  377. u8 wire;
  378. } replay_depth;
  379. u8 port_neigh_mode;
  380. u8 mtucap; /* 4 res, 4 bits */
  381. u8 resptimevalue; /* 3 res, 5 bits */
  382. u8 local_port_num;
  383. u8 reserved12;
  384. u8 reserved13; /* was guid_cap */
  385. } __attribute__ ((packed));
  386. #endif /* OPA_PORT_INFO_H */