| /* |
| * This file is part of the Chelsio FCoE driver for Linux. |
| * |
| * Copyright (c) 2009-2010 Chelsio Communications, Inc. All rights reserved. |
| * |
| * This software is available to you under a choice of one of two |
| * licenses. You may choose to be licensed under the terms of the GNU |
| * General Public License (GPL) Version 2, available from the file |
| * COPYING in the main directory of this source tree, or the |
| * OpenIB.org BSD license below: |
| * |
| * Redistribution and use in source and binary forms, with or |
| * without modification, are permitted provided that the following |
| * conditions are met: |
| * |
| * - Redistributions of source code must retain the above |
| * copyright notice, this list of conditions and the following |
| * disclaimer. |
| * |
| * - Redistributions in binary form must reproduce the above |
| * copyright notice, this list of conditions and the following |
| * disclaimer in the documentation and/or other materials |
| * provided with the distribution. |
| * |
| * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
| * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
| * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
| * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS |
| * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN |
| * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN |
| * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE |
| * SOFTWARE. |
| */ |
| |
| #ifndef _T4FW_API_STOR_H_ |
| #define _T4FW_API_STOR_H_ |
| |
| |
| /****************************************************************************** |
| * R E T U R N V A L U E S |
| ********************************/ |
| |
| enum fw_retval { |
| FW_SUCCESS = 0, /* completed sucessfully */ |
| FW_EPERM = 1, /* operation not permitted */ |
| FW_ENOENT = 2, /* no such file or directory */ |
| FW_EIO = 5, /* input/output error; hw bad */ |
| FW_ENOEXEC = 8, /* exec format error; inv microcode */ |
| FW_EAGAIN = 11, /* try again */ |
| FW_ENOMEM = 12, /* out of memory */ |
| FW_EFAULT = 14, /* bad address; fw bad */ |
| FW_EBUSY = 16, /* resource busy */ |
| FW_EEXIST = 17, /* file exists */ |
| FW_EINVAL = 22, /* invalid argument */ |
| FW_ENOSPC = 28, /* no space left on device */ |
| FW_ENOSYS = 38, /* functionality not implemented */ |
| FW_EPROTO = 71, /* protocol error */ |
| FW_EADDRINUSE = 98, /* address already in use */ |
| FW_EADDRNOTAVAIL = 99, /* cannot assigned requested address */ |
| FW_ENETDOWN = 100, /* network is down */ |
| FW_ENETUNREACH = 101, /* network is unreachable */ |
| FW_ENOBUFS = 105, /* no buffer space available */ |
| FW_ETIMEDOUT = 110, /* timeout */ |
| FW_EINPROGRESS = 115, /* fw internal */ |
| FW_SCSI_ABORT_REQUESTED = 128, /* */ |
| FW_SCSI_ABORT_TIMEDOUT = 129, /* */ |
| FW_SCSI_ABORTED = 130, /* */ |
| FW_SCSI_CLOSE_REQUESTED = 131, /* */ |
| FW_ERR_LINK_DOWN = 132, /* */ |
| FW_RDEV_NOT_READY = 133, /* */ |
| FW_ERR_RDEV_LOST = 134, /* */ |
| FW_ERR_RDEV_LOGO = 135, /* */ |
| FW_FCOE_NO_XCHG = 136, /* */ |
| FW_SCSI_RSP_ERR = 137, /* */ |
| FW_ERR_RDEV_IMPL_LOGO = 138, /* */ |
| FW_SCSI_UNDER_FLOW_ERR = 139, /* */ |
| FW_SCSI_OVER_FLOW_ERR = 140, /* */ |
| FW_SCSI_DDP_ERR = 141, /* DDP error*/ |
| FW_SCSI_TASK_ERR = 142, /* No SCSI tasks available */ |
| }; |
| |
| enum fw_fcoe_link_sub_op { |
| FCOE_LINK_DOWN = 0x0, |
| FCOE_LINK_UP = 0x1, |
| FCOE_LINK_COND = 0x2, |
| }; |
| |
| enum fw_fcoe_link_status { |
| FCOE_LINKDOWN = 0x0, |
| FCOE_LINKUP = 0x1, |
| }; |
| |
| enum fw_ofld_prot { |
| PROT_FCOE = 0x1, |
| PROT_ISCSI = 0x2, |
| }; |
| |
| enum rport_type_fcoe { |
| FLOGI_VFPORT = 0x1, /* 0xfffffe */ |
| FDISC_VFPORT = 0x2, /* 0xfffffe */ |
| NS_VNPORT = 0x3, /* 0xfffffc */ |
| REG_FC4_VNPORT = 0x4, /* any FC4 type VN_PORT */ |
| REG_VNPORT = 0x5, /* 0xfffxxx - non FC4 port in switch */ |
| FDMI_VNPORT = 0x6, /* 0xfffffa */ |
| FAB_CTLR_VNPORT = 0x7, /* 0xfffffd */ |
| }; |
| |
| enum event_cause_fcoe { |
| PLOGI_ACC_RCVD = 0x01, |
| PLOGI_RJT_RCVD = 0x02, |
| PLOGI_RCVD = 0x03, |
| PLOGO_RCVD = 0x04, |
| PRLI_ACC_RCVD = 0x05, |
| PRLI_RJT_RCVD = 0x06, |
| PRLI_RCVD = 0x07, |
| PRLO_RCVD = 0x08, |
| NPORT_ID_CHGD = 0x09, |
| FLOGO_RCVD = 0x0a, |
| CLR_VIRT_LNK_RCVD = 0x0b, |
| FLOGI_ACC_RCVD = 0x0c, |
| FLOGI_RJT_RCVD = 0x0d, |
| FDISC_ACC_RCVD = 0x0e, |
| FDISC_RJT_RCVD = 0x0f, |
| FLOGI_TMO_MAX_RETRY = 0x10, |
| IMPL_LOGO_ADISC_ACC = 0x11, |
| IMPL_LOGO_ADISC_RJT = 0x12, |
| IMPL_LOGO_ADISC_CNFLT = 0x13, |
| PRLI_TMO = 0x14, |
| ADISC_TMO = 0x15, |
| RSCN_DEV_LOST = 0x16, |
| SCR_ACC_RCVD = 0x17, |
| ADISC_RJT_RCVD = 0x18, |
| LOGO_SNT = 0x19, |
| PROTO_ERR_IMPL_LOGO = 0x1a, |
| }; |
| |
| enum fcoe_cmn_type { |
| FCOE_ELS, |
| FCOE_CT, |
| FCOE_SCSI_CMD, |
| FCOE_UNSOL_ELS, |
| }; |
| |
| enum fw_wr_stor_opcodes { |
| FW_RDEV_WR = 0x38, |
| FW_FCOE_ELS_CT_WR = 0x30, |
| FW_SCSI_WRITE_WR = 0x31, |
| FW_SCSI_READ_WR = 0x32, |
| FW_SCSI_CMD_WR = 0x33, |
| FW_SCSI_ABRT_CLS_WR = 0x34, |
| }; |
| |
| struct fw_rdev_wr { |
| __be32 op_to_immdlen; |
| __be32 alloc_to_len16; |
| __be64 cookie; |
| u8 protocol; |
| u8 event_cause; |
| u8 cur_state; |
| u8 prev_state; |
| __be32 flags_to_assoc_flowid; |
| union rdev_entry { |
| struct fcoe_rdev_entry { |
| __be32 flowid; |
| u8 protocol; |
| u8 event_cause; |
| u8 flags; |
| u8 rjt_reason; |
| u8 cur_login_st; |
| u8 prev_login_st; |
| __be16 rcv_fr_sz; |
| u8 rd_xfer_rdy_to_rport_type; |
| u8 vft_to_qos; |
| u8 org_proc_assoc_to_acc_rsp_code; |
| u8 enh_disc_to_tgt; |
| u8 wwnn[8]; |
| u8 wwpn[8]; |
| __be16 iqid; |
| u8 fc_oui[3]; |
| u8 r_id[3]; |
| } fcoe_rdev; |
| struct iscsi_rdev_entry { |
| __be32 flowid; |
| u8 protocol; |
| u8 event_cause; |
| u8 flags; |
| u8 r3; |
| __be16 iscsi_opts; |
| __be16 tcp_opts; |
| __be16 ip_opts; |
| __be16 max_rcv_len; |
| __be16 max_snd_len; |
| __be16 first_brst_len; |
| __be16 max_brst_len; |
| __be16 r4; |
| __be16 def_time2wait; |
| __be16 def_time2ret; |
| __be16 nop_out_intrvl; |
| __be16 non_scsi_to; |
| __be16 isid; |
| __be16 tsid; |
| __be16 port; |
| __be16 tpgt; |
| u8 r5[6]; |
| __be16 iqid; |
| } iscsi_rdev; |
| } u; |
| }; |
| |
| #define FW_RDEV_WR_FLOWID_GET(x) (((x) >> 8) & 0xfffff) |
| #define FW_RDEV_WR_ASSOC_FLOWID_GET(x) (((x) >> 0) & 0xfffff) |
| #define FW_RDEV_WR_RPORT_TYPE_GET(x) (((x) >> 0) & 0x1f) |
| #define FW_RDEV_WR_NPIV_GET(x) (((x) >> 6) & 0x1) |
| #define FW_RDEV_WR_CLASS_GET(x) (((x) >> 4) & 0x3) |
| #define FW_RDEV_WR_TASK_RETRY_ID_GET(x) (((x) >> 5) & 0x1) |
| #define FW_RDEV_WR_RETRY_GET(x) (((x) >> 4) & 0x1) |
| #define FW_RDEV_WR_CONF_CMPL_GET(x) (((x) >> 3) & 0x1) |
| #define FW_RDEV_WR_INI_GET(x) (((x) >> 1) & 0x1) |
| #define FW_RDEV_WR_TGT_GET(x) (((x) >> 0) & 0x1) |
| |
| struct fw_fcoe_els_ct_wr { |
| __be32 op_immdlen; |
| __be32 flowid_len16; |
| __be64 cookie; |
| __be16 iqid; |
| u8 tmo_val; |
| u8 els_ct_type; |
| u8 ctl_pri; |
| u8 cp_en_class; |
| __be16 xfer_cnt; |
| u8 fl_to_sp; |
| u8 l_id[3]; |
| u8 r5; |
| u8 r_id[3]; |
| __be64 rsp_dmaaddr; |
| __be32 rsp_dmalen; |
| __be32 r6; |
| }; |
| |
| #define FW_FCOE_ELS_CT_WR_OPCODE(x) ((x) << 24) |
| #define FW_FCOE_ELS_CT_WR_OPCODE_GET(x) (((x) >> 24) & 0xff) |
| #define FW_FCOE_ELS_CT_WR_IMMDLEN(x) ((x) << 0) |
| #define FW_FCOE_ELS_CT_WR_IMMDLEN_GET(x) (((x) >> 0) & 0xff) |
| #define FW_FCOE_ELS_CT_WR_SP(x) ((x) << 0) |
| |
| struct fw_scsi_write_wr { |
| __be32 op_immdlen; |
| __be32 flowid_len16; |
| __be64 cookie; |
| __be16 iqid; |
| u8 tmo_val; |
| u8 use_xfer_cnt; |
| union fw_scsi_write_priv { |
| struct fcoe_write_priv { |
| u8 ctl_pri; |
| u8 cp_en_class; |
| u8 r3_lo[2]; |
| } fcoe; |
| struct iscsi_write_priv { |
| u8 r3[4]; |
| } iscsi; |
| } u; |
| __be32 xfer_cnt; |
| __be32 ini_xfer_cnt; |
| __be64 rsp_dmaaddr; |
| __be32 rsp_dmalen; |
| __be32 r4; |
| }; |
| |
| #define FW_SCSI_WRITE_WR_IMMDLEN(x) ((x) << 0) |
| |
| struct fw_scsi_read_wr { |
| __be32 op_immdlen; |
| __be32 flowid_len16; |
| __be64 cookie; |
| __be16 iqid; |
| u8 tmo_val; |
| u8 use_xfer_cnt; |
| union fw_scsi_read_priv { |
| struct fcoe_read_priv { |
| u8 ctl_pri; |
| u8 cp_en_class; |
| u8 r3_lo[2]; |
| } fcoe; |
| struct iscsi_read_priv { |
| u8 r3[4]; |
| } iscsi; |
| } u; |
| __be32 xfer_cnt; |
| __be32 ini_xfer_cnt; |
| __be64 rsp_dmaaddr; |
| __be32 rsp_dmalen; |
| __be32 r4; |
| }; |
| |
| #define FW_SCSI_READ_WR_IMMDLEN(x) ((x) << 0) |
| |
| struct fw_scsi_cmd_wr { |
| __be32 op_immdlen; |
| __be32 flowid_len16; |
| __be64 cookie; |
| __be16 iqid; |
| u8 tmo_val; |
| u8 r3; |
| union fw_scsi_cmd_priv { |
| struct fcoe_cmd_priv { |
| u8 ctl_pri; |
| u8 cp_en_class; |
| u8 r4_lo[2]; |
| } fcoe; |
| struct iscsi_cmd_priv { |
| u8 r4[4]; |
| } iscsi; |
| } u; |
| u8 r5[8]; |
| __be64 rsp_dmaaddr; |
| __be32 rsp_dmalen; |
| __be32 r6; |
| }; |
| |
| #define FW_SCSI_CMD_WR_IMMDLEN(x) ((x) << 0) |
| |
| #define SCSI_ABORT 0 |
| #define SCSI_CLOSE 1 |
| |
| struct fw_scsi_abrt_cls_wr { |
| __be32 op_immdlen; |
| __be32 flowid_len16; |
| __be64 cookie; |
| __be16 iqid; |
| u8 tmo_val; |
| u8 sub_opcode_to_chk_all_io; |
| u8 r3[4]; |
| __be64 t_cookie; |
| }; |
| |
| #define FW_SCSI_ABRT_CLS_WR_SUB_OPCODE(x) ((x) << 2) |
| #define FW_SCSI_ABRT_CLS_WR_SUB_OPCODE_GET(x) (((x) >> 2) & 0x3f) |
| #define FW_SCSI_ABRT_CLS_WR_CHK_ALL_IO(x) ((x) << 0) |
| |
| enum fw_cmd_stor_opcodes { |
| FW_FCOE_RES_INFO_CMD = 0x31, |
| FW_FCOE_LINK_CMD = 0x32, |
| FW_FCOE_VNP_CMD = 0x33, |
| FW_FCOE_SPARAMS_CMD = 0x35, |
| FW_FCOE_STATS_CMD = 0x37, |
| FW_FCOE_FCF_CMD = 0x38, |
| }; |
| |
| struct fw_fcoe_res_info_cmd { |
| __be32 op_to_read; |
| __be32 retval_len16; |
| __be16 e_d_tov; |
| __be16 r_a_tov_seq; |
| __be16 r_a_tov_els; |
| __be16 r_r_tov; |
| __be32 max_xchgs; |
| __be32 max_ssns; |
| __be32 used_xchgs; |
| __be32 used_ssns; |
| __be32 max_fcfs; |
| __be32 max_vnps; |
| __be32 used_fcfs; |
| __be32 used_vnps; |
| }; |
| |
| struct fw_fcoe_link_cmd { |
| __be32 op_to_portid; |
| __be32 retval_len16; |
| __be32 sub_opcode_fcfi; |
| u8 r3; |
| u8 lstatus; |
| __be16 flags; |
| u8 r4; |
| u8 set_vlan; |
| __be16 vlan_id; |
| __be32 vnpi_pkd; |
| __be16 r6; |
| u8 phy_mac[6]; |
| u8 vnport_wwnn[8]; |
| u8 vnport_wwpn[8]; |
| }; |
| |
| #define FW_FCOE_LINK_CMD_PORTID(x) ((x) << 0) |
| #define FW_FCOE_LINK_CMD_PORTID_GET(x) (((x) >> 0) & 0xf) |
| #define FW_FCOE_LINK_CMD_SUB_OPCODE(x) ((x) << 24U) |
| #define FW_FCOE_LINK_CMD_FCFI(x) ((x) << 0) |
| #define FW_FCOE_LINK_CMD_FCFI_GET(x) (((x) >> 0) & 0xffffff) |
| #define FW_FCOE_LINK_CMD_VNPI_GET(x) (((x) >> 0) & 0xfffff) |
| |
| struct fw_fcoe_vnp_cmd { |
| __be32 op_to_fcfi; |
| __be32 alloc_to_len16; |
| __be32 gen_wwn_to_vnpi; |
| __be32 vf_id; |
| __be16 iqid; |
| u8 vnport_mac[6]; |
| u8 vnport_wwnn[8]; |
| u8 vnport_wwpn[8]; |
| u8 cmn_srv_parms[16]; |
| u8 clsp_word_0_1[8]; |
| }; |
| |
| #define FW_FCOE_VNP_CMD_FCFI(x) ((x) << 0) |
| #define FW_FCOE_VNP_CMD_ALLOC (1U << 31) |
| #define FW_FCOE_VNP_CMD_FREE (1U << 30) |
| #define FW_FCOE_VNP_CMD_MODIFY (1U << 29) |
| #define FW_FCOE_VNP_CMD_GEN_WWN (1U << 22) |
| #define FW_FCOE_VNP_CMD_VFID_EN (1U << 20) |
| #define FW_FCOE_VNP_CMD_VNPI(x) ((x) << 0) |
| #define FW_FCOE_VNP_CMD_VNPI_GET(x) (((x) >> 0) & 0xfffff) |
| |
| struct fw_fcoe_sparams_cmd { |
| __be32 op_to_portid; |
| __be32 retval_len16; |
| u8 r3[7]; |
| u8 cos; |
| u8 lport_wwnn[8]; |
| u8 lport_wwpn[8]; |
| u8 cmn_srv_parms[16]; |
| u8 cls_srv_parms[16]; |
| }; |
| |
| #define FW_FCOE_SPARAMS_CMD_PORTID(x) ((x) << 0) |
| |
| struct fw_fcoe_stats_cmd { |
| __be32 op_to_flowid; |
| __be32 free_to_len16; |
| union fw_fcoe_stats { |
| struct fw_fcoe_stats_ctl { |
| u8 nstats_port; |
| u8 port_valid_ix; |
| __be16 r6; |
| __be32 r7; |
| __be64 stat0; |
| __be64 stat1; |
| __be64 stat2; |
| __be64 stat3; |
| __be64 stat4; |
| __be64 stat5; |
| } ctl; |
| struct fw_fcoe_port_stats { |
| __be64 tx_bcast_bytes; |
| __be64 tx_bcast_frames; |
| __be64 tx_mcast_bytes; |
| __be64 tx_mcast_frames; |
| __be64 tx_ucast_bytes; |
| __be64 tx_ucast_frames; |
| __be64 tx_drop_frames; |
| __be64 tx_offload_bytes; |
| __be64 tx_offload_frames; |
| __be64 rx_bcast_bytes; |
| __be64 rx_bcast_frames; |
| __be64 rx_mcast_bytes; |
| __be64 rx_mcast_frames; |
| __be64 rx_ucast_bytes; |
| __be64 rx_ucast_frames; |
| __be64 rx_err_frames; |
| } port_stats; |
| struct fw_fcoe_fcf_stats { |
| __be32 fip_tx_bytes; |
| __be32 fip_tx_fr; |
| __be64 fcf_ka; |
| __be64 mcast_adv_rcvd; |
| __be16 ucast_adv_rcvd; |
| __be16 sol_sent; |
| __be16 vlan_req; |
| __be16 vlan_rpl; |
| __be16 clr_vlink; |
| __be16 link_down; |
| __be16 link_up; |
| __be16 logo; |
| __be16 flogi_req; |
| __be16 flogi_rpl; |
| __be16 fdisc_req; |
| __be16 fdisc_rpl; |
| __be16 fka_prd_chg; |
| __be16 fc_map_chg; |
| __be16 vfid_chg; |
| u8 no_fka_req; |
| u8 no_vnp; |
| } fcf_stats; |
| struct fw_fcoe_pcb_stats { |
| __be64 tx_bytes; |
| __be64 tx_frames; |
| __be64 rx_bytes; |
| __be64 rx_frames; |
| __be32 vnp_ka; |
| __be32 unsol_els_rcvd; |
| __be64 unsol_cmd_rcvd; |
| __be16 implicit_logo; |
| __be16 flogi_inv_sparm; |
| __be16 fdisc_inv_sparm; |
| __be16 flogi_rjt; |
| __be16 fdisc_rjt; |
| __be16 no_ssn; |
| __be16 mac_flt_fail; |
| __be16 inv_fr_rcvd; |
| } pcb_stats; |
| struct fw_fcoe_scb_stats { |
| __be64 tx_bytes; |
| __be64 tx_frames; |
| __be64 rx_bytes; |
| __be64 rx_frames; |
| __be32 host_abrt_req; |
| __be32 adap_auto_abrt; |
| __be32 adap_abrt_rsp; |
| __be32 host_ios_req; |
| __be16 ssn_offl_ios; |
| __be16 ssn_not_rdy_ios; |
| u8 rx_data_ddp_err; |
| u8 ddp_flt_set_err; |
| __be16 rx_data_fr_err; |
| u8 bad_st_abrt_req; |
| u8 no_io_abrt_req; |
| u8 abort_tmo; |
| u8 abort_tmo_2; |
| __be32 abort_req; |
| u8 no_ppod_res_tmo; |
| u8 bp_tmo; |
| u8 adap_auto_cls; |
| u8 no_io_cls_req; |
| __be32 host_cls_req; |
| __be64 unsol_cmd_rcvd; |
| __be32 plogi_req_rcvd; |
| __be32 prli_req_rcvd; |
| __be16 logo_req_rcvd; |
| __be16 prlo_req_rcvd; |
| __be16 plogi_rjt_rcvd; |
| __be16 prli_rjt_rcvd; |
| __be32 adisc_req_rcvd; |
| __be32 rscn_rcvd; |
| __be32 rrq_req_rcvd; |
| __be32 unsol_els_rcvd; |
| u8 adisc_rjt_rcvd; |
| u8 scr_rjt; |
| u8 ct_rjt; |
| u8 inval_bls_rcvd; |
| __be32 ba_rjt_rcvd; |
| } scb_stats; |
| } u; |
| }; |
| |
| #define FW_FCOE_STATS_CMD_FLOWID(x) ((x) << 0) |
| #define FW_FCOE_STATS_CMD_FREE (1U << 30) |
| #define FW_FCOE_STATS_CMD_NSTATS(x) ((x) << 4) |
| #define FW_FCOE_STATS_CMD_PORT(x) ((x) << 0) |
| #define FW_FCOE_STATS_CMD_PORT_VALID (1U << 7) |
| #define FW_FCOE_STATS_CMD_IX(x) ((x) << 0) |
| |
| struct fw_fcoe_fcf_cmd { |
| __be32 op_to_fcfi; |
| __be32 retval_len16; |
| __be16 priority_pkd; |
| u8 mac[6]; |
| u8 name_id[8]; |
| u8 fabric[8]; |
| __be16 vf_id; |
| __be16 max_fcoe_size; |
| u8 vlan_id; |
| u8 fc_map[3]; |
| __be32 fka_adv; |
| __be32 r6; |
| u8 r7_hi; |
| u8 fpma_to_portid; |
| u8 spma_mac[6]; |
| __be64 r8; |
| }; |
| |
| #define FW_FCOE_FCF_CMD_FCFI(x) ((x) << 0) |
| #define FW_FCOE_FCF_CMD_FCFI_GET(x) (((x) >> 0) & 0xfffff) |
| #define FW_FCOE_FCF_CMD_PRIORITY_GET(x) (((x) >> 0) & 0xff) |
| #define FW_FCOE_FCF_CMD_FPMA_GET(x) (((x) >> 6) & 0x1) |
| #define FW_FCOE_FCF_CMD_SPMA_GET(x) (((x) >> 5) & 0x1) |
| #define FW_FCOE_FCF_CMD_LOGIN_GET(x) (((x) >> 4) & 0x1) |
| #define FW_FCOE_FCF_CMD_PORTID_GET(x) (((x) >> 0) & 0xf) |
| |
| #endif /* _T4FW_API_STOR_H_ */ |