xref: /linux/drivers/infiniband/sw/siw/iwarp.h (revision a23e1966932464e1c5226cb9ac4ce1d5fc10ba22)
13ec648c6SKrzysztof Kozlowski /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
20e935ae6SBernard Metzler 
30e935ae6SBernard Metzler /* Authors: Bernard Metzler <bmt@zurich.ibm.com> */
40e935ae6SBernard Metzler /* Copyright (c) 2008-2019, IBM Corporation */
50e935ae6SBernard Metzler 
60e935ae6SBernard Metzler #ifndef _IWARP_H
70e935ae6SBernard Metzler #define _IWARP_H
80e935ae6SBernard Metzler 
90e935ae6SBernard Metzler #include <rdma/rdma_user_cm.h> /* RDMA_MAX_PRIVATE_DATA */
100e935ae6SBernard Metzler #include <linux/types.h>
110e935ae6SBernard Metzler #include <asm/byteorder.h>
120e935ae6SBernard Metzler 
130e935ae6SBernard Metzler #define RDMAP_VERSION 1
140e935ae6SBernard Metzler #define DDP_VERSION 1
150e935ae6SBernard Metzler #define MPA_REVISION_1 1
160e935ae6SBernard Metzler #define MPA_REVISION_2 2
170e935ae6SBernard Metzler #define MPA_MAX_PRIVDATA RDMA_MAX_PRIVATE_DATA
180e935ae6SBernard Metzler #define MPA_KEY_REQ "MPA ID Req Frame"
190e935ae6SBernard Metzler #define MPA_KEY_REP "MPA ID Rep Frame"
200e935ae6SBernard Metzler #define MPA_IRD_ORD_MASK 0x3fff
210e935ae6SBernard Metzler 
220e935ae6SBernard Metzler struct mpa_rr_params {
230e935ae6SBernard Metzler 	__be16 bits;
240e935ae6SBernard Metzler 	__be16 pd_len;
250e935ae6SBernard Metzler };
260e935ae6SBernard Metzler 
270e935ae6SBernard Metzler /*
280e935ae6SBernard Metzler  * MPA request/response header bits & fields
290e935ae6SBernard Metzler  */
300e935ae6SBernard Metzler enum {
310e935ae6SBernard Metzler 	MPA_RR_FLAG_MARKERS = cpu_to_be16(0x8000),
320e935ae6SBernard Metzler 	MPA_RR_FLAG_CRC = cpu_to_be16(0x4000),
330e935ae6SBernard Metzler 	MPA_RR_FLAG_REJECT = cpu_to_be16(0x2000),
340e935ae6SBernard Metzler 	MPA_RR_FLAG_ENHANCED = cpu_to_be16(0x1000),
350e935ae6SBernard Metzler 	MPA_RR_FLAG_GSO_EXP = cpu_to_be16(0x0800),
360e935ae6SBernard Metzler 	MPA_RR_MASK_REVISION = cpu_to_be16(0x00ff)
370e935ae6SBernard Metzler };
380e935ae6SBernard Metzler 
390e935ae6SBernard Metzler /*
400e935ae6SBernard Metzler  * MPA request/reply header
410e935ae6SBernard Metzler  */
420e935ae6SBernard Metzler struct mpa_rr {
430e935ae6SBernard Metzler 	__u8 key[16];
440e935ae6SBernard Metzler 	struct mpa_rr_params params;
450e935ae6SBernard Metzler };
460e935ae6SBernard Metzler 
__mpa_rr_set_revision(__be16 * bits,u8 rev)470e935ae6SBernard Metzler static inline void __mpa_rr_set_revision(__be16 *bits, u8 rev)
480e935ae6SBernard Metzler {
490e935ae6SBernard Metzler 	*bits = (*bits & ~MPA_RR_MASK_REVISION) |
500e935ae6SBernard Metzler 		(cpu_to_be16(rev) & MPA_RR_MASK_REVISION);
510e935ae6SBernard Metzler }
520e935ae6SBernard Metzler 
__mpa_rr_revision(__be16 mpa_rr_bits)530e935ae6SBernard Metzler static inline u8 __mpa_rr_revision(__be16 mpa_rr_bits)
540e935ae6SBernard Metzler {
550e935ae6SBernard Metzler 	__be16 rev = mpa_rr_bits & MPA_RR_MASK_REVISION;
560e935ae6SBernard Metzler 
570e935ae6SBernard Metzler 	return be16_to_cpu(rev);
580e935ae6SBernard Metzler }
590e935ae6SBernard Metzler 
600e935ae6SBernard Metzler enum mpa_v2_ctrl {
610e935ae6SBernard Metzler 	MPA_V2_PEER_TO_PEER = cpu_to_be16(0x8000),
620e935ae6SBernard Metzler 	MPA_V2_ZERO_LENGTH_RTR = cpu_to_be16(0x4000),
630e935ae6SBernard Metzler 	MPA_V2_RDMA_WRITE_RTR = cpu_to_be16(0x8000),
640e935ae6SBernard Metzler 	MPA_V2_RDMA_READ_RTR = cpu_to_be16(0x4000),
650e935ae6SBernard Metzler 	MPA_V2_RDMA_NO_RTR = cpu_to_be16(0x0000),
660e935ae6SBernard Metzler 	MPA_V2_MASK_IRD_ORD = cpu_to_be16(0x3fff)
670e935ae6SBernard Metzler };
680e935ae6SBernard Metzler 
690e935ae6SBernard Metzler struct mpa_v2_data {
700e935ae6SBernard Metzler 	__be16 ird;
710e935ae6SBernard Metzler 	__be16 ord;
720e935ae6SBernard Metzler };
730e935ae6SBernard Metzler 
740e935ae6SBernard Metzler struct mpa_marker {
750e935ae6SBernard Metzler 	__be16 rsvd;
760e935ae6SBernard Metzler 	__be16 fpdu_hmd; /* FPDU header-marker distance (= MPA's FPDUPTR) */
770e935ae6SBernard Metzler };
780e935ae6SBernard Metzler 
790e935ae6SBernard Metzler /*
800e935ae6SBernard Metzler  * maximum MPA trailer
810e935ae6SBernard Metzler  */
820e935ae6SBernard Metzler struct mpa_trailer {
830e935ae6SBernard Metzler 	__u8 pad[4];
840e935ae6SBernard Metzler 	__be32 crc;
850e935ae6SBernard Metzler };
860e935ae6SBernard Metzler 
870e935ae6SBernard Metzler #define MPA_HDR_SIZE 2
880e935ae6SBernard Metzler #define MPA_CRC_SIZE 4
890e935ae6SBernard Metzler 
900e935ae6SBernard Metzler /*
910e935ae6SBernard Metzler  * Common portion of iWARP headers (MPA, DDP, RDMAP)
920e935ae6SBernard Metzler  * for any FPDU
930e935ae6SBernard Metzler  */
940e935ae6SBernard Metzler struct iwarp_ctrl {
950e935ae6SBernard Metzler 	__be16 mpa_len;
960e935ae6SBernard Metzler 	__be16 ddp_rdmap_ctrl;
970e935ae6SBernard Metzler };
980e935ae6SBernard Metzler 
990e935ae6SBernard Metzler /*
1000e935ae6SBernard Metzler  * DDP/RDMAP Hdr bits & fields
1010e935ae6SBernard Metzler  */
1020e935ae6SBernard Metzler enum {
1030e935ae6SBernard Metzler 	DDP_FLAG_TAGGED = cpu_to_be16(0x8000),
1040e935ae6SBernard Metzler 	DDP_FLAG_LAST = cpu_to_be16(0x4000),
1050e935ae6SBernard Metzler 	DDP_MASK_RESERVED = cpu_to_be16(0x3C00),
1060e935ae6SBernard Metzler 	DDP_MASK_VERSION = cpu_to_be16(0x0300),
1070e935ae6SBernard Metzler 	RDMAP_MASK_VERSION = cpu_to_be16(0x00C0),
1080e935ae6SBernard Metzler 	RDMAP_MASK_RESERVED = cpu_to_be16(0x0030),
1090e935ae6SBernard Metzler 	RDMAP_MASK_OPCODE = cpu_to_be16(0x000f)
1100e935ae6SBernard Metzler };
1110e935ae6SBernard Metzler 
__ddp_get_version(struct iwarp_ctrl * ctrl)1120e935ae6SBernard Metzler static inline u8 __ddp_get_version(struct iwarp_ctrl *ctrl)
1130e935ae6SBernard Metzler {
1140e935ae6SBernard Metzler 	return be16_to_cpu(ctrl->ddp_rdmap_ctrl & DDP_MASK_VERSION) >> 8;
1150e935ae6SBernard Metzler }
1160e935ae6SBernard Metzler 
__rdmap_get_version(struct iwarp_ctrl * ctrl)1170e935ae6SBernard Metzler static inline u8 __rdmap_get_version(struct iwarp_ctrl *ctrl)
1180e935ae6SBernard Metzler {
1190e935ae6SBernard Metzler 	__be16 ver = ctrl->ddp_rdmap_ctrl & RDMAP_MASK_VERSION;
1200e935ae6SBernard Metzler 
1210e935ae6SBernard Metzler 	return be16_to_cpu(ver) >> 6;
1220e935ae6SBernard Metzler }
1230e935ae6SBernard Metzler 
__rdmap_get_opcode(struct iwarp_ctrl * ctrl)1240e935ae6SBernard Metzler static inline u8 __rdmap_get_opcode(struct iwarp_ctrl *ctrl)
1250e935ae6SBernard Metzler {
1260e935ae6SBernard Metzler 	return be16_to_cpu(ctrl->ddp_rdmap_ctrl & RDMAP_MASK_OPCODE);
1270e935ae6SBernard Metzler }
1280e935ae6SBernard Metzler 
__rdmap_set_opcode(struct iwarp_ctrl * ctrl,u8 opcode)1290e935ae6SBernard Metzler static inline void __rdmap_set_opcode(struct iwarp_ctrl *ctrl, u8 opcode)
1300e935ae6SBernard Metzler {
1310e935ae6SBernard Metzler 	ctrl->ddp_rdmap_ctrl = (ctrl->ddp_rdmap_ctrl & ~RDMAP_MASK_OPCODE) |
1320e935ae6SBernard Metzler 			       (cpu_to_be16(opcode) & RDMAP_MASK_OPCODE);
1330e935ae6SBernard Metzler }
1340e935ae6SBernard Metzler 
1350e935ae6SBernard Metzler struct iwarp_rdma_write {
1360e935ae6SBernard Metzler 	struct iwarp_ctrl ctrl;
1370e935ae6SBernard Metzler 	__be32 sink_stag;
1380e935ae6SBernard Metzler 	__be64 sink_to;
1390e935ae6SBernard Metzler };
1400e935ae6SBernard Metzler 
1410e935ae6SBernard Metzler struct iwarp_rdma_rreq {
1420e935ae6SBernard Metzler 	struct iwarp_ctrl ctrl;
1430e935ae6SBernard Metzler 	__be32 rsvd;
1440e935ae6SBernard Metzler 	__be32 ddp_qn;
1450e935ae6SBernard Metzler 	__be32 ddp_msn;
1460e935ae6SBernard Metzler 	__be32 ddp_mo;
1470e935ae6SBernard Metzler 	__be32 sink_stag;
1480e935ae6SBernard Metzler 	__be64 sink_to;
1490e935ae6SBernard Metzler 	__be32 read_size;
1500e935ae6SBernard Metzler 	__be32 source_stag;
1510e935ae6SBernard Metzler 	__be64 source_to;
1520e935ae6SBernard Metzler };
1530e935ae6SBernard Metzler 
1540e935ae6SBernard Metzler struct iwarp_rdma_rresp {
1550e935ae6SBernard Metzler 	struct iwarp_ctrl ctrl;
1560e935ae6SBernard Metzler 	__be32 sink_stag;
1570e935ae6SBernard Metzler 	__be64 sink_to;
1580e935ae6SBernard Metzler };
1590e935ae6SBernard Metzler 
1600e935ae6SBernard Metzler struct iwarp_send {
1610e935ae6SBernard Metzler 	struct iwarp_ctrl ctrl;
1620e935ae6SBernard Metzler 	__be32 rsvd;
1630e935ae6SBernard Metzler 	__be32 ddp_qn;
1640e935ae6SBernard Metzler 	__be32 ddp_msn;
1650e935ae6SBernard Metzler 	__be32 ddp_mo;
1660e935ae6SBernard Metzler };
1670e935ae6SBernard Metzler 
1680e935ae6SBernard Metzler struct iwarp_send_inv {
1690e935ae6SBernard Metzler 	struct iwarp_ctrl ctrl;
1700e935ae6SBernard Metzler 	__be32 inval_stag;
1710e935ae6SBernard Metzler 	__be32 ddp_qn;
1720e935ae6SBernard Metzler 	__be32 ddp_msn;
1730e935ae6SBernard Metzler 	__be32 ddp_mo;
1740e935ae6SBernard Metzler };
1750e935ae6SBernard Metzler 
1760e935ae6SBernard Metzler struct iwarp_terminate {
1770e935ae6SBernard Metzler 	struct iwarp_ctrl ctrl;
1780e935ae6SBernard Metzler 	__be32 rsvd;
1790e935ae6SBernard Metzler 	__be32 ddp_qn;
1800e935ae6SBernard Metzler 	__be32 ddp_msn;
1810e935ae6SBernard Metzler 	__be32 ddp_mo;
1820e935ae6SBernard Metzler #if defined(__LITTLE_ENDIAN_BITFIELD)
1830e935ae6SBernard Metzler 	__be32 layer : 4;
1840e935ae6SBernard Metzler 	__be32 etype : 4;
1850e935ae6SBernard Metzler 	__be32 ecode : 8;
1860e935ae6SBernard Metzler 	__be32 flag_m : 1;
1870e935ae6SBernard Metzler 	__be32 flag_d : 1;
1880e935ae6SBernard Metzler 	__be32 flag_r : 1;
1890e935ae6SBernard Metzler 	__be32 reserved : 13;
1900e935ae6SBernard Metzler #elif defined(__BIG_ENDIAN_BITFIELD)
1910e935ae6SBernard Metzler 	__be32 reserved : 13;
1920e935ae6SBernard Metzler 	__be32 flag_r : 1;
1930e935ae6SBernard Metzler 	__be32 flag_d : 1;
1940e935ae6SBernard Metzler 	__be32 flag_m : 1;
1950e935ae6SBernard Metzler 	__be32 ecode : 8;
1960e935ae6SBernard Metzler 	__be32 etype : 4;
1970e935ae6SBernard Metzler 	__be32 layer : 4;
1980e935ae6SBernard Metzler #else
1990e935ae6SBernard Metzler #error "undefined byte order"
2000e935ae6SBernard Metzler #endif
2010e935ae6SBernard Metzler };
2020e935ae6SBernard Metzler 
2030e935ae6SBernard Metzler /*
2040e935ae6SBernard Metzler  * Terminate Hdr bits & fields
2050e935ae6SBernard Metzler  */
2060e935ae6SBernard Metzler enum {
2070e935ae6SBernard Metzler 	TERM_MASK_LAYER = cpu_to_be32(0xf0000000),
2080e935ae6SBernard Metzler 	TERM_MASK_ETYPE = cpu_to_be32(0x0f000000),
2090e935ae6SBernard Metzler 	TERM_MASK_ECODE = cpu_to_be32(0x00ff0000),
2100e935ae6SBernard Metzler 	TERM_FLAG_M = cpu_to_be32(0x00008000),
2110e935ae6SBernard Metzler 	TERM_FLAG_D = cpu_to_be32(0x00004000),
2120e935ae6SBernard Metzler 	TERM_FLAG_R = cpu_to_be32(0x00002000),
2130e935ae6SBernard Metzler 	TERM_MASK_RESVD = cpu_to_be32(0x00001fff)
2140e935ae6SBernard Metzler };
2150e935ae6SBernard Metzler 
__rdmap_term_layer(struct iwarp_terminate * term)2160e935ae6SBernard Metzler static inline u8 __rdmap_term_layer(struct iwarp_terminate *term)
2170e935ae6SBernard Metzler {
2180e935ae6SBernard Metzler 	return term->layer;
2190e935ae6SBernard Metzler }
2200e935ae6SBernard Metzler 
__rdmap_term_set_layer(struct iwarp_terminate * term,u8 layer)2210e935ae6SBernard Metzler static inline void __rdmap_term_set_layer(struct iwarp_terminate *term,
2220e935ae6SBernard Metzler 					  u8 layer)
2230e935ae6SBernard Metzler {
2240e935ae6SBernard Metzler 	term->layer = layer & 0xf;
2250e935ae6SBernard Metzler }
2260e935ae6SBernard Metzler 
__rdmap_term_etype(struct iwarp_terminate * term)2270e935ae6SBernard Metzler static inline u8 __rdmap_term_etype(struct iwarp_terminate *term)
2280e935ae6SBernard Metzler {
2290e935ae6SBernard Metzler 	return term->etype;
2300e935ae6SBernard Metzler }
2310e935ae6SBernard Metzler 
__rdmap_term_set_etype(struct iwarp_terminate * term,u8 etype)2320e935ae6SBernard Metzler static inline void __rdmap_term_set_etype(struct iwarp_terminate *term,
2330e935ae6SBernard Metzler 					  u8 etype)
2340e935ae6SBernard Metzler {
2350e935ae6SBernard Metzler 	term->etype = etype & 0xf;
2360e935ae6SBernard Metzler }
2370e935ae6SBernard Metzler 
__rdmap_term_ecode(struct iwarp_terminate * term)2380e935ae6SBernard Metzler static inline u8 __rdmap_term_ecode(struct iwarp_terminate *term)
2390e935ae6SBernard Metzler {
2400e935ae6SBernard Metzler 	return term->ecode;
2410e935ae6SBernard Metzler }
2420e935ae6SBernard Metzler 
__rdmap_term_set_ecode(struct iwarp_terminate * term,u8 ecode)2430e935ae6SBernard Metzler static inline void __rdmap_term_set_ecode(struct iwarp_terminate *term,
2440e935ae6SBernard Metzler 					  u8 ecode)
2450e935ae6SBernard Metzler {
2460e935ae6SBernard Metzler 	term->ecode = ecode;
2470e935ae6SBernard Metzler }
2480e935ae6SBernard Metzler 
2490e935ae6SBernard Metzler /*
2500e935ae6SBernard Metzler  * Common portion of iWARP headers (MPA, DDP, RDMAP)
2510e935ae6SBernard Metzler  * for an FPDU carrying an untagged DDP segment
2520e935ae6SBernard Metzler  */
2530e935ae6SBernard Metzler struct iwarp_ctrl_untagged {
2540e935ae6SBernard Metzler 	struct iwarp_ctrl ctrl;
2550e935ae6SBernard Metzler 	__be32 rsvd;
2560e935ae6SBernard Metzler 	__be32 ddp_qn;
2570e935ae6SBernard Metzler 	__be32 ddp_msn;
2580e935ae6SBernard Metzler 	__be32 ddp_mo;
2590e935ae6SBernard Metzler };
2600e935ae6SBernard Metzler 
2610e935ae6SBernard Metzler /*
2620e935ae6SBernard Metzler  * Common portion of iWARP headers (MPA, DDP, RDMAP)
2630e935ae6SBernard Metzler  * for an FPDU carrying a tagged DDP segment
2640e935ae6SBernard Metzler  */
2650e935ae6SBernard Metzler struct iwarp_ctrl_tagged {
2660e935ae6SBernard Metzler 	struct iwarp_ctrl ctrl;
2670e935ae6SBernard Metzler 	__be32 ddp_stag;
2680e935ae6SBernard Metzler 	__be64 ddp_to;
2690e935ae6SBernard Metzler };
2700e935ae6SBernard Metzler 
2710e935ae6SBernard Metzler union iwarp_hdr {
2720e935ae6SBernard Metzler 	struct iwarp_ctrl ctrl;
2730e935ae6SBernard Metzler 	struct iwarp_ctrl_untagged c_untagged;
2740e935ae6SBernard Metzler 	struct iwarp_ctrl_tagged c_tagged;
2750e935ae6SBernard Metzler 	struct iwarp_rdma_write rwrite;
2760e935ae6SBernard Metzler 	struct iwarp_rdma_rreq rreq;
2770e935ae6SBernard Metzler 	struct iwarp_rdma_rresp rresp;
2780e935ae6SBernard Metzler 	struct iwarp_terminate terminate;
2790e935ae6SBernard Metzler 	struct iwarp_send send;
2800e935ae6SBernard Metzler 	struct iwarp_send_inv send_inv;
2810e935ae6SBernard Metzler };
2820e935ae6SBernard Metzler 
2830e935ae6SBernard Metzler enum term_elayer {
2840e935ae6SBernard Metzler 	TERM_ERROR_LAYER_RDMAP = 0x00,
2850e935ae6SBernard Metzler 	TERM_ERROR_LAYER_DDP = 0x01,
2860e935ae6SBernard Metzler 	TERM_ERROR_LAYER_LLP = 0x02 /* eg., MPA */
2870e935ae6SBernard Metzler };
2880e935ae6SBernard Metzler 
2890e935ae6SBernard Metzler enum ddp_etype {
2900e935ae6SBernard Metzler 	DDP_ETYPE_CATASTROPHIC = 0x0,
2910e935ae6SBernard Metzler 	DDP_ETYPE_TAGGED_BUF = 0x1,
2920e935ae6SBernard Metzler 	DDP_ETYPE_UNTAGGED_BUF = 0x2,
2930e935ae6SBernard Metzler 	DDP_ETYPE_RSVD = 0x3
2940e935ae6SBernard Metzler };
2950e935ae6SBernard Metzler 
2960e935ae6SBernard Metzler enum ddp_ecode {
2970e935ae6SBernard Metzler 	/* unspecified, set to zero */
2980e935ae6SBernard Metzler 	DDP_ECODE_CATASTROPHIC = 0x00,
2990e935ae6SBernard Metzler 	/* Tagged Buffer Errors */
3000e935ae6SBernard Metzler 	DDP_ECODE_T_INVALID_STAG = 0x00,
3010e935ae6SBernard Metzler 	DDP_ECODE_T_BASE_BOUNDS = 0x01,
3020e935ae6SBernard Metzler 	DDP_ECODE_T_STAG_NOT_ASSOC = 0x02,
3030e935ae6SBernard Metzler 	DDP_ECODE_T_TO_WRAP = 0x03,
3040e935ae6SBernard Metzler 	DDP_ECODE_T_VERSION = 0x04,
3050e935ae6SBernard Metzler 	/* Untagged Buffer Errors */
3060e935ae6SBernard Metzler 	DDP_ECODE_UT_INVALID_QN = 0x01,
3070e935ae6SBernard Metzler 	DDP_ECODE_UT_INVALID_MSN_NOBUF = 0x02,
3080e935ae6SBernard Metzler 	DDP_ECODE_UT_INVALID_MSN_RANGE = 0x03,
3090e935ae6SBernard Metzler 	DDP_ECODE_UT_INVALID_MO = 0x04,
3100e935ae6SBernard Metzler 	DDP_ECODE_UT_MSG_TOOLONG = 0x05,
3110e935ae6SBernard Metzler 	DDP_ECODE_UT_VERSION = 0x06
3120e935ae6SBernard Metzler };
3130e935ae6SBernard Metzler 
3140e935ae6SBernard Metzler enum rdmap_untagged_qn {
3150e935ae6SBernard Metzler 	RDMAP_UNTAGGED_QN_SEND = 0,
3160e935ae6SBernard Metzler 	RDMAP_UNTAGGED_QN_RDMA_READ = 1,
3170e935ae6SBernard Metzler 	RDMAP_UNTAGGED_QN_TERMINATE = 2,
3180e935ae6SBernard Metzler 	RDMAP_UNTAGGED_QN_COUNT = 3
3190e935ae6SBernard Metzler };
3200e935ae6SBernard Metzler 
3210e935ae6SBernard Metzler enum rdmap_etype {
3220e935ae6SBernard Metzler 	RDMAP_ETYPE_CATASTROPHIC = 0x0,
3230e935ae6SBernard Metzler 	RDMAP_ETYPE_REMOTE_PROTECTION = 0x1,
3240e935ae6SBernard Metzler 	RDMAP_ETYPE_REMOTE_OPERATION = 0x2
3250e935ae6SBernard Metzler };
3260e935ae6SBernard Metzler 
3270e935ae6SBernard Metzler enum rdmap_ecode {
3280e935ae6SBernard Metzler 	RDMAP_ECODE_INVALID_STAG = 0x00,
3290e935ae6SBernard Metzler 	RDMAP_ECODE_BASE_BOUNDS = 0x01,
3300e935ae6SBernard Metzler 	RDMAP_ECODE_ACCESS_RIGHTS = 0x02,
3310e935ae6SBernard Metzler 	RDMAP_ECODE_STAG_NOT_ASSOC = 0x03,
3320e935ae6SBernard Metzler 	RDMAP_ECODE_TO_WRAP = 0x04,
3330e935ae6SBernard Metzler 	RDMAP_ECODE_VERSION = 0x05,
3340e935ae6SBernard Metzler 	RDMAP_ECODE_OPCODE = 0x06,
3350e935ae6SBernard Metzler 	RDMAP_ECODE_CATASTROPHIC_STREAM = 0x07,
3360e935ae6SBernard Metzler 	RDMAP_ECODE_CATASTROPHIC_GLOBAL = 0x08,
3370e935ae6SBernard Metzler 	RDMAP_ECODE_CANNOT_INVALIDATE = 0x09,
3380e935ae6SBernard Metzler 	RDMAP_ECODE_UNSPECIFIED = 0xff
3390e935ae6SBernard Metzler };
3400e935ae6SBernard Metzler 
3410e935ae6SBernard Metzler enum llp_ecode {
3420e935ae6SBernard Metzler 	LLP_ECODE_TCP_STREAM_LOST = 0x01, /* How to transfer this ?? */
3430e935ae6SBernard Metzler 	LLP_ECODE_RECEIVED_CRC = 0x02,
3440e935ae6SBernard Metzler 	LLP_ECODE_FPDU_START = 0x03,
3450e935ae6SBernard Metzler 	LLP_ECODE_INVALID_REQ_RESP = 0x04,
3460e935ae6SBernard Metzler 
3470e935ae6SBernard Metzler 	/* Errors for Enhanced Connection Establishment only */
3480e935ae6SBernard Metzler 	LLP_ECODE_LOCAL_CATASTROPHIC = 0x05,
3490e935ae6SBernard Metzler 	LLP_ECODE_INSUFFICIENT_IRD = 0x06,
3500e935ae6SBernard Metzler 	LLP_ECODE_NO_MATCHING_RTR = 0x07
3510e935ae6SBernard Metzler };
3520e935ae6SBernard Metzler 
3530e935ae6SBernard Metzler enum llp_etype { LLP_ETYPE_MPA = 0x00 };
3540e935ae6SBernard Metzler 
3550e935ae6SBernard Metzler enum rdma_opcode {
3560e935ae6SBernard Metzler 	RDMAP_RDMA_WRITE = 0x0,
3570e935ae6SBernard Metzler 	RDMAP_RDMA_READ_REQ = 0x1,
3580e935ae6SBernard Metzler 	RDMAP_RDMA_READ_RESP = 0x2,
3590e935ae6SBernard Metzler 	RDMAP_SEND = 0x3,
3600e935ae6SBernard Metzler 	RDMAP_SEND_INVAL = 0x4,
3610e935ae6SBernard Metzler 	RDMAP_SEND_SE = 0x5,
3620e935ae6SBernard Metzler 	RDMAP_SEND_SE_INVAL = 0x6,
3630e935ae6SBernard Metzler 	RDMAP_TERMINATE = 0x7,
3640e935ae6SBernard Metzler 	RDMAP_NOT_SUPPORTED = RDMAP_TERMINATE + 1
3650e935ae6SBernard Metzler };
3660e935ae6SBernard Metzler 
3670e935ae6SBernard Metzler #endif
368