You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

ib_mad.h 15KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556
  1. #ifndef _GPXE_IB_MAD_H
  2. #define _GPXE_IB_MAD_H
  3. /** @file
  4. *
  5. * Infiniband management datagrams
  6. *
  7. */
  8. FILE_LICENCE ( GPL2_OR_LATER );
  9. #include <stdint.h>
  10. #include <gpxe/ib_packet.h>
  11. /*****************************************************************************
  12. *
  13. * Subnet management MADs
  14. *
  15. *****************************************************************************
  16. */
  17. /** A subnet management header
  18. *
  19. * Defined in sections 14.2.1.1 and 14.2.1.2 of the IBA.
  20. */
  21. struct ib_smp_hdr {
  22. uint64_t mkey;
  23. uint16_t slid;
  24. uint16_t dlid;
  25. uint8_t reserved[28];
  26. } __attribute__ (( packed ));
  27. /** Subnet management class version */
  28. #define IB_SMP_CLASS_VERSION 1
  29. /** Subnet management direction bit
  30. *
  31. * This bit resides in the "status" field in the MAD header.
  32. */
  33. #define IB_SMP_STATUS_D_INBOUND 0x8000
  34. /* Subnet management attributes */
  35. #define IB_SMP_ATTR_NOTICE 0x0002
  36. #define IB_SMP_ATTR_NODE_DESC 0x0010
  37. #define IB_SMP_ATTR_NODE_INFO 0x0011
  38. #define IB_SMP_ATTR_SWITCH_INFO 0x0012
  39. #define IB_SMP_ATTR_GUID_INFO 0x0014
  40. #define IB_SMP_ATTR_PORT_INFO 0x0015
  41. #define IB_SMP_ATTR_PKEY_TABLE 0x0016
  42. #define IB_SMP_ATTR_SL_TO_VL_TABLE 0x0017
  43. #define IB_SMP_ATTR_VL_ARB_TABLE 0x0018
  44. #define IB_SMP_ATTR_LINEAR_FORWARD_TABLE 0x0019
  45. #define IB_SMP_ATTR_RANDOM_FORWARD_TABLE 0x001A
  46. #define IB_SMP_ATTR_MCAST_FORWARD_TABLE 0x001B
  47. #define IB_SMP_ATTR_SM_INFO 0x0020
  48. #define IB_SMP_ATTR_VENDOR_DIAG 0x0030
  49. #define IB_SMP_ATTR_LED_INFO 0x0031
  50. #define IB_SMP_ATTR_VENDOR_MASK 0xFF00
  51. /**
  52. * A Node Description attribute
  53. *
  54. * Defined in section 14.2.5.2 of the IBA
  55. */
  56. struct ib_node_desc {
  57. char node_string[64];
  58. } __attribute__ (( packed ));
  59. /** A Node Information attribute
  60. *
  61. * Defined in section 14.2.5.3 of the IBA.
  62. */
  63. struct ib_node_info {
  64. uint8_t base_version;
  65. uint8_t class_version;
  66. uint8_t node_type;
  67. uint8_t num_ports;
  68. struct ib_gid_half sys_guid;
  69. struct ib_gid_half node_guid;
  70. struct ib_gid_half port_guid;
  71. uint16_t partition_cap;
  72. uint16_t device_id;
  73. uint32_t revision;
  74. uint8_t local_port_num;
  75. uint8_t vendor_id[3];
  76. } __attribute__ ((packed));
  77. #define IB_NODE_TYPE_HCA 0x01
  78. #define IB_NODE_TYPE_SWITCH 0x02
  79. #define IB_NODE_TYPE_ROUTER 0x03
  80. /** A GUID Information attribute
  81. *
  82. * Defined in section 14.2.5.5 of the IBA.
  83. */
  84. struct ib_guid_info {
  85. uint8_t guid[8][8];
  86. } __attribute__ (( packed ));
  87. /** A Port Information attribute
  88. *
  89. * Defined in section 14.2.5.6 of the IBA.
  90. */
  91. struct ib_port_info {
  92. uint64_t mkey;
  93. uint8_t gid_prefix[8];
  94. uint16_t lid;
  95. uint16_t mastersm_lid;
  96. uint32_t cap_mask;
  97. uint16_t diag_code;
  98. uint16_t mkey_lease_period;
  99. uint8_t local_port_num;
  100. uint8_t link_width_enabled;
  101. uint8_t link_width_supported;
  102. uint8_t link_width_active;
  103. uint8_t link_speed_supported__port_state;
  104. uint8_t port_phys_state__link_down_def_state;
  105. uint8_t mkey_prot_bits__lmc;
  106. uint8_t link_speed_active__link_speed_enabled;
  107. uint8_t neighbour_mtu__mastersm_sl;
  108. uint8_t vl_cap__init_type;
  109. uint8_t vl_high_limit;
  110. uint8_t vl_arbitration_high_cap;
  111. uint8_t vl_arbitration_low_cap;
  112. uint8_t init_type_reply__mtu_cap;
  113. uint8_t vl_stall_count__hoq_life;
  114. uint8_t operational_vls__enforcement;
  115. uint16_t mkey_violations;
  116. uint16_t pkey_violations;
  117. uint16_t qkey_violations;
  118. uint8_t guid_cap;
  119. uint8_t client_reregister__subnet_timeout;
  120. uint8_t resp_time_value;
  121. uint8_t local_phy_errors__overrun_errors;
  122. uint16_t max_credit_hint;
  123. uint32_t link_round_trip_latency;
  124. } __attribute__ (( packed ));
  125. #define IB_LINK_WIDTH_1X 0x01
  126. #define IB_LINK_WIDTH_4X 0x02
  127. #define IB_LINK_WIDTH_8X 0x04
  128. #define IB_LINK_WIDTH_12X 0x08
  129. #define IB_LINK_SPEED_SDR 0x01
  130. #define IB_LINK_SPEED_DDR 0x02
  131. #define IB_LINK_SPEED_QDR 0x04
  132. #define IB_PORT_STATE_DOWN 0x01
  133. #define IB_PORT_STATE_INIT 0x02
  134. #define IB_PORT_STATE_ARMED 0x03
  135. #define IB_PORT_STATE_ACTIVE 0x04
  136. #define IB_PORT_PHYS_STATE_SLEEP 0x01
  137. #define IB_PORT_PHYS_STATE_POLLING 0x02
  138. #define IB_MTU_256 0x01
  139. #define IB_MTU_512 0x02
  140. #define IB_MTU_1024 0x03
  141. #define IB_MTU_2048 0x04
  142. #define IB_MTU_4096 0x05
  143. #define IB_VL_0 0x01
  144. #define IB_VL_0_1 0x02
  145. #define IB_VL_0_3 0x03
  146. #define IB_VL_0_7 0x04
  147. #define IB_VL_0_14 0x05
  148. /** A Partition Key Table attribute
  149. *
  150. * Defined in section 14.2.5.7 of the IBA.
  151. */
  152. struct ib_pkey_table {
  153. uint16_t pkey[32];
  154. } __attribute__ (( packed ));
  155. /** A subnet management attribute */
  156. union ib_smp_data {
  157. struct ib_node_desc node_desc;
  158. struct ib_node_info node_info;
  159. struct ib_guid_info guid_info;
  160. struct ib_port_info port_info;
  161. struct ib_pkey_table pkey_table;
  162. uint8_t bytes[64];
  163. } __attribute__ (( packed ));
  164. /** A subnet management directed route path */
  165. struct ib_smp_dr_path {
  166. uint8_t hops[64];
  167. } __attribute__ (( packed ));
  168. /** Subnet management MAD class-specific data */
  169. struct ib_smp_class_specific {
  170. uint8_t hop_pointer;
  171. uint8_t hop_count;
  172. } __attribute__ (( packed ));
  173. /*****************************************************************************
  174. *
  175. * Subnet administration MADs
  176. *
  177. *****************************************************************************
  178. */
  179. #define IB_SA_CLASS_VERSION 2
  180. #define IB_SA_METHOD_DELETE_RESP 0x95
  181. struct ib_rmpp_hdr {
  182. uint32_t raw[3];
  183. } __attribute__ (( packed ));
  184. struct ib_sa_hdr {
  185. uint32_t sm_key[2];
  186. uint16_t reserved;
  187. uint16_t attrib_offset;
  188. uint32_t comp_mask[2];
  189. } __attribute__ (( packed ));
  190. #define IB_SA_ATTR_MC_MEMBER_REC 0x38
  191. #define IB_SA_ATTR_PATH_REC 0x35
  192. struct ib_path_record {
  193. uint32_t reserved0[2];
  194. struct ib_gid dgid;
  195. struct ib_gid sgid;
  196. uint16_t dlid;
  197. uint16_t slid;
  198. uint32_t hop_limit__flow_label__raw_traffic;
  199. uint32_t pkey__numb_path__reversible__tclass;
  200. uint8_t reserved1;
  201. uint8_t reserved__sl;
  202. uint8_t mtu_selector__mtu;
  203. uint8_t rate_selector__rate;
  204. uint32_t preference__packet_lifetime__packet_lifetime_selector;
  205. uint32_t reserved2[35];
  206. } __attribute__ (( packed ));
  207. #define IB_SA_PATH_REC_DGID (1<<2)
  208. #define IB_SA_PATH_REC_SGID (1<<3)
  209. struct ib_mc_member_record {
  210. struct ib_gid mgid;
  211. struct ib_gid port_gid;
  212. uint32_t qkey;
  213. uint16_t mlid;
  214. uint8_t mtu_selector__mtu;
  215. uint8_t tclass;
  216. uint16_t pkey;
  217. uint8_t rate_selector__rate;
  218. uint8_t packet_lifetime_selector__packet_lifetime;
  219. uint32_t sl__flow_label__hop_limit;
  220. uint8_t scope__join_state;
  221. uint8_t proxy_join__reserved;
  222. uint16_t reserved0;
  223. uint32_t reserved1[37];
  224. } __attribute__ (( packed ));
  225. #define IB_SA_MCMEMBER_REC_MGID (1<<0)
  226. #define IB_SA_MCMEMBER_REC_PORT_GID (1<<1)
  227. #define IB_SA_MCMEMBER_REC_QKEY (1<<2)
  228. #define IB_SA_MCMEMBER_REC_MLID (1<<3)
  229. #define IB_SA_MCMEMBER_REC_MTU_SELECTOR (1<<4)
  230. #define IB_SA_MCMEMBER_REC_MTU (1<<5)
  231. #define IB_SA_MCMEMBER_REC_TRAFFIC_CLASS (1<<6)
  232. #define IB_SA_MCMEMBER_REC_PKEY (1<<7)
  233. #define IB_SA_MCMEMBER_REC_RATE_SELECTOR (1<<8)
  234. #define IB_SA_MCMEMBER_REC_RATE (1<<9)
  235. #define IB_SA_MCMEMBER_REC_PACKET_LIFE_TIME_SELECTOR (1<<10)
  236. #define IB_SA_MCMEMBER_REC_PACKET_LIFE_TIME (1<<11)
  237. #define IB_SA_MCMEMBER_REC_SL (1<<12)
  238. #define IB_SA_MCMEMBER_REC_FLOW_LABEL (1<<13)
  239. #define IB_SA_MCMEMBER_REC_HOP_LIMIT (1<<14)
  240. #define IB_SA_MCMEMBER_REC_SCOPE (1<<15)
  241. #define IB_SA_MCMEMBER_REC_JOIN_STATE (1<<16)
  242. #define IB_SA_MCMEMBER_REC_PROXY_JOIN (1<<17)
  243. union ib_sa_data {
  244. struct ib_path_record path_record;
  245. struct ib_mc_member_record mc_member_record;
  246. } __attribute__ (( packed ));
  247. /*****************************************************************************
  248. *
  249. * Communication management MADs
  250. *
  251. *****************************************************************************
  252. */
  253. /** Communication management class version */
  254. #define IB_CM_CLASS_VERSION 2
  255. /* Communication management attributes */
  256. #define IB_CM_ATTR_CLASS_PORT_INFO 0x0001
  257. #define IB_CM_ATTR_CONNECT_REQUEST 0x0010
  258. #define IB_CM_ATTR_MSG_RCPT_ACK 0x0011
  259. #define IB_CM_ATTR_CONNECT_REJECT 0x0012
  260. #define IB_CM_ATTR_CONNECT_REPLY 0x0013
  261. #define IB_CM_ATTR_READY_TO_USE 0x0014
  262. #define IB_CM_ATTR_DISCONNECT_REQUEST 0x0015
  263. #define IB_CM_ATTR_DISCONNECT_REPLY 0x0016
  264. #define IB_CM_ATTR_SERVICE_ID_RES_REQ 0x0016
  265. #define IB_CM_ATTR_SERVICE_ID_RES_REQ_RESP 0x0018
  266. #define IB_CM_ATTR_LOAD_ALTERNATE_PATH 0x0019
  267. #define IB_CM_ATTR_ALTERNATE_PATH_RESPONSE 0x001a
  268. /** Communication management common fields */
  269. struct ib_cm_common {
  270. /** Local communication ID */
  271. uint32_t local_id;
  272. /** Remote communication ID */
  273. uint32_t remote_id;
  274. /** Reserved */
  275. uint8_t reserved[224];
  276. } __attribute__ (( packed ));
  277. /** A communication management path */
  278. struct ib_cm_path {
  279. /** Local port LID */
  280. uint16_t local_lid;
  281. /** Remote port LID */
  282. uint16_t remote_lid;
  283. /** Local port GID */
  284. struct ib_gid local_gid;
  285. /** Remote port GID */
  286. struct ib_gid remote_gid;
  287. /** Flow label and rate */
  288. uint32_t flow_label__rate;
  289. /** Traffic class */
  290. uint8_t tc;
  291. /** Hop limit */
  292. uint8_t hop_limit;
  293. /** SL and subnet local*/
  294. uint8_t sl__subnet_local;
  295. /** Local ACK timeout */
  296. uint8_t local_ack_timeout;
  297. } __attribute__ (( packed ));
  298. /** A communication management connection request
  299. *
  300. * Defined in section 12.6.5 of the IBA.
  301. */
  302. struct ib_cm_connect_request {
  303. /** Local communication ID */
  304. uint32_t local_id;
  305. /** Reserved */
  306. uint32_t reserved0[1];
  307. /** Service ID */
  308. struct ib_gid_half service_id;
  309. /** Local CA GUID */
  310. struct ib_gid_half local_ca;
  311. /** Reserved */
  312. uint32_t reserved1[1];
  313. /** Local queue key */
  314. uint32_t local_qkey;
  315. /** Local QPN and responder resources*/
  316. uint32_t local_qpn__responder_resources;
  317. /** Local EECN and initiator depth */
  318. uint32_t local_eecn__initiator_depth;
  319. /** Remote EECN, remote CM response timeout, transport service
  320. * type, EE flow control
  321. */
  322. uint32_t remote_eecn__remote_timeout__service_type__ee_flow_ctrl;
  323. /** Starting PSN, local CM response timeout and retry count */
  324. uint32_t starting_psn__local_timeout__retry_count;
  325. /** Partition key */
  326. uint16_t pkey;
  327. /** Path packet payload MTU, RDC exists, RNR retry count */
  328. uint8_t payload_mtu__rdc_exists__rnr_retry;
  329. /** Max CM retries and SRQ */
  330. uint8_t max_cm_retries__srq;
  331. /** Primary path */
  332. struct ib_cm_path primary;
  333. /** Alternate path */
  334. struct ib_cm_path alternate;
  335. /** Private data */
  336. uint8_t private_data[92];
  337. } __attribute__ (( packed ));
  338. /** CM transport types */
  339. #define IB_CM_TRANSPORT_RC 0
  340. #define IB_CM_TRANSPORT_UC 1
  341. #define IB_CM_TRANSPORT_RD 2
  342. /** A communication management connection rejection
  343. *
  344. * Defined in section 12.6.7 of the IBA.
  345. */
  346. struct ib_cm_connect_reject {
  347. /** Local communication ID */
  348. uint32_t local_id;
  349. /** Remote communication ID */
  350. uint32_t remote_id;
  351. /** Message rejected */
  352. uint8_t message;
  353. /** Reject information length */
  354. uint8_t info_len;
  355. /** Rejection reason */
  356. uint16_t reason;
  357. /** Additional rejection information */
  358. uint8_t info[72];
  359. /** Private data */
  360. uint8_t private_data[148];
  361. } __attribute__ (( packed ));
  362. /** A communication management connection reply
  363. *
  364. * Defined in section 12.6.8 of the IBA.
  365. */
  366. struct ib_cm_connect_reply {
  367. /** Local communication ID */
  368. uint32_t local_id;
  369. /** Remote communication ID */
  370. uint32_t remote_id;
  371. /** Local queue key */
  372. uint32_t local_qkey;
  373. /** Local QPN */
  374. uint32_t local_qpn;
  375. /** Local EECN */
  376. uint32_t local_eecn;
  377. /** Starting PSN */
  378. uint32_t starting_psn;
  379. /** Responder resources */
  380. uint8_t responder_resources;
  381. /** Initiator depth */
  382. uint8_t initiator_depth;
  383. /** Target ACK delay, failover accepted, and end-to-end flow control */
  384. uint8_t target_ack_delay__failover_accepted__ee_flow_ctrl;
  385. /** RNR retry count, SRQ */
  386. uint8_t rnr_retry__srq;
  387. /** Local CA GUID */
  388. struct ib_gid_half local_ca;
  389. /** Private data */
  390. uint8_t private_data[196];
  391. } __attribute__ (( packed ));
  392. /** A communication management ready to use reply
  393. *
  394. * Defined in section 12.6.9 of the IBA.
  395. */
  396. struct ib_cm_ready_to_use {
  397. /** Local communication ID */
  398. uint32_t local_id;
  399. /** Remote communication ID */
  400. uint32_t remote_id;
  401. /** Private data */
  402. uint8_t private_data[224];
  403. } __attribute__ (( packed ));
  404. /** A communication management attribute */
  405. union ib_cm_data {
  406. struct ib_cm_common common;
  407. struct ib_cm_connect_request connect_request;
  408. struct ib_cm_connect_reject connect_reject;
  409. struct ib_cm_connect_reply connect_reply;
  410. struct ib_cm_ready_to_use ready_to_use;
  411. uint8_t bytes[232];
  412. } __attribute__ (( packed ));
  413. /*****************************************************************************
  414. *
  415. * MADs
  416. *
  417. *****************************************************************************
  418. */
  419. /** Management datagram class_specific data */
  420. union ib_mad_class_specific {
  421. uint16_t raw;
  422. struct ib_smp_class_specific smp;
  423. } __attribute__ (( packed ));
  424. /** A management datagram common header
  425. *
  426. * Defined in section 13.4.2 of the IBA.
  427. */
  428. struct ib_mad_hdr {
  429. uint8_t base_version;
  430. uint8_t mgmt_class;
  431. uint8_t class_version;
  432. uint8_t method;
  433. uint16_t status;
  434. union ib_mad_class_specific class_specific;
  435. uint32_t tid[2];
  436. uint16_t attr_id;
  437. uint8_t reserved[2];
  438. uint32_t attr_mod;
  439. } __attribute__ (( packed ));
  440. /* Management base version */
  441. #define IB_MGMT_BASE_VERSION 1
  442. /* Management classes */
  443. #define IB_MGMT_CLASS_SUBN_LID_ROUTED 0x01
  444. #define IB_MGMT_CLASS_SUBN_DIRECTED_ROUTE 0x81
  445. #define IB_MGMT_CLASS_SUBN_ADM 0x03
  446. #define IB_MGMT_CLASS_PERF_MGMT 0x04
  447. #define IB_MGMT_CLASS_BM 0x05
  448. #define IB_MGMT_CLASS_DEVICE_MGMT 0x06
  449. #define IB_MGMT_CLASS_CM 0x07
  450. #define IB_MGMT_CLASS_SNMP 0x08
  451. #define IB_MGMT_CLASS_VENDOR_RANGE2_START 0x30
  452. #define IB_MGMT_CLASS_VENDOR_RANGE2_END 0x4f
  453. #define IB_MGMT_CLASS_MASK 0x7f
  454. /* Management methods */
  455. #define IB_MGMT_METHOD_GET 0x01
  456. #define IB_MGMT_METHOD_SET 0x02
  457. #define IB_MGMT_METHOD_GET_RESP 0x81
  458. #define IB_MGMT_METHOD_SEND 0x03
  459. #define IB_MGMT_METHOD_TRAP 0x05
  460. #define IB_MGMT_METHOD_REPORT 0x06
  461. #define IB_MGMT_METHOD_REPORT_RESP 0x86
  462. #define IB_MGMT_METHOD_TRAP_REPRESS 0x07
  463. #define IB_MGMT_METHOD_DELETE 0x15
  464. /* Status codes */
  465. #define IB_MGMT_STATUS_OK 0x0000
  466. #define IB_MGMT_STATUS_BAD_VERSION 0x0001
  467. #define IB_MGMT_STATUS_UNSUPPORTED_METHOD 0x0002
  468. #define IB_MGMT_STATUS_UNSUPPORTED_METHOD_ATTR 0x0003
  469. #define IB_MGMT_STATUS_INVALID_VALUE 0x0004
  470. /** A subnet management MAD */
  471. struct ib_mad_smp {
  472. struct ib_mad_hdr mad_hdr;
  473. struct ib_smp_hdr smp_hdr;
  474. union ib_smp_data smp_data;
  475. struct ib_smp_dr_path initial_path;
  476. struct ib_smp_dr_path return_path;
  477. } __attribute__ (( packed ));
  478. /** A subnet administration MAD */
  479. struct ib_mad_sa {
  480. struct ib_mad_hdr mad_hdr;
  481. struct ib_rmpp_hdr rmpp_hdr;
  482. struct ib_sa_hdr sa_hdr;
  483. union ib_sa_data sa_data;
  484. } __attribute__ (( packed ));
  485. /** A communication management MAD */
  486. struct ib_mad_cm {
  487. struct ib_mad_hdr mad_hdr;
  488. union ib_cm_data cm_data;
  489. } __attribute__ (( packed ));
  490. /** A management datagram */
  491. union ib_mad {
  492. struct ib_mad_hdr hdr;
  493. struct ib_mad_smp smp;
  494. struct ib_mad_sa sa;
  495. struct ib_mad_cm cm;
  496. uint8_t bytes[256];
  497. } __attribute__ (( packed ));
  498. #endif /* _GPXE_IB_MAD_H */