1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*
3  * NVMe over Fabrics TCP protocol header.
4  * Copyright (c) 2018 Lightbits Labs. All rights reserved.
5  */
6 
7 #ifndef _LINUX_NVME_TCP_H
8 #define _LINUX_NVME_TCP_H
9 
10 #include <linux/nvme.h>
11 
12 #define NVME_TCP_DISC_PORT	8009
13 #define NVME_TCP_ADMIN_CCSZ	SZ_8K
14 #define NVME_TCP_DIGEST_LENGTH	4
15 #define NVME_TCP_MIN_MAXH2CDATA 4096
16 
17 enum nvme_tcp_pfv {
18 	NVME_TCP_PFV_1_0 = 0x0,
19 };
20 
21 enum nvme_tcp_tls_cipher {
22 	NVME_TCP_TLS_CIPHER_INVALID     = 0,
23 	NVME_TCP_TLS_CIPHER_SHA256      = 1,
24 	NVME_TCP_TLS_CIPHER_SHA384      = 2,
25 };
26 
27 enum nvme_tcp_fatal_error_status {
28 	NVME_TCP_FES_INVALID_PDU_HDR		= 0x01,
29 	NVME_TCP_FES_PDU_SEQ_ERR		= 0x02,
30 	NVME_TCP_FES_HDR_DIGEST_ERR		= 0x03,
31 	NVME_TCP_FES_DATA_OUT_OF_RANGE		= 0x04,
32 	NVME_TCP_FES_R2T_LIMIT_EXCEEDED		= 0x05,
33 	NVME_TCP_FES_DATA_LIMIT_EXCEEDED	= 0x05,
34 	NVME_TCP_FES_UNSUPPORTED_PARAM		= 0x06,
35 };
36 
37 enum nvme_tcp_digest_option {
38 	NVME_TCP_HDR_DIGEST_ENABLE	= (1 << 0),
39 	NVME_TCP_DATA_DIGEST_ENABLE	= (1 << 1),
40 };
41 
42 enum nvme_tcp_pdu_type {
43 	nvme_tcp_icreq		= 0x0,
44 	nvme_tcp_icresp		= 0x1,
45 	nvme_tcp_h2c_term	= 0x2,
46 	nvme_tcp_c2h_term	= 0x3,
47 	nvme_tcp_cmd		= 0x4,
48 	nvme_tcp_rsp		= 0x5,
49 	nvme_tcp_h2c_data	= 0x6,
50 	nvme_tcp_c2h_data	= 0x7,
51 	nvme_tcp_r2t		= 0x9,
52 };
53 
54 enum nvme_tcp_pdu_flags {
55 	NVME_TCP_F_HDGST		= (1 << 0),
56 	NVME_TCP_F_DDGST		= (1 << 1),
57 	NVME_TCP_F_DATA_LAST		= (1 << 2),
58 	NVME_TCP_F_DATA_SUCCESS		= (1 << 3),
59 };
60 
61 /**
62  * struct nvme_tcp_hdr - nvme tcp pdu common header
63  *
64  * @type:          pdu type
65  * @flags:         pdu specific flags
66  * @hlen:          pdu header length
67  * @pdo:           pdu data offset
68  * @plen:          pdu wire byte length
69  */
70 struct nvme_tcp_hdr {
71 	__u8	type;
72 	__u8	flags;
73 	__u8	hlen;
74 	__u8	pdo;
75 	__le32	plen;
76 };
77 
78 /**
79  * struct nvme_tcp_icreq_pdu - nvme tcp initialize connection request pdu
80  *
81  * @hdr:           pdu generic header
82  * @pfv:           pdu version format
83  * @hpda:          host pdu data alignment (dwords, 0's based)
84  * @digest:        digest types enabled
85  * @maxr2t:        maximum r2ts per request supported
86  */
87 struct nvme_tcp_icreq_pdu {
88 	struct nvme_tcp_hdr	hdr;
89 	__le16			pfv;
90 	__u8			hpda;
91 	__u8			digest;
92 	__le32			maxr2t;
93 	__u8			rsvd2[112];
94 };
95 
96 /**
97  * struct nvme_tcp_icresp_pdu - nvme tcp initialize connection response pdu
98  *
99  * @hdr:           pdu common header
100  * @pfv:           pdu version format
101  * @cpda:          controller pdu data alignment (dowrds, 0's based)
102  * @digest:        digest types enabled
103  * @maxdata:       maximum data capsules per r2t supported
104  */
105 struct nvme_tcp_icresp_pdu {
106 	struct nvme_tcp_hdr	hdr;
107 	__le16			pfv;
108 	__u8			cpda;
109 	__u8			digest;
110 	__le32			maxdata;
111 	__u8			rsvd[112];
112 };
113 
114 /**
115  * struct nvme_tcp_term_pdu - nvme tcp terminate connection pdu
116  *
117  * @hdr:           pdu common header
118  * @fes:           fatal error status
119  * @fei:           fatal error information
120  */
121 struct nvme_tcp_term_pdu {
122 	struct nvme_tcp_hdr	hdr;
123 	__le16			fes;
124 	__le16			feil;
125 	__le16			feiu;
126 	__u8			rsvd[10];
127 };
128 
129 /**
130  * struct nvme_tcp_cmd_pdu - nvme tcp command capsule pdu
131  *
132  * @hdr:           pdu common header
133  * @cmd:           nvme command
134  */
135 struct nvme_tcp_cmd_pdu {
136 	struct nvme_tcp_hdr	hdr;
137 	struct nvme_command	cmd;
138 };
139 
140 /**
141  * struct nvme_tcp_rsp_pdu - nvme tcp response capsule pdu
142  *
143  * @hdr:           pdu common header
144  * @hdr:           nvme-tcp generic header
145  * @cqe:           nvme completion queue entry
146  */
147 struct nvme_tcp_rsp_pdu {
148 	struct nvme_tcp_hdr	hdr;
149 	struct nvme_completion	cqe;
150 };
151 
152 /**
153  * struct nvme_tcp_r2t_pdu - nvme tcp ready-to-transfer pdu
154  *
155  * @hdr:           pdu common header
156  * @command_id:    nvme command identifier which this relates to
157  * @ttag:          transfer tag (controller generated)
158  * @r2t_offset:    offset from the start of the command data
159  * @r2t_length:    length the host is allowed to send
160  */
161 struct nvme_tcp_r2t_pdu {
162 	struct nvme_tcp_hdr	hdr;
163 	__u16			command_id;
164 	__u16			ttag;
165 	__le32			r2t_offset;
166 	__le32			r2t_length;
167 	__u8			rsvd[4];
168 };
169 
170 /**
171  * struct nvme_tcp_data_pdu - nvme tcp data pdu
172  *
173  * @hdr:           pdu common header
174  * @command_id:    nvme command identifier which this relates to
175  * @ttag:          transfer tag (controller generated)
176  * @data_offset:   offset from the start of the command data
177  * @data_length:   length of the data stream
178  */
179 struct nvme_tcp_data_pdu {
180 	struct nvme_tcp_hdr	hdr;
181 	__u16			command_id;
182 	__u16			ttag;
183 	__le32			data_offset;
184 	__le32			data_length;
185 	__u8			rsvd[4];
186 };
187 
188 union nvme_tcp_pdu {
189 	struct nvme_tcp_icreq_pdu	icreq;
190 	struct nvme_tcp_icresp_pdu	icresp;
191 	struct nvme_tcp_cmd_pdu		cmd;
192 	struct nvme_tcp_rsp_pdu		rsp;
193 	struct nvme_tcp_r2t_pdu		r2t;
194 	struct nvme_tcp_data_pdu	data;
195 };
196 
197 #endif /* _LINUX_NVME_TCP_H */
198