root/drivers/scsi/csiostor/t4fw_api_stor.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


   1 /*
   2  * This file is part of the Chelsio FCoE driver for Linux.
   3  *
   4  * Copyright (c) 2009-2010 Chelsio Communications, Inc. All rights reserved.
   5  *
   6  * This software is available to you under a choice of one of two
   7  * licenses.  You may choose to be licensed under the terms of the GNU
   8  * General Public License (GPL) Version 2, available from the file
   9  * COPYING in the main directory of this source tree, or the
  10  * OpenIB.org BSD license below:
  11  *
  12  *     Redistribution and use in source and binary forms, with or
  13  *     without modification, are permitted provided that the following
  14  *     conditions are met:
  15  *
  16  *      - Redistributions of source code must retain the above
  17  *        copyright notice, this list of conditions and the following
  18  *        disclaimer.
  19  *
  20  *      - Redistributions in binary form must reproduce the above
  21  *        copyright notice, this list of conditions and the following
  22  *        disclaimer in the documentation and/or other materials
  23  *        provided with the distribution.
  24  *
  25  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  26  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  27  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  28  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
  29  * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  30  * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  31  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  32  * SOFTWARE.
  33  */
  34 
  35 #ifndef _T4FW_API_STOR_H_
  36 #define _T4FW_API_STOR_H_
  37 
  38 
  39 /******************************************************************************
  40  *   R E T U R N   V A L U E S
  41  ********************************/
  42 
  43 enum fw_fcoe_link_sub_op {
  44         FCOE_LINK_DOWN  = 0x0,
  45         FCOE_LINK_UP    = 0x1,
  46         FCOE_LINK_COND  = 0x2,
  47 };
  48 
  49 enum fw_fcoe_link_status {
  50         FCOE_LINKDOWN   = 0x0,
  51         FCOE_LINKUP     = 0x1,
  52 };
  53 
  54 enum fw_ofld_prot {
  55         PROT_FCOE       = 0x1,
  56         PROT_ISCSI      = 0x2,
  57 };
  58 
  59 enum rport_type_fcoe {
  60         FLOGI_VFPORT    = 0x1,          /* 0xfffffe */
  61         FDISC_VFPORT    = 0x2,          /* 0xfffffe */
  62         NS_VNPORT       = 0x3,          /* 0xfffffc */
  63         REG_FC4_VNPORT  = 0x4,          /* any FC4 type VN_PORT */
  64         REG_VNPORT      = 0x5,          /* 0xfffxxx - non FC4 port in switch */
  65         FDMI_VNPORT     = 0x6,          /* 0xfffffa */
  66         FAB_CTLR_VNPORT = 0x7,          /* 0xfffffd */
  67 };
  68 
  69 enum event_cause_fcoe {
  70         PLOGI_ACC_RCVD          = 0x01,
  71         PLOGI_RJT_RCVD          = 0x02,
  72         PLOGI_RCVD              = 0x03,
  73         PLOGO_RCVD              = 0x04,
  74         PRLI_ACC_RCVD           = 0x05,
  75         PRLI_RJT_RCVD           = 0x06,
  76         PRLI_RCVD               = 0x07,
  77         PRLO_RCVD               = 0x08,
  78         NPORT_ID_CHGD           = 0x09,
  79         FLOGO_RCVD              = 0x0a,
  80         CLR_VIRT_LNK_RCVD       = 0x0b,
  81         FLOGI_ACC_RCVD          = 0x0c,
  82         FLOGI_RJT_RCVD          = 0x0d,
  83         FDISC_ACC_RCVD          = 0x0e,
  84         FDISC_RJT_RCVD          = 0x0f,
  85         FLOGI_TMO_MAX_RETRY     = 0x10,
  86         IMPL_LOGO_ADISC_ACC     = 0x11,
  87         IMPL_LOGO_ADISC_RJT     = 0x12,
  88         IMPL_LOGO_ADISC_CNFLT   = 0x13,
  89         PRLI_TMO                = 0x14,
  90         ADISC_TMO               = 0x15,
  91         RSCN_DEV_LOST           = 0x16,
  92         SCR_ACC_RCVD            = 0x17,
  93         ADISC_RJT_RCVD          = 0x18,
  94         LOGO_SNT                = 0x19,
  95         PROTO_ERR_IMPL_LOGO     = 0x1a,
  96 };
  97 
  98 enum fcoe_cmn_type {
  99         FCOE_ELS,
 100         FCOE_CT,
 101         FCOE_SCSI_CMD,
 102         FCOE_UNSOL_ELS,
 103 };
 104 
 105 enum fw_wr_stor_opcodes {
 106         FW_RDEV_WR                     = 0x38,
 107         FW_FCOE_ELS_CT_WR              = 0x30,
 108         FW_SCSI_WRITE_WR               = 0x31,
 109         FW_SCSI_READ_WR                = 0x32,
 110         FW_SCSI_CMD_WR                 = 0x33,
 111         FW_SCSI_ABRT_CLS_WR            = 0x34,
 112 };
 113 
 114 struct fw_rdev_wr {
 115         __be32 op_to_immdlen;
 116         __be32 alloc_to_len16;
 117         __be64 cookie;
 118         u8     protocol;
 119         u8     event_cause;
 120         u8     cur_state;
 121         u8     prev_state;
 122         __be32 flags_to_assoc_flowid;
 123         union rdev_entry {
 124                 struct fcoe_rdev_entry {
 125                         __be32 flowid;
 126                         u8     protocol;
 127                         u8     event_cause;
 128                         u8     flags;
 129                         u8     rjt_reason;
 130                         u8     cur_login_st;
 131                         u8     prev_login_st;
 132                         __be16 rcv_fr_sz;
 133                         u8     rd_xfer_rdy_to_rport_type;
 134                         u8     vft_to_qos;
 135                         u8     org_proc_assoc_to_acc_rsp_code;
 136                         u8     enh_disc_to_tgt;
 137                         u8     wwnn[8];
 138                         u8     wwpn[8];
 139                         __be16 iqid;
 140                         u8     fc_oui[3];
 141                         u8     r_id[3];
 142                 } fcoe_rdev;
 143                 struct iscsi_rdev_entry {
 144                         __be32 flowid;
 145                         u8     protocol;
 146                         u8     event_cause;
 147                         u8     flags;
 148                         u8     r3;
 149                         __be16 iscsi_opts;
 150                         __be16 tcp_opts;
 151                         __be16 ip_opts;
 152                         __be16 max_rcv_len;
 153                         __be16 max_snd_len;
 154                         __be16 first_brst_len;
 155                         __be16 max_brst_len;
 156                         __be16 r4;
 157                         __be16 def_time2wait;
 158                         __be16 def_time2ret;
 159                         __be16 nop_out_intrvl;
 160                         __be16 non_scsi_to;
 161                         __be16 isid;
 162                         __be16 tsid;
 163                         __be16 port;
 164                         __be16 tpgt;
 165                         u8     r5[6];
 166                         __be16 iqid;
 167                 } iscsi_rdev;
 168         } u;
 169 };
 170 
 171 #define FW_RDEV_WR_FLOWID_GET(x)        (((x) >> 8) & 0xfffff)
 172 #define FW_RDEV_WR_ASSOC_FLOWID_GET(x)  (((x) >> 0) & 0xfffff)
 173 #define FW_RDEV_WR_RPORT_TYPE_GET(x)    (((x) >> 0) & 0x1f)
 174 #define FW_RDEV_WR_NPIV_GET(x)          (((x) >> 6) & 0x1)
 175 #define FW_RDEV_WR_CLASS_GET(x)         (((x) >> 4) & 0x3)
 176 #define FW_RDEV_WR_TASK_RETRY_ID_GET(x) (((x) >> 5) & 0x1)
 177 #define FW_RDEV_WR_RETRY_GET(x)         (((x) >> 4) & 0x1)
 178 #define FW_RDEV_WR_CONF_CMPL_GET(x)     (((x) >> 3) & 0x1)
 179 #define FW_RDEV_WR_INI_GET(x)           (((x) >> 1) & 0x1)
 180 #define FW_RDEV_WR_TGT_GET(x)           (((x) >> 0) & 0x1)
 181 
 182 struct fw_fcoe_els_ct_wr {
 183         __be32 op_immdlen;
 184         __be32 flowid_len16;
 185         u64    cookie;
 186         __be16 iqid;
 187         u8     tmo_val;
 188         u8     els_ct_type;
 189         u8     ctl_pri;
 190         u8     cp_en_class;
 191         __be16 xfer_cnt;
 192         u8     fl_to_sp;
 193         u8     l_id[3];
 194         u8     r5;
 195         u8     r_id[3];
 196         __be64 rsp_dmaaddr;
 197         __be32 rsp_dmalen;
 198         __be32 r6;
 199 };
 200 
 201 #define FW_FCOE_ELS_CT_WR_OPCODE(x)             ((x) << 24)
 202 #define FW_FCOE_ELS_CT_WR_OPCODE_GET(x)         (((x) >> 24) & 0xff)
 203 #define FW_FCOE_ELS_CT_WR_IMMDLEN(x)            ((x) << 0)
 204 #define FW_FCOE_ELS_CT_WR_IMMDLEN_GET(x)        (((x) >> 0) & 0xff)
 205 #define FW_FCOE_ELS_CT_WR_SP(x)                 ((x) << 0)
 206 
 207 struct fw_scsi_write_wr {
 208         __be32 op_immdlen;
 209         __be32 flowid_len16;
 210         u64    cookie;
 211         __be16 iqid;
 212         u8     tmo_val;
 213         u8     use_xfer_cnt;
 214         union fw_scsi_write_priv {
 215                 struct fcoe_write_priv {
 216                         u8   ctl_pri;
 217                         u8   cp_en_class;
 218                         u8   r3_lo[2];
 219                 } fcoe;
 220                 struct iscsi_write_priv {
 221                         u8   r3[4];
 222                 } iscsi;
 223         } u;
 224         __be32 xfer_cnt;
 225         __be32 ini_xfer_cnt;
 226         __be64 rsp_dmaaddr;
 227         __be32 rsp_dmalen;
 228         __be32 r4;
 229 };
 230 
 231 #define FW_SCSI_WRITE_WR_IMMDLEN(x)     ((x) << 0)
 232 
 233 struct fw_scsi_read_wr {
 234         __be32 op_immdlen;
 235         __be32 flowid_len16;
 236         u64    cookie;
 237         __be16 iqid;
 238         u8     tmo_val;
 239         u8     use_xfer_cnt;
 240         union fw_scsi_read_priv {
 241                 struct fcoe_read_priv {
 242                         u8   ctl_pri;
 243                         u8   cp_en_class;
 244                         u8   r3_lo[2];
 245                 } fcoe;
 246                 struct iscsi_read_priv {
 247                         u8   r3[4];
 248                 } iscsi;
 249         } u;
 250         __be32 xfer_cnt;
 251         __be32 ini_xfer_cnt;
 252         __be64 rsp_dmaaddr;
 253         __be32 rsp_dmalen;
 254         __be32 r4;
 255 };
 256 
 257 #define FW_SCSI_READ_WR_IMMDLEN(x)      ((x) << 0)
 258 
 259 struct fw_scsi_cmd_wr {
 260         __be32 op_immdlen;
 261         __be32 flowid_len16;
 262         u64    cookie;
 263         __be16 iqid;
 264         u8     tmo_val;
 265         u8     r3;
 266         union fw_scsi_cmd_priv {
 267                 struct fcoe_cmd_priv {
 268                         u8   ctl_pri;
 269                         u8   cp_en_class;
 270                         u8   r4_lo[2];
 271                 } fcoe;
 272                 struct iscsi_cmd_priv {
 273                         u8   r4[4];
 274                 } iscsi;
 275         } u;
 276         u8     r5[8];
 277         __be64 rsp_dmaaddr;
 278         __be32 rsp_dmalen;
 279         __be32 r6;
 280 };
 281 
 282 #define FW_SCSI_CMD_WR_IMMDLEN(x)       ((x) << 0)
 283 
 284 #define SCSI_ABORT 0
 285 #define SCSI_CLOSE 1
 286 
 287 struct fw_scsi_abrt_cls_wr {
 288         __be32 op_immdlen;
 289         __be32 flowid_len16;
 290         u64    cookie;
 291         __be16 iqid;
 292         u8     tmo_val;
 293         u8     sub_opcode_to_chk_all_io;
 294         u8     r3[4];
 295         u64    t_cookie;
 296 };
 297 
 298 #define FW_SCSI_ABRT_CLS_WR_SUB_OPCODE(x)       ((x) << 2)
 299 #define FW_SCSI_ABRT_CLS_WR_SUB_OPCODE_GET(x)   (((x) >> 2) & 0x3f)
 300 #define FW_SCSI_ABRT_CLS_WR_CHK_ALL_IO(x)       ((x) << 0)
 301 
 302 enum fw_cmd_stor_opcodes {
 303         FW_FCOE_RES_INFO_CMD           = 0x31,
 304         FW_FCOE_LINK_CMD               = 0x32,
 305         FW_FCOE_VNP_CMD                = 0x33,
 306         FW_FCOE_SPARAMS_CMD            = 0x35,
 307         FW_FCOE_STATS_CMD              = 0x37,
 308         FW_FCOE_FCF_CMD                = 0x38,
 309 };
 310 
 311 struct fw_fcoe_res_info_cmd {
 312         __be32 op_to_read;
 313         __be32 retval_len16;
 314         __be16 e_d_tov;
 315         __be16 r_a_tov_seq;
 316         __be16 r_a_tov_els;
 317         __be16 r_r_tov;
 318         __be32 max_xchgs;
 319         __be32 max_ssns;
 320         __be32 used_xchgs;
 321         __be32 used_ssns;
 322         __be32 max_fcfs;
 323         __be32 max_vnps;
 324         __be32 used_fcfs;
 325         __be32 used_vnps;
 326 };
 327 
 328 struct fw_fcoe_link_cmd {
 329         __be32 op_to_portid;
 330         __be32 retval_len16;
 331         __be32 sub_opcode_fcfi;
 332         u8     r3;
 333         u8     lstatus;
 334         __be16 flags;
 335         u8     r4;
 336         u8     set_vlan;
 337         __be16 vlan_id;
 338         __be32 vnpi_pkd;
 339         __be16 r6;
 340         u8     phy_mac[6];
 341         u8     vnport_wwnn[8];
 342         u8     vnport_wwpn[8];
 343 };
 344 
 345 #define FW_FCOE_LINK_CMD_PORTID(x)      ((x) << 0)
 346 #define FW_FCOE_LINK_CMD_PORTID_GET(x)  (((x) >> 0) & 0xf)
 347 #define FW_FCOE_LINK_CMD_SUB_OPCODE(x)  ((x) << 24U)
 348 #define FW_FCOE_LINK_CMD_FCFI(x)        ((x) << 0)
 349 #define FW_FCOE_LINK_CMD_FCFI_GET(x)    (((x) >> 0) & 0xffffff)
 350 #define FW_FCOE_LINK_CMD_VNPI_GET(x)    (((x) >> 0) & 0xfffff)
 351 
 352 struct fw_fcoe_vnp_cmd {
 353         __be32 op_to_fcfi;
 354         __be32 alloc_to_len16;
 355         __be32 gen_wwn_to_vnpi;
 356         __be32 vf_id;
 357         __be16 iqid;
 358         u8   vnport_mac[6];
 359         u8   vnport_wwnn[8];
 360         u8   vnport_wwpn[8];
 361         u8   cmn_srv_parms[16];
 362         u8   clsp_word_0_1[8];
 363 };
 364 
 365 #define FW_FCOE_VNP_CMD_FCFI(x)         ((x) << 0)
 366 #define FW_FCOE_VNP_CMD_ALLOC           (1U << 31)
 367 #define FW_FCOE_VNP_CMD_FREE            (1U << 30)
 368 #define FW_FCOE_VNP_CMD_MODIFY          (1U << 29)
 369 #define FW_FCOE_VNP_CMD_GEN_WWN         (1U << 22)
 370 #define FW_FCOE_VNP_CMD_VFID_EN         (1U << 20)
 371 #define FW_FCOE_VNP_CMD_VNPI(x)         ((x) << 0)
 372 #define FW_FCOE_VNP_CMD_VNPI_GET(x)     (((x) >> 0) & 0xfffff)
 373 
 374 struct fw_fcoe_sparams_cmd {
 375         __be32 op_to_portid;
 376         __be32 retval_len16;
 377         u8     r3[7];
 378         u8     cos;
 379         u8     lport_wwnn[8];
 380         u8     lport_wwpn[8];
 381         u8     cmn_srv_parms[16];
 382         u8     cls_srv_parms[16];
 383 };
 384 
 385 #define FW_FCOE_SPARAMS_CMD_PORTID(x)   ((x) << 0)
 386 
 387 struct fw_fcoe_stats_cmd {
 388         __be32 op_to_flowid;
 389         __be32 free_to_len16;
 390         union fw_fcoe_stats {
 391                 struct fw_fcoe_stats_ctl {
 392                         u8   nstats_port;
 393                         u8   port_valid_ix;
 394                         __be16 r6;
 395                         __be32 r7;
 396                         __be64 stat0;
 397                         __be64 stat1;
 398                         __be64 stat2;
 399                         __be64 stat3;
 400                         __be64 stat4;
 401                         __be64 stat5;
 402                 } ctl;
 403                 struct fw_fcoe_port_stats {
 404                         __be64 tx_bcast_bytes;
 405                         __be64 tx_bcast_frames;
 406                         __be64 tx_mcast_bytes;
 407                         __be64 tx_mcast_frames;
 408                         __be64 tx_ucast_bytes;
 409                         __be64 tx_ucast_frames;
 410                         __be64 tx_drop_frames;
 411                         __be64 tx_offload_bytes;
 412                         __be64 tx_offload_frames;
 413                         __be64 rx_bcast_bytes;
 414                         __be64 rx_bcast_frames;
 415                         __be64 rx_mcast_bytes;
 416                         __be64 rx_mcast_frames;
 417                         __be64 rx_ucast_bytes;
 418                         __be64 rx_ucast_frames;
 419                         __be64 rx_err_frames;
 420                 } port_stats;
 421                 struct fw_fcoe_fcf_stats {
 422                         __be32 fip_tx_bytes;
 423                         __be32 fip_tx_fr;
 424                         __be64 fcf_ka;
 425                         __be64 mcast_adv_rcvd;
 426                         __be16 ucast_adv_rcvd;
 427                         __be16 sol_sent;
 428                         __be16 vlan_req;
 429                         __be16 vlan_rpl;
 430                         __be16 clr_vlink;
 431                         __be16 link_down;
 432                         __be16 link_up;
 433                         __be16 logo;
 434                         __be16 flogi_req;
 435                         __be16 flogi_rpl;
 436                         __be16 fdisc_req;
 437                         __be16 fdisc_rpl;
 438                         __be16 fka_prd_chg;
 439                         __be16 fc_map_chg;
 440                         __be16 vfid_chg;
 441                         u8   no_fka_req;
 442                         u8   no_vnp;
 443                 } fcf_stats;
 444                 struct fw_fcoe_pcb_stats {
 445                         __be64 tx_bytes;
 446                         __be64 tx_frames;
 447                         __be64 rx_bytes;
 448                         __be64 rx_frames;
 449                         __be32 vnp_ka;
 450                         __be32 unsol_els_rcvd;
 451                         __be64 unsol_cmd_rcvd;
 452                         __be16 implicit_logo;
 453                         __be16 flogi_inv_sparm;
 454                         __be16 fdisc_inv_sparm;
 455                         __be16 flogi_rjt;
 456                         __be16 fdisc_rjt;
 457                         __be16 no_ssn;
 458                         __be16 mac_flt_fail;
 459                         __be16 inv_fr_rcvd;
 460                 } pcb_stats;
 461                 struct fw_fcoe_scb_stats {
 462                         __be64 tx_bytes;
 463                         __be64 tx_frames;
 464                         __be64 rx_bytes;
 465                         __be64 rx_frames;
 466                         __be32 host_abrt_req;
 467                         __be32 adap_auto_abrt;
 468                         __be32 adap_abrt_rsp;
 469                         __be32 host_ios_req;
 470                         __be16 ssn_offl_ios;
 471                         __be16 ssn_not_rdy_ios;
 472                         u8   rx_data_ddp_err;
 473                         u8   ddp_flt_set_err;
 474                         __be16 rx_data_fr_err;
 475                         u8   bad_st_abrt_req;
 476                         u8   no_io_abrt_req;
 477                         u8   abort_tmo;
 478                         u8   abort_tmo_2;
 479                         __be32 abort_req;
 480                         u8   no_ppod_res_tmo;
 481                         u8   bp_tmo;
 482                         u8   adap_auto_cls;
 483                         u8   no_io_cls_req;
 484                         __be32 host_cls_req;
 485                         __be64 unsol_cmd_rcvd;
 486                         __be32 plogi_req_rcvd;
 487                         __be32 prli_req_rcvd;
 488                         __be16 logo_req_rcvd;
 489                         __be16 prlo_req_rcvd;
 490                         __be16 plogi_rjt_rcvd;
 491                         __be16 prli_rjt_rcvd;
 492                         __be32 adisc_req_rcvd;
 493                         __be32 rscn_rcvd;
 494                         __be32 rrq_req_rcvd;
 495                         __be32 unsol_els_rcvd;
 496                         u8   adisc_rjt_rcvd;
 497                         u8   scr_rjt;
 498                         u8   ct_rjt;
 499                         u8   inval_bls_rcvd;
 500                         __be32 ba_rjt_rcvd;
 501                 } scb_stats;
 502         } u;
 503 };
 504 
 505 #define FW_FCOE_STATS_CMD_FLOWID(x)     ((x) << 0)
 506 #define FW_FCOE_STATS_CMD_FREE          (1U << 30)
 507 #define FW_FCOE_STATS_CMD_NSTATS(x)     ((x) << 4)
 508 #define FW_FCOE_STATS_CMD_PORT(x)       ((x) << 0)
 509 #define FW_FCOE_STATS_CMD_PORT_VALID    (1U << 7)
 510 #define FW_FCOE_STATS_CMD_IX(x)         ((x) << 0)
 511 
 512 struct fw_fcoe_fcf_cmd {
 513         __be32 op_to_fcfi;
 514         __be32 retval_len16;
 515         __be16 priority_pkd;
 516         u8     mac[6];
 517         u8     name_id[8];
 518         u8     fabric[8];
 519         __be16 vf_id;
 520         __be16 max_fcoe_size;
 521         u8     vlan_id;
 522         u8     fc_map[3];
 523         __be32 fka_adv;
 524         __be32 r6;
 525         u8     r7_hi;
 526         u8     fpma_to_portid;
 527         u8     spma_mac[6];
 528         __be64 r8;
 529 };
 530 
 531 #define FW_FCOE_FCF_CMD_FCFI(x)         ((x) << 0)
 532 #define FW_FCOE_FCF_CMD_FCFI_GET(x)     (((x) >> 0) & 0xfffff)
 533 #define FW_FCOE_FCF_CMD_PRIORITY_GET(x) (((x) >> 0) & 0xff)
 534 #define FW_FCOE_FCF_CMD_FPMA_GET(x)     (((x) >> 6) & 0x1)
 535 #define FW_FCOE_FCF_CMD_SPMA_GET(x)     (((x) >> 5) & 0x1)
 536 #define FW_FCOE_FCF_CMD_LOGIN_GET(x)    (((x) >> 4) & 0x1)
 537 #define FW_FCOE_FCF_CMD_PORTID_GET(x)   (((x) >> 0) & 0xf)
 538 
 539 #endif /* _T4FW_API_STOR_H_ */

/* [<][>][^][v][top][bottom][index][help] */