Merge branch 'irq-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git...
[pandora-kernel.git] / drivers / net / ethernet / brocade / bna / bfa_defs_cna.h
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__ */