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
17enum nvme_tcp_pfv {
18 NVME_TCP_PFV_1_0 = 0x0,
19};
20
21enum 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
27enum 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
37enum nvme_tcp_digest_option {
38 NVME_TCP_HDR_DIGEST_ENABLE = (1 << 0),
39 NVME_TCP_DATA_DIGEST_ENABLE = (1 << 1),
40};
41
42enum 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
54enum 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 */
70struct 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 */
87struct 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 */
105struct 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 */
121struct 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 */
135struct 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 */
147struct 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 */
161struct 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 */
179struct 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
188union 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

source code of linux/include/linux/nvme-tcp.h