cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

nvme-tcp.h (4541B)


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