0001
0002
0003
0004
0005
0006 #ifndef __QLA_NVME_H
0007 #define __QLA_NVME_H
0008
0009 #include <uapi/scsi/fc/fc_fs.h>
0010 #include <uapi/scsi/fc/fc_els.h>
0011 #include <linux/nvme-fc-driver.h>
0012
0013 #include "qla_def.h"
0014 #include "qla_dsd.h"
0015
0016 #define MIN_NVME_HW_QUEUES 1
0017 #define DEF_NVME_HW_QUEUES 8
0018
0019 #define NVME_ATIO_CMD_OFF 32
0020 #define NVME_FIRST_PACKET_CMDLEN (64 - NVME_ATIO_CMD_OFF)
0021 #define Q2T_NVME_NUM_TAGS 2048
0022 #define QLA_MAX_FC_SEGMENTS 64
0023
0024 struct scsi_qla_host;
0025 struct qla_hw_data;
0026 struct req_que;
0027 struct srb;
0028
0029 struct nvme_private {
0030 struct srb *sp;
0031 struct nvmefc_ls_req *fd;
0032 struct work_struct ls_work;
0033 struct work_struct abort_work;
0034 int comp_status;
0035 spinlock_t cmd_lock;
0036 };
0037
0038 struct qla_nvme_rport {
0039 struct fc_port *fcport;
0040 };
0041
0042 #define COMMAND_NVME 0x88
0043 struct cmd_nvme {
0044 uint8_t entry_type;
0045 uint8_t entry_count;
0046 uint8_t sys_define;
0047 uint8_t entry_status;
0048
0049 uint32_t handle;
0050 __le16 nport_handle;
0051 __le16 timeout;
0052
0053 __le16 dseg_count;
0054 __le16 nvme_rsp_dsd_len;
0055
0056 uint64_t rsvd;
0057
0058 __le16 control_flags;
0059 #define CF_ADMIN_ASYNC_EVENT BIT_13
0060 #define CF_NVME_FIRST_BURST_ENABLE BIT_11
0061 #define CF_DIF_SEG_DESCR_ENABLE BIT_3
0062 #define CF_DATA_SEG_DESCR_ENABLE BIT_2
0063 #define CF_READ_DATA BIT_1
0064 #define CF_WRITE_DATA BIT_0
0065
0066 __le16 nvme_cmnd_dseg_len;
0067 __le64 nvme_cmnd_dseg_address __packed;
0068 __le64 nvme_rsp_dseg_address __packed;
0069
0070 __le32 byte_count;
0071
0072 uint8_t port_id[3];
0073 uint8_t vp_index;
0074
0075 struct dsd64 nvme_dsd;
0076 };
0077
0078 #define PT_LS4_REQUEST 0x89
0079 struct pt_ls4_request {
0080 uint8_t entry_type;
0081 uint8_t entry_count;
0082 uint8_t sys_define;
0083 uint8_t entry_status;
0084 uint32_t handle;
0085 __le16 status;
0086 __le16 nport_handle;
0087 __le16 tx_dseg_count;
0088 uint8_t vp_index;
0089 uint8_t rsvd;
0090 __le16 timeout;
0091 __le16 control_flags;
0092 #define CF_LS4_SHIFT 13
0093 #define CF_LS4_ORIGINATOR 0
0094 #define CF_LS4_RESPONDER 1
0095 #define CF_LS4_RESPONDER_TERM 2
0096
0097 __le16 rx_dseg_count;
0098 __le16 rsvd2;
0099 __le32 exchange_address;
0100 __le32 rsvd3;
0101 __le32 rx_byte_count;
0102 __le32 tx_byte_count;
0103 struct dsd64 dsd[2];
0104 };
0105
0106 #define PT_LS4_UNSOL 0x56
0107 struct pt_ls4_rx_unsol {
0108 uint8_t entry_type;
0109 uint8_t entry_count;
0110 __le16 rsvd0;
0111 __le16 rsvd1;
0112 uint8_t vp_index;
0113 uint8_t rsvd2;
0114 __le16 rsvd3;
0115 __le16 nport_handle;
0116 __le16 frame_size;
0117 __le16 rsvd4;
0118 __le32 exchange_address;
0119 uint8_t d_id[3];
0120 uint8_t r_ctl;
0121 be_id_t s_id;
0122 uint8_t cs_ctl;
0123 uint8_t f_ctl[3];
0124 uint8_t type;
0125 __le16 seq_cnt;
0126 uint8_t df_ctl;
0127 uint8_t seq_id;
0128 __le16 rx_id;
0129 __le16 ox_id;
0130 __le32 param;
0131 __le32 desc0;
0132 #define PT_LS4_PAYLOAD_OFFSET 0x2c
0133 #define PT_LS4_FIRST_PACKET_LEN 20
0134 __le32 desc_len;
0135 __le32 payload[3];
0136 };
0137
0138
0139
0140
0141 int qla_nvme_register_hba(struct scsi_qla_host *);
0142 int qla_nvme_register_remote(struct scsi_qla_host *, struct fc_port *);
0143 void qla_nvme_delete(struct scsi_qla_host *);
0144 void qla24xx_nvme_ls4_iocb(struct scsi_qla_host *, struct pt_ls4_request *,
0145 struct req_que *);
0146 void qla24xx_async_gffid_sp_done(struct srb *sp, int);
0147 #endif