1 /* 2 * Linux network driver for Brocade Converged Network Adapter. 3 * 4 * This program is free software; you can redistribute it and/or modify it 5 * under the terms of the GNU General Public License (GPL) Version 2 as 6 * published by the Free Software Foundation 7 * 8 * This program is distributed in the hope that it will be useful, but 9 * WITHOUT ANY WARRANTY; without even the implied warranty of 10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 11 * General Public License for more details. 12 */ 13 /* 14 * Copyright (c) 2005-2010 Brocade Communications Systems, Inc. 15 * All rights reserved 16 * www.brocade.com 17 */ 18 #ifndef __BFA_DEFS_CNA_H__ 19 #define __BFA_DEFS_CNA_H__ 20 21 #include "bfa_defs.h" 22 23 /** 24 * @brief 25 * FC physical port statistics. 26 */ 27 struct bfa_port_fc_stats { 28 u64 secs_reset; /*!< Seconds since stats is reset */ 29 u64 tx_frames; /*!< Tx frames */ 30 u64 tx_words; /*!< Tx words */ 31 u64 tx_lip; /*!< Tx LIP */ 32 u64 tx_nos; /*!< Tx NOS */ 33 u64 tx_ols; /*!< Tx OLS */ 34 u64 tx_lr; /*!< Tx LR */ 35 u64 tx_lrr; /*!< Tx LRR */ 36 u64 rx_frames; /*!< Rx frames */ 37 u64 rx_words; /*!< Rx words */ 38 u64 lip_count; /*!< Rx LIP */ 39 u64 nos_count; /*!< Rx NOS */ 40 u64 ols_count; /*!< Rx OLS */ 41 u64 lr_count; /*!< Rx LR */ 42 u64 lrr_count; /*!< Rx LRR */ 43 u64 invalid_crcs; /*!< Rx CRC err frames */ 44 u64 invalid_crc_gd_eof; /*!< Rx CRC err good EOF frames */ 45 u64 undersized_frm; /*!< Rx undersized frames */ 46 u64 oversized_frm; /*!< Rx oversized frames */ 47 u64 bad_eof_frm; /*!< Rx frames with bad EOF */ 48 u64 error_frames; /*!< Errored frames */ 49 u64 dropped_frames; /*!< Dropped frames */ 50 u64 link_failures; /*!< Link Failure (LF) count */ 51 u64 loss_of_syncs; /*!< Loss of sync count */ 52 u64 loss_of_signals; /*!< Loss of signal count */ 53 u64 primseq_errs; /*!< Primitive sequence protocol err. */ 54 u64 bad_os_count; /*!< Invalid ordered sets */ 55 u64 err_enc_out; /*!< Encoding err nonframe_8b10b */ 56 u64 err_enc; /*!< Encoding err frame_8b10b */ 57 u64 bbsc_frames_lost; /*!< Credit Recovery-Frames Lost */ 58 u64 bbsc_credits_lost; /*!< Credit Recovery-Credits Lost */ 59 u64 bbsc_link_resets; /*!< Credit Recovery-Link Resets */ 60 }; 61 62 /** 63 * @brief 64 * Eth Physical Port statistics. 65 */ 66 struct bfa_port_eth_stats { 67 u64 secs_reset; /*!< Seconds since stats is reset */ 68 u64 frame_64; /*!< Frames 64 bytes */ 69 u64 frame_65_127; /*!< Frames 65-127 bytes */ 70 u64 frame_128_255; /*!< Frames 128-255 bytes */ 71 u64 frame_256_511; /*!< Frames 256-511 bytes */ 72 u64 frame_512_1023; /*!< Frames 512-1023 bytes */ 73 u64 frame_1024_1518; /*!< Frames 1024-1518 bytes */ 74 u64 frame_1519_1522; /*!< Frames 1519-1522 bytes */ 75 u64 tx_bytes; /*!< Tx bytes */ 76 u64 tx_packets; /*!< Tx packets */ 77 u64 tx_mcast_packets; /*!< Tx multicast packets */ 78 u64 tx_bcast_packets; /*!< Tx broadcast packets */ 79 u64 tx_control_frame; /*!< Tx control frame */ 80 u64 tx_drop; /*!< Tx drops */ 81 u64 tx_jabber; /*!< Tx jabber */ 82 u64 tx_fcs_error; /*!< Tx FCS errors */ 83 u64 tx_fragments; /*!< Tx fragments */ 84 u64 rx_bytes; /*!< Rx bytes */ 85 u64 rx_packets; /*!< Rx packets */ 86 u64 rx_mcast_packets; /*!< Rx multicast packets */ 87 u64 rx_bcast_packets; /*!< Rx broadcast packets */ 88 u64 rx_control_frames; /*!< Rx control frames */ 89 u64 rx_unknown_opcode; /*!< Rx unknown opcode */ 90 u64 rx_drop; /*!< Rx drops */ 91 u64 rx_jabber; /*!< Rx jabber */ 92 u64 rx_fcs_error; /*!< Rx FCS errors */ 93 u64 rx_alignment_error; /*!< Rx alignment errors */ 94 u64 rx_frame_length_error; /*!< Rx frame len errors */ 95 u64 rx_code_error; /*!< Rx code errors */ 96 u64 rx_fragments; /*!< Rx fragments */ 97 u64 rx_pause; /*!< Rx pause */ 98 u64 rx_zero_pause; /*!< Rx zero pause */ 99 u64 tx_pause; /*!< Tx pause */ 100 u64 tx_zero_pause; /*!< Tx zero pause */ 101 u64 rx_fcoe_pause; /*!< Rx FCoE pause */ 102 u64 rx_fcoe_zero_pause; /*!< Rx FCoE zero pause */ 103 u64 tx_fcoe_pause; /*!< Tx FCoE pause */ 104 u64 tx_fcoe_zero_pause; /*!< Tx FCoE zero pause */ 105 u64 rx_iscsi_pause; /*!< Rx iSCSI pause */ 106 u64 rx_iscsi_zero_pause; /*!< Rx iSCSI zero pause */ 107 u64 tx_iscsi_pause; /*!< Tx iSCSI pause */ 108 u64 tx_iscsi_zero_pause; /*!< Tx iSCSI zero pause */ 109 }; 110 111 /** 112 * @brief 113 * Port statistics. 114 */ 115 union bfa_port_stats_u { 116 struct bfa_port_fc_stats fc; 117 struct bfa_port_eth_stats eth; 118 }; 119 120 #pragma pack(1) 121 122 #define BFA_CEE_LLDP_MAX_STRING_LEN (128) 123 #define BFA_CEE_DCBX_MAX_PRIORITY (8) 124 #define BFA_CEE_DCBX_MAX_PGID (8) 125 126 #define BFA_CEE_LLDP_SYS_CAP_OTHER 0x0001 127 #define BFA_CEE_LLDP_SYS_CAP_REPEATER 0x0002 128 #define BFA_CEE_LLDP_SYS_CAP_MAC_BRIDGE 0x0004 129 #define BFA_CEE_LLDP_SYS_CAP_WLAN_AP 0x0008 130 #define BFA_CEE_LLDP_SYS_CAP_ROUTER 0x0010 131 #define BFA_CEE_LLDP_SYS_CAP_TELEPHONE 0x0020 132 #define BFA_CEE_LLDP_SYS_CAP_DOCSIS_CD 0x0040 133 #define BFA_CEE_LLDP_SYS_CAP_STATION 0x0080 134 #define BFA_CEE_LLDP_SYS_CAP_CVLAN 0x0100 135 #define BFA_CEE_LLDP_SYS_CAP_SVLAN 0x0200 136 #define BFA_CEE_LLDP_SYS_CAP_TPMR 0x0400 137 138 /* LLDP string type */ 139 struct bfa_cee_lldp_str { 140 u8 sub_type; 141 u8 len; 142 u8 rsvd[2]; 143 u8 value[BFA_CEE_LLDP_MAX_STRING_LEN]; 144 }; 145 146 /* LLDP paramters */ 147 struct bfa_cee_lldp_cfg { 148 struct bfa_cee_lldp_str chassis_id; 149 struct bfa_cee_lldp_str port_id; 150 struct bfa_cee_lldp_str port_desc; 151 struct bfa_cee_lldp_str sys_name; 152 struct bfa_cee_lldp_str sys_desc; 153 struct bfa_cee_lldp_str mgmt_addr; 154 u16 time_to_live; 155 u16 enabled_system_cap; 156 }; 157 158 enum bfa_cee_dcbx_version { 159 DCBX_PROTOCOL_PRECEE = 1, 160 DCBX_PROTOCOL_CEE = 2, 161 }; 162 163 enum bfa_cee_lls { 164 /* LLS is down because the TLV not sent by the peer */ 165 CEE_LLS_DOWN_NO_TLV = 0, 166 /* LLS is down as advertised by the peer */ 167 CEE_LLS_DOWN = 1, 168 CEE_LLS_UP = 2, 169 }; 170 171 /* CEE/DCBX parameters */ 172 struct bfa_cee_dcbx_cfg { 173 u8 pgid[BFA_CEE_DCBX_MAX_PRIORITY]; 174 u8 pg_percentage[BFA_CEE_DCBX_MAX_PGID]; 175 u8 pfc_primap; /* bitmap of priorties with PFC enabled */ 176 u8 fcoe_primap; /* bitmap of priorities used for FcoE traffic */ 177 u8 iscsi_primap; /* bitmap of priorities used for iSCSI traffic */ 178 u8 dcbx_version; /* operating version:CEE or preCEE */ 179 u8 lls_fcoe; /* FCoE Logical Link Status */ 180 u8 lls_lan; /* LAN Logical Link Status */ 181 u8 rsvd[2]; 182 }; 183 184 /* CEE status */ 185 /* Making this to tri-state for the benefit of port list command */ 186 enum bfa_cee_status { 187 CEE_UP = 0, 188 CEE_PHY_UP = 1, 189 CEE_LOOPBACK = 2, 190 CEE_PHY_DOWN = 3, 191 }; 192 193 /* CEE Query */ 194 struct bfa_cee_attr { 195 u8 cee_status; 196 u8 error_reason; 197 struct bfa_cee_lldp_cfg lldp_remote; 198 struct bfa_cee_dcbx_cfg dcbx_remote; 199 mac_t src_mac; 200 u8 link_speed; 201 u8 nw_priority; 202 u8 filler[2]; 203 }; 204 205 /* LLDP/DCBX/CEE Statistics */ 206 struct bfa_cee_stats { 207 u32 lldp_tx_frames; /*!< LLDP Tx Frames */ 208 u32 lldp_rx_frames; /*!< LLDP Rx Frames */ 209 u32 lldp_rx_frames_invalid; /*!< LLDP Rx Frames invalid */ 210 u32 lldp_rx_frames_new; /*!< LLDP Rx Frames new */ 211 u32 lldp_tlvs_unrecognized; /*!< LLDP Rx unrecognized TLVs */ 212 u32 lldp_rx_shutdown_tlvs; /*!< LLDP Rx shutdown TLVs */ 213 u32 lldp_info_aged_out; /*!< LLDP remote info aged out */ 214 u32 dcbx_phylink_ups; /*!< DCBX phy link ups */ 215 u32 dcbx_phylink_downs; /*!< DCBX phy link downs */ 216 u32 dcbx_rx_tlvs; /*!< DCBX Rx TLVs */ 217 u32 dcbx_rx_tlvs_invalid; /*!< DCBX Rx TLVs invalid */ 218 u32 dcbx_control_tlv_error; /*!< DCBX control TLV errors */ 219 u32 dcbx_feature_tlv_error; /*!< DCBX feature TLV errors */ 220 u32 dcbx_cee_cfg_new; /*!< DCBX new CEE cfg rcvd */ 221 u32 cee_status_down; /*!< CEE status down */ 222 u32 cee_status_up; /*!< CEE status up */ 223 u32 cee_hw_cfg_changed; /*!< CEE hw cfg changed */ 224 u32 cee_rx_invalid_cfg; /*!< CEE invalid cfg */ 225 }; 226 227 #pragma pack() 228 229 #endif /* __BFA_DEFS_CNA_H__ */ 230