]> pilppa.org Git - linux-2.6-omap-h63xx.git/blob - drivers/net/bnx2x_hsi.h
bnx2x: Removing the board type
[linux-2.6-omap-h63xx.git] / drivers / net / bnx2x_hsi.h
1 /* bnx2x_hsi.h: Broadcom Everest network driver.
2  *
3  * Copyright (c) 2007-2008 Broadcom Corporation
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation.
8  */
9
10
11 #define PORT_0                          0
12 #define PORT_1                          1
13 #define PORT_MAX                        2
14
15 /****************************************************************************
16  * Shared HW configuration                                                  *
17  ****************************************************************************/
18 struct shared_hw_cfg {                                   /* NVRAM Offset */
19         /* Up to 16 bytes of NULL-terminated string */
20         u8  part_num[16];                                       /* 0x104 */
21
22         u32 config;                                             /* 0x114 */
23 #define SHARED_HW_CFG_MDIO_VOLTAGE_MASK             0x00000001
24 #define SHARED_HW_CFG_MDIO_VOLTAGE_SHIFT            0
25 #define SHARED_HW_CFG_MDIO_VOLTAGE_1_2V             0x00000000
26 #define SHARED_HW_CFG_MDIO_VOLTAGE_2_5V             0x00000001
27 #define SHARED_HW_CFG_MCP_RST_ON_CORE_RST_EN        0x00000002
28
29 #define SHARED_HW_CFG_PORT_SWAP                     0x00000004
30
31 #define SHARED_HW_CFG_BEACON_WOL_EN                 0x00000008
32
33 #define SHARED_HW_CFG_MFW_SELECT_MASK               0x00000700
34 #define SHARED_HW_CFG_MFW_SELECT_SHIFT              8
35         /* Whatever MFW found in NVM
36            (if multiple found, priority order is: NC-SI, UMP, IPMI) */
37 #define SHARED_HW_CFG_MFW_SELECT_DEFAULT            0x00000000
38 #define SHARED_HW_CFG_MFW_SELECT_NC_SI              0x00000100
39 #define SHARED_HW_CFG_MFW_SELECT_UMP                0x00000200
40 #define SHARED_HW_CFG_MFW_SELECT_IPMI               0x00000300
41         /* Use SPIO4 as an arbiter between: 0-NC_SI, 1-IPMI
42           (can only be used when an add-in board, not BMC, pulls-down SPIO4) */
43 #define SHARED_HW_CFG_MFW_SELECT_SPIO4_NC_SI_IPMI   0x00000400
44         /* Use SPIO4 as an arbiter between: 0-UMP, 1-IPMI
45           (can only be used when an add-in board, not BMC, pulls-down SPIO4) */
46 #define SHARED_HW_CFG_MFW_SELECT_SPIO4_UMP_IPMI     0x00000500
47         /* Use SPIO4 as an arbiter between: 0-NC-SI, 1-UMP
48           (can only be used when an add-in board, not BMC, pulls-down SPIO4) */
49 #define SHARED_HW_CFG_MFW_SELECT_SPIO4_NC_SI_UMP    0x00000600
50
51 #define SHARED_HW_CFG_LED_MODE_MASK                 0x000f0000
52 #define SHARED_HW_CFG_LED_MODE_SHIFT                16
53 #define SHARED_HW_CFG_LED_MAC1                      0x00000000
54 #define SHARED_HW_CFG_LED_PHY1                      0x00010000
55 #define SHARED_HW_CFG_LED_PHY2                      0x00020000
56 #define SHARED_HW_CFG_LED_PHY3                      0x00030000
57 #define SHARED_HW_CFG_LED_MAC2                      0x00040000
58 #define SHARED_HW_CFG_LED_PHY4                      0x00050000
59 #define SHARED_HW_CFG_LED_PHY5                      0x00060000
60 #define SHARED_HW_CFG_LED_PHY6                      0x00070000
61 #define SHARED_HW_CFG_LED_MAC3                      0x00080000
62 #define SHARED_HW_CFG_LED_PHY7                      0x00090000
63 #define SHARED_HW_CFG_LED_PHY9                      0x000a0000
64 #define SHARED_HW_CFG_LED_PHY11                     0x000b0000
65 #define SHARED_HW_CFG_LED_MAC4                      0x000c0000
66 #define SHARED_HW_CFG_LED_PHY8                      0x000d0000
67
68 #define SHARED_HW_CFG_AN_ENABLE_MASK                0x3f000000
69 #define SHARED_HW_CFG_AN_ENABLE_SHIFT               24
70 #define SHARED_HW_CFG_AN_ENABLE_CL37                0x01000000
71 #define SHARED_HW_CFG_AN_ENABLE_CL73                0x02000000
72 #define SHARED_HW_CFG_AN_ENABLE_BAM                 0x04000000
73 #define SHARED_HW_CFG_AN_ENABLE_PARALLEL_DETECTION  0x08000000
74 #define SHARED_HW_CFG_AN_EN_SGMII_FIBER_AUTO_DETECT 0x10000000
75 #define SHARED_HW_CFG_AN_ENABLE_REMOTE_PHY          0x20000000
76
77         u32 config2;                                            /* 0x118 */
78         /* one time auto detect grace period (in sec) */
79 #define SHARED_HW_CFG_GRACE_PERIOD_MASK             0x000000ff
80 #define SHARED_HW_CFG_GRACE_PERIOD_SHIFT            0
81
82 #define SHARED_HW_CFG_PCIE_GEN2_ENABLED             0x00000100
83
84         /* The default value for the core clock is 250MHz and it is
85            achieved by setting the clock change to 4 */
86 #define SHARED_HW_CFG_CLOCK_CHANGE_MASK             0x00000e00
87 #define SHARED_HW_CFG_CLOCK_CHANGE_SHIFT            9
88
89 #define SHARED_HW_CFG_SMBUS_TIMING_100KHZ           0x00000000
90 #define SHARED_HW_CFG_SMBUS_TIMING_400KHZ           0x00001000
91
92 #define SHARED_HW_CFG_HIDE_PORT1                    0x00002000
93
94         u32 power_dissipated;                                   /* 0x11c */
95 #define SHARED_HW_CFG_POWER_DIS_CMN_MASK            0xff000000
96 #define SHARED_HW_CFG_POWER_DIS_CMN_SHIFT           24
97
98 #define SHARED_HW_CFG_POWER_MGNT_SCALE_MASK         0x00ff0000
99 #define SHARED_HW_CFG_POWER_MGNT_SCALE_SHIFT        16
100 #define SHARED_HW_CFG_POWER_MGNT_UNKNOWN_SCALE      0x00000000
101 #define SHARED_HW_CFG_POWER_MGNT_DOT_1_WATT         0x00010000
102 #define SHARED_HW_CFG_POWER_MGNT_DOT_01_WATT        0x00020000
103 #define SHARED_HW_CFG_POWER_MGNT_DOT_001_WATT       0x00030000
104
105         u32 ump_nc_si_config;                                   /* 0x120 */
106 #define SHARED_HW_CFG_UMP_NC_SI_MII_MODE_MASK       0x00000003
107 #define SHARED_HW_CFG_UMP_NC_SI_MII_MODE_SHIFT      0
108 #define SHARED_HW_CFG_UMP_NC_SI_MII_MODE_MAC        0x00000000
109 #define SHARED_HW_CFG_UMP_NC_SI_MII_MODE_PHY        0x00000001
110 #define SHARED_HW_CFG_UMP_NC_SI_MII_MODE_MII        0x00000000
111 #define SHARED_HW_CFG_UMP_NC_SI_MII_MODE_RMII       0x00000002
112
113 #define SHARED_HW_CFG_UMP_NC_SI_NUM_DEVS_MASK       0x00000f00
114 #define SHARED_HW_CFG_UMP_NC_SI_NUM_DEVS_SHIFT      8
115
116 #define SHARED_HW_CFG_UMP_NC_SI_EXT_PHY_TYPE_MASK   0x00ff0000
117 #define SHARED_HW_CFG_UMP_NC_SI_EXT_PHY_TYPE_SHIFT  16
118 #define SHARED_HW_CFG_UMP_NC_SI_EXT_PHY_TYPE_NONE   0x00000000
119 #define SHARED_HW_CFG_UMP_NC_SI_EXT_PHY_TYPE_BCM5221 0x00010000
120
121         u32 board;                                              /* 0x124 */
122 #define SHARED_HW_CFG_BOARD_REV_MASK                0x00FF0000
123 #define SHARED_HW_CFG_BOARD_REV_SHIFT               16
124
125 #define SHARED_HW_CFG_BOARD_MAJOR_VER_MASK          0x0F000000
126 #define SHARED_HW_CFG_BOARD_MAJOR_VER_SHIFT         24
127
128 #define SHARED_HW_CFG_BOARD_MINOR_VER_MASK          0xF0000000
129 #define SHARED_HW_CFG_BOARD_MINOR_VER_SHIFT         28
130
131         u32 reserved;                                           /* 0x128 */
132
133 };
134
135
136 /****************************************************************************
137  * Port HW configuration                                                    *
138  ****************************************************************************/
139 struct port_hw_cfg {                        /* port 0: 0x12c  port 1: 0x2bc */
140
141         u32 pci_id;
142 #define PORT_HW_CFG_PCI_VENDOR_ID_MASK              0xffff0000
143 #define PORT_HW_CFG_PCI_DEVICE_ID_MASK              0x0000ffff
144
145         u32 pci_sub_id;
146 #define PORT_HW_CFG_PCI_SUBSYS_DEVICE_ID_MASK       0xffff0000
147 #define PORT_HW_CFG_PCI_SUBSYS_VENDOR_ID_MASK       0x0000ffff
148
149         u32 power_dissipated;
150 #define PORT_HW_CFG_POWER_DIS_D3_MASK               0xff000000
151 #define PORT_HW_CFG_POWER_DIS_D3_SHIFT              24
152 #define PORT_HW_CFG_POWER_DIS_D2_MASK               0x00ff0000
153 #define PORT_HW_CFG_POWER_DIS_D2_SHIFT              16
154 #define PORT_HW_CFG_POWER_DIS_D1_MASK               0x0000ff00
155 #define PORT_HW_CFG_POWER_DIS_D1_SHIFT              8
156 #define PORT_HW_CFG_POWER_DIS_D0_MASK               0x000000ff
157 #define PORT_HW_CFG_POWER_DIS_D0_SHIFT              0
158
159         u32 power_consumed;
160 #define PORT_HW_CFG_POWER_CONS_D3_MASK              0xff000000
161 #define PORT_HW_CFG_POWER_CONS_D3_SHIFT             24
162 #define PORT_HW_CFG_POWER_CONS_D2_MASK              0x00ff0000
163 #define PORT_HW_CFG_POWER_CONS_D2_SHIFT             16
164 #define PORT_HW_CFG_POWER_CONS_D1_MASK              0x0000ff00
165 #define PORT_HW_CFG_POWER_CONS_D1_SHIFT             8
166 #define PORT_HW_CFG_POWER_CONS_D0_MASK              0x000000ff
167 #define PORT_HW_CFG_POWER_CONS_D0_SHIFT             0
168
169         u32 mac_upper;
170 #define PORT_HW_CFG_UPPERMAC_MASK                   0x0000ffff
171 #define PORT_HW_CFG_UPPERMAC_SHIFT                  0
172         u32 mac_lower;
173
174         u32 iscsi_mac_upper;  /* Upper 16 bits are always zeroes */
175         u32 iscsi_mac_lower;
176
177         u32 rdma_mac_upper;   /* Upper 16 bits are always zeroes */
178         u32 rdma_mac_lower;
179
180         u32 serdes_config;
181         /* for external PHY, or forced mode or during AN */
182 #define PORT_HW_CFG_SERDES_TX_DRV_PRE_EMPHASIS_MASK 0xffff0000
183 #define PORT_HW_CFG_SERDES_TX_DRV_PRE_EMPHASIS_SHIFT  16
184
185 #define PORT_HW_CFG_SERDES_RX_DRV_EQUALIZER_MASK    0x0000ffff
186 #define PORT_HW_CFG_SERDES_RX_DRV_EQUALIZER_SHIFT   0
187
188         u16 serdes_tx_driver_pre_emphasis[16];
189         u16 serdes_rx_driver_equalizer[16];
190
191         u32 xgxs_config_lane0;
192         u32 xgxs_config_lane1;
193         u32 xgxs_config_lane2;
194         u32 xgxs_config_lane3;
195         /* for external PHY, or forced mode or during AN */
196 #define PORT_HW_CFG_XGXS_TX_DRV_PRE_EMPHASIS_MASK   0xffff0000
197 #define PORT_HW_CFG_XGXS_TX_DRV_PRE_EMPHASIS_SHIFT  16
198
199 #define PORT_HW_CFG_XGXS_RX_DRV_EQUALIZER_MASK      0x0000ffff
200 #define PORT_HW_CFG_XGXS_RX_DRV_EQUALIZER_SHIFT     0
201
202         u16 xgxs_tx_driver_pre_emphasis_lane0[16];
203         u16 xgxs_tx_driver_pre_emphasis_lane1[16];
204         u16 xgxs_tx_driver_pre_emphasis_lane2[16];
205         u16 xgxs_tx_driver_pre_emphasis_lane3[16];
206
207         u16 xgxs_rx_driver_equalizer_lane0[16];
208         u16 xgxs_rx_driver_equalizer_lane1[16];
209         u16 xgxs_rx_driver_equalizer_lane2[16];
210         u16 xgxs_rx_driver_equalizer_lane3[16];
211
212         u32 lane_config;
213 #define PORT_HW_CFG_LANE_SWAP_CFG_MASK              0x0000ffff
214 #define PORT_HW_CFG_LANE_SWAP_CFG_SHIFT             0
215 #define PORT_HW_CFG_LANE_SWAP_CFG_TX_MASK           0x000000ff
216 #define PORT_HW_CFG_LANE_SWAP_CFG_TX_SHIFT          0
217 #define PORT_HW_CFG_LANE_SWAP_CFG_RX_MASK           0x0000ff00
218 #define PORT_HW_CFG_LANE_SWAP_CFG_RX_SHIFT          8
219 #define PORT_HW_CFG_LANE_SWAP_CFG_MASTER_MASK       0x0000c000
220 #define PORT_HW_CFG_LANE_SWAP_CFG_MASTER_SHIFT      14
221         /* AN and forced */
222 #define PORT_HW_CFG_LANE_SWAP_CFG_01230123          0x00001b1b
223         /* forced only */
224 #define PORT_HW_CFG_LANE_SWAP_CFG_01233210          0x00001be4
225         /* forced only */
226 #define PORT_HW_CFG_LANE_SWAP_CFG_31203120          0x0000d8d8
227         /* forced only */
228 #define PORT_HW_CFG_LANE_SWAP_CFG_32103210          0x0000e4e4
229
230         u32 external_phy_config;
231 #define PORT_HW_CFG_SERDES_EXT_PHY_TYPE_MASK        0xff000000
232 #define PORT_HW_CFG_SERDES_EXT_PHY_TYPE_SHIFT       24
233 #define PORT_HW_CFG_SERDES_EXT_PHY_TYPE_DIRECT      0x00000000
234 #define PORT_HW_CFG_SERDES_EXT_PHY_TYPE_BCM5482     0x01000000
235 #define PORT_HW_CFG_SERDES_EXT_PHY_TYPE_NOT_CONN    0xff000000
236
237 #define PORT_HW_CFG_SERDES_EXT_PHY_ADDR_MASK        0x00ff0000
238 #define PORT_HW_CFG_SERDES_EXT_PHY_ADDR_SHIFT       16
239
240 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_MASK          0x0000ff00
241 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_SHIFT         8
242 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_DIRECT        0x00000000
243 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_BCM8071       0x00000100
244 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_BCM8072       0x00000200
245 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_BCM8073       0x00000300
246 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_BCM8705       0x00000400
247 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_BCM8706       0x00000500
248 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_BCM8276       0x00000600
249 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_BCM8481       0x00000700
250 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_SFX7101       0x00000800
251 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_FAILURE       0x0000fd00
252 #define PORT_HW_CFG_XGXS_EXT_PHY_TYPE_NOT_CONN      0x0000ff00
253
254 #define PORT_HW_CFG_XGXS_EXT_PHY_ADDR_MASK          0x000000ff
255 #define PORT_HW_CFG_XGXS_EXT_PHY_ADDR_SHIFT         0
256
257         u32 speed_capability_mask;
258 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_MASK        0xffff0000
259 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_SHIFT       16
260 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_10M_FULL    0x00010000
261 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_10M_HALF    0x00020000
262 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_100M_HALF   0x00040000
263 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_100M_FULL   0x00080000
264 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_1G          0x00100000
265 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_2_5G        0x00200000
266 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_10G         0x00400000
267 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_12G         0x00800000
268 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_12_5G       0x01000000
269 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_13G         0x02000000
270 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_15G         0x04000000
271 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_16G         0x08000000
272 #define PORT_HW_CFG_SPEED_CAPABILITY_D0_RESERVED    0xf0000000
273
274 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_MASK        0x0000ffff
275 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_SHIFT       0
276 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_10M_FULL    0x00000001
277 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_10M_HALF    0x00000002
278 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_100M_HALF   0x00000004
279 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_100M_FULL   0x00000008
280 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_1G          0x00000010
281 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_2_5G        0x00000020
282 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_10G         0x00000040
283 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_12G         0x00000080
284 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_12_5G       0x00000100
285 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_13G         0x00000200
286 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_15G         0x00000400
287 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_16G         0x00000800
288 #define PORT_HW_CFG_SPEED_CAPABILITY_D3_RESERVED    0x0000f000
289
290         u32 reserved[2];
291
292 };
293
294
295 /****************************************************************************
296  * Shared Feature configuration                                             *
297  ****************************************************************************/
298 struct shared_feat_cfg {                                 /* NVRAM Offset */
299
300         u32 config;                                             /* 0x450 */
301 #define SHARED_FEATURE_BMC_ECHO_MODE_EN             0x00000001
302 #define SHARED_FEATURE_MF_MODE_DISABLED             0x00000100
303
304 };
305
306
307 /****************************************************************************
308  * Port Feature configuration                                               *
309  ****************************************************************************/
310 struct port_feat_cfg {                      /* port 0: 0x454  port 1: 0x4c8 */
311
312         u32 config;
313 #define PORT_FEATURE_BAR1_SIZE_MASK                 0x0000000f
314 #define PORT_FEATURE_BAR1_SIZE_SHIFT                0
315 #define PORT_FEATURE_BAR1_SIZE_DISABLED             0x00000000
316 #define PORT_FEATURE_BAR1_SIZE_64K                  0x00000001
317 #define PORT_FEATURE_BAR1_SIZE_128K                 0x00000002
318 #define PORT_FEATURE_BAR1_SIZE_256K                 0x00000003
319 #define PORT_FEATURE_BAR1_SIZE_512K                 0x00000004
320 #define PORT_FEATURE_BAR1_SIZE_1M                   0x00000005
321 #define PORT_FEATURE_BAR1_SIZE_2M                   0x00000006
322 #define PORT_FEATURE_BAR1_SIZE_4M                   0x00000007
323 #define PORT_FEATURE_BAR1_SIZE_8M                   0x00000008
324 #define PORT_FEATURE_BAR1_SIZE_16M                  0x00000009
325 #define PORT_FEATURE_BAR1_SIZE_32M                  0x0000000a
326 #define PORT_FEATURE_BAR1_SIZE_64M                  0x0000000b
327 #define PORT_FEATURE_BAR1_SIZE_128M                 0x0000000c
328 #define PORT_FEATURE_BAR1_SIZE_256M                 0x0000000d
329 #define PORT_FEATURE_BAR1_SIZE_512M                 0x0000000e
330 #define PORT_FEATURE_BAR1_SIZE_1G                   0x0000000f
331 #define PORT_FEATURE_BAR2_SIZE_MASK                 0x000000f0
332 #define PORT_FEATURE_BAR2_SIZE_SHIFT                4
333 #define PORT_FEATURE_BAR2_SIZE_DISABLED             0x00000000
334 #define PORT_FEATURE_BAR2_SIZE_64K                  0x00000010
335 #define PORT_FEATURE_BAR2_SIZE_128K                 0x00000020
336 #define PORT_FEATURE_BAR2_SIZE_256K                 0x00000030
337 #define PORT_FEATURE_BAR2_SIZE_512K                 0x00000040
338 #define PORT_FEATURE_BAR2_SIZE_1M                   0x00000050
339 #define PORT_FEATURE_BAR2_SIZE_2M                   0x00000060
340 #define PORT_FEATURE_BAR2_SIZE_4M                   0x00000070
341 #define PORT_FEATURE_BAR2_SIZE_8M                   0x00000080
342 #define PORT_FEATURE_BAR2_SIZE_16M                  0x00000090
343 #define PORT_FEATURE_BAR2_SIZE_32M                  0x000000a0
344 #define PORT_FEATURE_BAR2_SIZE_64M                  0x000000b0
345 #define PORT_FEATURE_BAR2_SIZE_128M                 0x000000c0
346 #define PORT_FEATURE_BAR2_SIZE_256M                 0x000000d0
347 #define PORT_FEATURE_BAR2_SIZE_512M                 0x000000e0
348 #define PORT_FEATURE_BAR2_SIZE_1G                   0x000000f0
349 #define PORT_FEATURE_EN_SIZE_MASK                   0x07000000
350 #define PORT_FEATURE_EN_SIZE_SHIFT                  24
351 #define PORT_FEATURE_WOL_ENABLED                    0x01000000
352 #define PORT_FEATURE_MBA_ENABLED                    0x02000000
353 #define PORT_FEATURE_MFW_ENABLED                    0x04000000
354
355         u32 wol_config;
356         /* Default is used when driver sets to "auto" mode */
357 #define PORT_FEATURE_WOL_DEFAULT_MASK               0x00000003
358 #define PORT_FEATURE_WOL_DEFAULT_SHIFT              0
359 #define PORT_FEATURE_WOL_DEFAULT_DISABLE            0x00000000
360 #define PORT_FEATURE_WOL_DEFAULT_MAGIC              0x00000001
361 #define PORT_FEATURE_WOL_DEFAULT_ACPI               0x00000002
362 #define PORT_FEATURE_WOL_DEFAULT_MAGIC_AND_ACPI     0x00000003
363 #define PORT_FEATURE_WOL_RES_PAUSE_CAP              0x00000004
364 #define PORT_FEATURE_WOL_RES_ASYM_PAUSE_CAP         0x00000008
365 #define PORT_FEATURE_WOL_ACPI_UPON_MGMT             0x00000010
366
367         u32 mba_config;
368 #define PORT_FEATURE_MBA_BOOT_AGENT_TYPE_MASK       0x00000003
369 #define PORT_FEATURE_MBA_BOOT_AGENT_TYPE_SHIFT      0
370 #define PORT_FEATURE_MBA_BOOT_AGENT_TYPE_PXE        0x00000000
371 #define PORT_FEATURE_MBA_BOOT_AGENT_TYPE_RPL        0x00000001
372 #define PORT_FEATURE_MBA_BOOT_AGENT_TYPE_BOOTP      0x00000002
373 #define PORT_FEATURE_MBA_BOOT_AGENT_TYPE_ISCSIB     0x00000003
374 #define PORT_FEATURE_MBA_RES_PAUSE_CAP              0x00000100
375 #define PORT_FEATURE_MBA_RES_ASYM_PAUSE_CAP         0x00000200
376 #define PORT_FEATURE_MBA_SETUP_PROMPT_ENABLE        0x00000400
377 #define PORT_FEATURE_MBA_HOTKEY_CTRL_S              0x00000000
378 #define PORT_FEATURE_MBA_HOTKEY_CTRL_B              0x00000800
379 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_MASK          0x000ff000
380 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_SHIFT         12
381 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_DISABLED      0x00000000
382 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_2K            0x00001000
383 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_4K            0x00002000
384 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_8K            0x00003000
385 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_16K           0x00004000
386 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_32K           0x00005000
387 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_64K           0x00006000
388 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_128K          0x00007000
389 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_256K          0x00008000
390 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_512K          0x00009000
391 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_1M            0x0000a000
392 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_2M            0x0000b000
393 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_4M            0x0000c000
394 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_8M            0x0000d000
395 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_16M           0x0000e000
396 #define PORT_FEATURE_MBA_EXP_ROM_SIZE_32M           0x0000f000
397 #define PORT_FEATURE_MBA_MSG_TIMEOUT_MASK           0x00f00000
398 #define PORT_FEATURE_MBA_MSG_TIMEOUT_SHIFT          20
399 #define PORT_FEATURE_MBA_BIOS_BOOTSTRAP_MASK        0x03000000
400 #define PORT_FEATURE_MBA_BIOS_BOOTSTRAP_SHIFT       24
401 #define PORT_FEATURE_MBA_BIOS_BOOTSTRAP_AUTO        0x00000000
402 #define PORT_FEATURE_MBA_BIOS_BOOTSTRAP_BBS         0x01000000
403 #define PORT_FEATURE_MBA_BIOS_BOOTSTRAP_INT18H      0x02000000
404 #define PORT_FEATURE_MBA_BIOS_BOOTSTRAP_INT19H      0x03000000
405 #define PORT_FEATURE_MBA_LINK_SPEED_MASK            0x3c000000
406 #define PORT_FEATURE_MBA_LINK_SPEED_SHIFT           26
407 #define PORT_FEATURE_MBA_LINK_SPEED_AUTO            0x00000000
408 #define PORT_FEATURE_MBA_LINK_SPEED_10HD            0x04000000
409 #define PORT_FEATURE_MBA_LINK_SPEED_10FD            0x08000000
410 #define PORT_FEATURE_MBA_LINK_SPEED_100HD           0x0c000000
411 #define PORT_FEATURE_MBA_LINK_SPEED_100FD           0x10000000
412 #define PORT_FEATURE_MBA_LINK_SPEED_1GBPS           0x14000000
413 #define PORT_FEATURE_MBA_LINK_SPEED_2_5GBPS         0x18000000
414 #define PORT_FEATURE_MBA_LINK_SPEED_10GBPS_CX4      0x1c000000
415 #define PORT_FEATURE_MBA_LINK_SPEED_10GBPS_KX4      0x20000000
416 #define PORT_FEATURE_MBA_LINK_SPEED_10GBPS_KR       0x24000000
417 #define PORT_FEATURE_MBA_LINK_SPEED_12GBPS          0x28000000
418 #define PORT_FEATURE_MBA_LINK_SPEED_12_5GBPS        0x2c000000
419 #define PORT_FEATURE_MBA_LINK_SPEED_13GBPS          0x30000000
420 #define PORT_FEATURE_MBA_LINK_SPEED_15GBPS          0x34000000
421 #define PORT_FEATURE_MBA_LINK_SPEED_16GBPS          0x38000000
422
423         u32 bmc_config;
424 #define PORT_FEATURE_BMC_LINK_OVERRIDE_DEFAULT      0x00000000
425 #define PORT_FEATURE_BMC_LINK_OVERRIDE_EN           0x00000001
426
427         u32 mba_vlan_cfg;
428 #define PORT_FEATURE_MBA_VLAN_TAG_MASK              0x0000ffff
429 #define PORT_FEATURE_MBA_VLAN_TAG_SHIFT             0
430 #define PORT_FEATURE_MBA_VLAN_EN                    0x00010000
431
432         u32 resource_cfg;
433 #define PORT_FEATURE_RESOURCE_CFG_VALID             0x00000001
434 #define PORT_FEATURE_RESOURCE_CFG_DIAG              0x00000002
435 #define PORT_FEATURE_RESOURCE_CFG_L2                0x00000004
436 #define PORT_FEATURE_RESOURCE_CFG_ISCSI             0x00000008
437 #define PORT_FEATURE_RESOURCE_CFG_RDMA              0x00000010
438
439         u32 smbus_config;
440         /* Obsolete */
441 #define PORT_FEATURE_SMBUS_EN                       0x00000001
442 #define PORT_FEATURE_SMBUS_ADDR_MASK                0x000000fe
443 #define PORT_FEATURE_SMBUS_ADDR_SHIFT               1
444
445         u32 reserved1;
446
447         u32 link_config;    /* Used as HW defaults for the driver */
448 #define PORT_FEATURE_CONNECTED_SWITCH_MASK          0x03000000
449 #define PORT_FEATURE_CONNECTED_SWITCH_SHIFT         24
450         /* (forced) low speed switch (< 10G) */
451 #define PORT_FEATURE_CON_SWITCH_1G_SWITCH           0x00000000
452         /* (forced) high speed switch (>= 10G) */
453 #define PORT_FEATURE_CON_SWITCH_10G_SWITCH          0x01000000
454 #define PORT_FEATURE_CON_SWITCH_AUTO_DETECT         0x02000000
455 #define PORT_FEATURE_CON_SWITCH_ONE_TIME_DETECT     0x03000000
456
457 #define PORT_FEATURE_LINK_SPEED_MASK                0x000f0000
458 #define PORT_FEATURE_LINK_SPEED_SHIFT               16
459 #define PORT_FEATURE_LINK_SPEED_AUTO                0x00000000
460 #define PORT_FEATURE_LINK_SPEED_10M_FULL            0x00010000
461 #define PORT_FEATURE_LINK_SPEED_10M_HALF            0x00020000
462 #define PORT_FEATURE_LINK_SPEED_100M_HALF           0x00030000
463 #define PORT_FEATURE_LINK_SPEED_100M_FULL           0x00040000
464 #define PORT_FEATURE_LINK_SPEED_1G                  0x00050000
465 #define PORT_FEATURE_LINK_SPEED_2_5G                0x00060000
466 #define PORT_FEATURE_LINK_SPEED_10G_CX4             0x00070000
467 #define PORT_FEATURE_LINK_SPEED_10G_KX4             0x00080000
468 #define PORT_FEATURE_LINK_SPEED_10G_KR              0x00090000
469 #define PORT_FEATURE_LINK_SPEED_12G                 0x000a0000
470 #define PORT_FEATURE_LINK_SPEED_12_5G               0x000b0000
471 #define PORT_FEATURE_LINK_SPEED_13G                 0x000c0000
472 #define PORT_FEATURE_LINK_SPEED_15G                 0x000d0000
473 #define PORT_FEATURE_LINK_SPEED_16G                 0x000e0000
474
475 #define PORT_FEATURE_FLOW_CONTROL_MASK              0x00000700
476 #define PORT_FEATURE_FLOW_CONTROL_SHIFT             8
477 #define PORT_FEATURE_FLOW_CONTROL_AUTO              0x00000000
478 #define PORT_FEATURE_FLOW_CONTROL_TX                0x00000100
479 #define PORT_FEATURE_FLOW_CONTROL_RX                0x00000200
480 #define PORT_FEATURE_FLOW_CONTROL_BOTH              0x00000300
481 #define PORT_FEATURE_FLOW_CONTROL_NONE              0x00000400
482
483         /* The default for MCP link configuration,
484            uses the same defines as link_config */
485         u32 mfw_wol_link_cfg;
486
487         u32 reserved[19];
488
489 };
490
491
492 /****************************************************************************
493  * Device Information                                                       *
494  ****************************************************************************/
495 struct dev_info {                                                   /* size */
496
497         u32    bc_rev; /* 8 bits each: major, minor, build */          /* 4 */
498
499         struct shared_hw_cfg     shared_hw_config;                    /* 40 */
500
501         struct port_hw_cfg       port_hw_config[PORT_MAX];     /* 400*2=800 */
502
503         struct shared_feat_cfg   shared_feature_config;                /* 4 */
504
505         struct port_feat_cfg     port_feature_config[PORT_MAX];/* 116*2=232 */
506
507 };
508
509
510 #define FUNC_0                          0
511 #define FUNC_1                          1
512 #define FUNC_2                          2
513 #define FUNC_3                          3
514 #define FUNC_4                          4
515 #define FUNC_5                          5
516 #define FUNC_6                          6
517 #define FUNC_7                          7
518 #define E1_FUNC_MAX                     2
519 #define E1H_FUNC_MAX                    8
520
521 #define VN_0                            0
522 #define VN_1                            1
523 #define VN_2                            2
524 #define VN_3                            3
525 #define E1VN_MAX                        1
526 #define E1HVN_MAX                       4
527
528
529 /* This value (in milliseconds) determines the frequency of the driver
530  * issuing the PULSE message code.  The firmware monitors this periodic
531  * pulse to determine when to switch to an OS-absent mode. */
532 #define DRV_PULSE_PERIOD_MS             250
533
534 /* This value (in milliseconds) determines how long the driver should
535  * wait for an acknowledgement from the firmware before timing out.  Once
536  * the firmware has timed out, the driver will assume there is no firmware
537  * running and there won't be any firmware-driver synchronization during a
538  * driver reset. */
539 #define FW_ACK_TIME_OUT_MS              5000
540
541 #define FW_ACK_POLL_TIME_MS             1
542
543 #define FW_ACK_NUM_OF_POLL      (FW_ACK_TIME_OUT_MS/FW_ACK_POLL_TIME_MS)
544
545 /* LED Blink rate that will achieve ~15.9Hz */
546 #define LED_BLINK_RATE_VAL              480
547
548 /****************************************************************************
549  * Driver <-> FW Mailbox                                                    *
550  ****************************************************************************/
551 struct drv_port_mb {
552
553         u32 link_status;
554         /* Driver should update this field on any link change event */
555
556 #define LINK_STATUS_LINK_FLAG_MASK                      0x00000001
557 #define LINK_STATUS_LINK_UP                             0x00000001
558 #define LINK_STATUS_SPEED_AND_DUPLEX_MASK               0x0000001E
559 #define LINK_STATUS_SPEED_AND_DUPLEX_AN_NOT_COMPLETE    (0<<1)
560 #define LINK_STATUS_SPEED_AND_DUPLEX_10THD              (1<<1)
561 #define LINK_STATUS_SPEED_AND_DUPLEX_10TFD              (2<<1)
562 #define LINK_STATUS_SPEED_AND_DUPLEX_100TXHD            (3<<1)
563 #define LINK_STATUS_SPEED_AND_DUPLEX_100T4              (4<<1)
564 #define LINK_STATUS_SPEED_AND_DUPLEX_100TXFD            (5<<1)
565 #define LINK_STATUS_SPEED_AND_DUPLEX_1000THD            (6<<1)
566 #define LINK_STATUS_SPEED_AND_DUPLEX_1000TFD            (7<<1)
567 #define LINK_STATUS_SPEED_AND_DUPLEX_1000XFD            (7<<1)
568 #define LINK_STATUS_SPEED_AND_DUPLEX_2500THD            (8<<1)
569 #define LINK_STATUS_SPEED_AND_DUPLEX_2500TFD            (9<<1)
570 #define LINK_STATUS_SPEED_AND_DUPLEX_2500XFD            (9<<1)
571 #define LINK_STATUS_SPEED_AND_DUPLEX_10GTFD             (10<<1)
572 #define LINK_STATUS_SPEED_AND_DUPLEX_10GXFD             (10<<1)
573 #define LINK_STATUS_SPEED_AND_DUPLEX_12GTFD             (11<<1)
574 #define LINK_STATUS_SPEED_AND_DUPLEX_12GXFD             (11<<1)
575 #define LINK_STATUS_SPEED_AND_DUPLEX_12_5GTFD           (12<<1)
576 #define LINK_STATUS_SPEED_AND_DUPLEX_12_5GXFD           (12<<1)
577 #define LINK_STATUS_SPEED_AND_DUPLEX_13GTFD             (13<<1)
578 #define LINK_STATUS_SPEED_AND_DUPLEX_13GXFD             (13<<1)
579 #define LINK_STATUS_SPEED_AND_DUPLEX_15GTFD             (14<<1)
580 #define LINK_STATUS_SPEED_AND_DUPLEX_15GXFD             (14<<1)
581 #define LINK_STATUS_SPEED_AND_DUPLEX_16GTFD             (15<<1)
582 #define LINK_STATUS_SPEED_AND_DUPLEX_16GXFD             (15<<1)
583
584 #define LINK_STATUS_AUTO_NEGOTIATE_FLAG_MASK            0x00000020
585 #define LINK_STATUS_AUTO_NEGOTIATE_ENABLED              0x00000020
586
587 #define LINK_STATUS_AUTO_NEGOTIATE_COMPLETE             0x00000040
588 #define LINK_STATUS_PARALLEL_DETECTION_FLAG_MASK        0x00000080
589 #define LINK_STATUS_PARALLEL_DETECTION_USED             0x00000080
590
591 #define LINK_STATUS_LINK_PARTNER_1000TFD_CAPABLE        0x00000200
592 #define LINK_STATUS_LINK_PARTNER_1000THD_CAPABLE        0x00000400
593 #define LINK_STATUS_LINK_PARTNER_100T4_CAPABLE          0x00000800
594 #define LINK_STATUS_LINK_PARTNER_100TXFD_CAPABLE        0x00001000
595 #define LINK_STATUS_LINK_PARTNER_100TXHD_CAPABLE        0x00002000
596 #define LINK_STATUS_LINK_PARTNER_10TFD_CAPABLE          0x00004000
597 #define LINK_STATUS_LINK_PARTNER_10THD_CAPABLE          0x00008000
598
599 #define LINK_STATUS_TX_FLOW_CONTROL_FLAG_MASK           0x00010000
600 #define LINK_STATUS_TX_FLOW_CONTROL_ENABLED             0x00010000
601
602 #define LINK_STATUS_RX_FLOW_CONTROL_FLAG_MASK           0x00020000
603 #define LINK_STATUS_RX_FLOW_CONTROL_ENABLED             0x00020000
604
605 #define LINK_STATUS_LINK_PARTNER_FLOW_CONTROL_MASK      0x000C0000
606 #define LINK_STATUS_LINK_PARTNER_NOT_PAUSE_CAPABLE      (0<<18)
607 #define LINK_STATUS_LINK_PARTNER_SYMMETRIC_PAUSE        (1<<18)
608 #define LINK_STATUS_LINK_PARTNER_ASYMMETRIC_PAUSE       (2<<18)
609 #define LINK_STATUS_LINK_PARTNER_BOTH_PAUSE             (3<<18)
610
611 #define LINK_STATUS_SERDES_LINK                         0x00100000
612
613 #define LINK_STATUS_LINK_PARTNER_2500XFD_CAPABLE        0x00200000
614 #define LINK_STATUS_LINK_PARTNER_2500XHD_CAPABLE        0x00400000
615 #define LINK_STATUS_LINK_PARTNER_10GXFD_CAPABLE         0x00800000
616 #define LINK_STATUS_LINK_PARTNER_12GXFD_CAPABLE         0x01000000
617 #define LINK_STATUS_LINK_PARTNER_12_5GXFD_CAPABLE       0x02000000
618 #define LINK_STATUS_LINK_PARTNER_13GXFD_CAPABLE         0x04000000
619 #define LINK_STATUS_LINK_PARTNER_15GXFD_CAPABLE         0x08000000
620 #define LINK_STATUS_LINK_PARTNER_16GXFD_CAPABLE         0x10000000
621
622         u32 port_stx;
623
624         u32 stat_nig_timer;
625
626
627 };
628
629
630 struct drv_func_mb {
631
632         u32 drv_mb_header;
633 #define DRV_MSG_CODE_MASK                               0xffff0000
634 #define DRV_MSG_CODE_LOAD_REQ                           0x10000000
635 #define DRV_MSG_CODE_LOAD_DONE                          0x11000000
636 #define DRV_MSG_CODE_UNLOAD_REQ_WOL_EN                  0x20000000
637 #define DRV_MSG_CODE_UNLOAD_REQ_WOL_DIS                 0x20010000
638 #define DRV_MSG_CODE_UNLOAD_REQ_WOL_MCP                 0x20020000
639 #define DRV_MSG_CODE_UNLOAD_DONE                        0x21000000
640 #define DRV_MSG_CODE_DIAG_ENTER_REQ                     0x50000000
641 #define DRV_MSG_CODE_DIAG_EXIT_REQ                      0x60000000
642 #define DRV_MSG_CODE_VALIDATE_KEY                       0x70000000
643 #define DRV_MSG_CODE_GET_CURR_KEY                       0x80000000
644 #define DRV_MSG_CODE_GET_UPGRADE_KEY                    0x81000000
645 #define DRV_MSG_CODE_GET_MANUF_KEY                      0x82000000
646 #define DRV_MSG_CODE_LOAD_L2B_PRAM                      0x90000000
647
648 #define BIOS_MSG_CODE_LIC_CHALLENGE                     0xff010000
649 #define BIOS_MSG_CODE_LIC_RESPONSE                      0xff020000
650 #define BIOS_MSG_CODE_VIRT_MAC_PRIM                     0xff030000
651 #define BIOS_MSG_CODE_VIRT_MAC_ISCSI                    0xff040000
652
653 #define DRV_MSG_SEQ_NUMBER_MASK                         0x0000ffff
654
655         u32 drv_mb_param;
656
657         u32 fw_mb_header;
658 #define FW_MSG_CODE_MASK                                0xffff0000
659 #define FW_MSG_CODE_DRV_LOAD_COMMON                     0x10100000
660 #define FW_MSG_CODE_DRV_LOAD_PORT                       0x10110000
661 #define FW_MSG_CODE_DRV_LOAD_FUNCTION                   0x10120000
662 #define FW_MSG_CODE_DRV_LOAD_REFUSED                    0x10200000
663 #define FW_MSG_CODE_DRV_LOAD_DONE                       0x11100000
664 #define FW_MSG_CODE_DRV_UNLOAD_COMMON                   0x20100000
665 #define FW_MSG_CODE_DRV_UNLOAD_PORT                     0x20110000
666 #define FW_MSG_CODE_DRV_UNLOAD_FUNCTION                 0x20120000
667 #define FW_MSG_CODE_DRV_UNLOAD_DONE                     0x21100000
668 #define FW_MSG_CODE_DIAG_ENTER_DONE                     0x50100000
669 #define FW_MSG_CODE_DIAG_REFUSE                         0x50200000
670 #define FW_MSG_CODE_DIAG_EXIT_DONE                      0x60100000
671 #define FW_MSG_CODE_VALIDATE_KEY_SUCCESS                0x70100000
672 #define FW_MSG_CODE_VALIDATE_KEY_FAILURE                0x70200000
673 #define FW_MSG_CODE_GET_KEY_DONE                        0x80100000
674 #define FW_MSG_CODE_NO_KEY                              0x80f00000
675 #define FW_MSG_CODE_LIC_INFO_NOT_READY                  0x80f80000
676 #define FW_MSG_CODE_L2B_PRAM_LOADED                     0x90100000
677 #define FW_MSG_CODE_L2B_PRAM_T_LOAD_FAILURE             0x90210000
678 #define FW_MSG_CODE_L2B_PRAM_C_LOAD_FAILURE             0x90220000
679 #define FW_MSG_CODE_L2B_PRAM_X_LOAD_FAILURE             0x90230000
680 #define FW_MSG_CODE_L2B_PRAM_U_LOAD_FAILURE             0x90240000
681
682 #define FW_MSG_CODE_LIC_CHALLENGE                       0xff010000
683 #define FW_MSG_CODE_LIC_RESPONSE                        0xff020000
684 #define FW_MSG_CODE_VIRT_MAC_PRIM                       0xff030000
685 #define FW_MSG_CODE_VIRT_MAC_ISCSI                      0xff040000
686
687 #define FW_MSG_SEQ_NUMBER_MASK                          0x0000ffff
688
689         u32 fw_mb_param;
690
691         u32 drv_pulse_mb;
692 #define DRV_PULSE_SEQ_MASK                              0x00007fff
693 #define DRV_PULSE_SYSTEM_TIME_MASK                      0xffff0000
694         /* The system time is in the format of
695          * (year-2001)*12*32 + month*32 + day. */
696 #define DRV_PULSE_ALWAYS_ALIVE                          0x00008000
697         /* Indicate to the firmware not to go into the
698          * OS-absent when it is not getting driver pulse.
699          * This is used for debugging as well for PXE(MBA). */
700
701         u32 mcp_pulse_mb;
702 #define MCP_PULSE_SEQ_MASK                              0x00007fff
703 #define MCP_PULSE_ALWAYS_ALIVE                          0x00008000
704         /* Indicates to the driver not to assert due to lack
705          * of MCP response */
706 #define MCP_EVENT_MASK                                  0xffff0000
707 #define MCP_EVENT_OTHER_DRIVER_RESET_REQ                0x00010000
708
709         u32 iscsi_boot_signature;
710         u32 iscsi_boot_block_offset;
711
712         u32 drv_status;
713 #define DRV_STATUS_PMF                                  0x00000001
714
715         u32 virt_mac_upper;
716 #define VIRT_MAC_SIGN_MASK                              0xffff0000
717 #define VIRT_MAC_SIGNATURE                              0x564d0000
718         u32 virt_mac_lower;
719
720 };
721
722
723 /****************************************************************************
724  * Management firmware state                                                *
725  ****************************************************************************/
726 /* Allocate 440 bytes for management firmware */
727 #define MGMTFW_STATE_WORD_SIZE                              110
728
729 struct mgmtfw_state {
730         u32 opaque[MGMTFW_STATE_WORD_SIZE];
731 };
732
733
734 /****************************************************************************
735  * Multi-Function configuration                                             *
736  ****************************************************************************/
737 struct shared_mf_cfg {
738
739         u32 clp_mb;
740 #define SHARED_MF_CLP_SET_DEFAULT                   0x00000000
741         /* set by CLP */
742 #define SHARED_MF_CLP_EXIT                          0x00000001
743         /* set by MCP */
744 #define SHARED_MF_CLP_EXIT_DONE                     0x00010000
745
746 };
747
748 struct port_mf_cfg {
749
750         u32 dynamic_cfg;        /* device control channel */
751 #define PORT_MF_CFG_OUTER_VLAN_TAG_MASK             0x0000ffff
752 #define PORT_MF_CFG_OUTER_VLAN_TAG_SHIFT            0
753 #define PORT_MF_CFG_DYNAMIC_CFG_ENABLED             0x00010000
754 #define PORT_MF_CFG_DYNAMIC_CFG_DEFAULT             0x00000000
755
756         u32 reserved[3];
757
758 };
759
760 struct func_mf_cfg {
761
762         u32 config;
763         /* E/R/I/D */
764         /* function 0 of each port cannot be hidden */
765 #define FUNC_MF_CFG_FUNC_HIDE                       0x00000001
766
767 #define FUNC_MF_CFG_PROTOCOL_MASK                   0x00000007
768 #define FUNC_MF_CFG_PROTOCOL_ETHERNET               0x00000002
769 #define FUNC_MF_CFG_PROTOCOL_ETHERNET_WITH_RDMA     0x00000004
770 #define FUNC_MF_CFG_PROTOCOL_ISCSI                  0x00000006
771 #define FUNC_MF_CFG_PROTOCOL_DEFAULT\
772         FUNC_MF_CFG_PROTOCOL_ETHERNET_WITH_RDMA
773
774 #define FUNC_MF_CFG_FUNC_DISABLED                   0x00000008
775
776         /* PRI */
777         /* 0 - low priority, 3 - high priority */
778 #define FUNC_MF_CFG_TRANSMIT_PRIORITY_MASK          0x00000300
779 #define FUNC_MF_CFG_TRANSMIT_PRIORITY_SHIFT         8
780 #define FUNC_MF_CFG_TRANSMIT_PRIORITY_DEFAULT       0x00000000
781
782         /* MINBW, MAXBW */
783         /* value range - 0..100, increments in 100Mbps */
784 #define FUNC_MF_CFG_MIN_BW_MASK                     0x00ff0000
785 #define FUNC_MF_CFG_MIN_BW_SHIFT                    16
786 #define FUNC_MF_CFG_MIN_BW_DEFAULT                  0x00000000
787 #define FUNC_MF_CFG_MAX_BW_MASK                     0xff000000
788 #define FUNC_MF_CFG_MAX_BW_SHIFT                    24
789 #define FUNC_MF_CFG_MAX_BW_DEFAULT                  0x64000000
790
791         u32 mac_upper;          /* MAC */
792 #define FUNC_MF_CFG_UPPERMAC_MASK                   0x0000ffff
793 #define FUNC_MF_CFG_UPPERMAC_SHIFT                  0
794 #define FUNC_MF_CFG_UPPERMAC_DEFAULT                FUNC_MF_CFG_UPPERMAC_MASK
795         u32 mac_lower;
796 #define FUNC_MF_CFG_LOWERMAC_DEFAULT                0xffffffff
797
798         u32 e1hov_tag;  /* VNI */
799 #define FUNC_MF_CFG_E1HOV_TAG_MASK                  0x0000ffff
800 #define FUNC_MF_CFG_E1HOV_TAG_SHIFT                 0
801 #define FUNC_MF_CFG_E1HOV_TAG_DEFAULT               FUNC_MF_CFG_E1HOV_TAG_MASK
802
803         u32 reserved[2];
804
805 };
806
807 struct mf_cfg {
808
809         struct shared_mf_cfg    shared_mf_config;
810         struct port_mf_cfg      port_mf_config[PORT_MAX];
811 #if defined(b710)
812         struct func_mf_cfg      func_mf_config[E1_FUNC_MAX];
813 #else
814         struct func_mf_cfg      func_mf_config[E1H_FUNC_MAX];
815 #endif
816
817 };
818
819
820 /****************************************************************************
821  * Shared Memory Region                                                     *
822  ****************************************************************************/
823 struct shmem_region {                          /*   SharedMem Offset (size) */
824
825         u32                     validity_map[PORT_MAX];  /* 0x0 (4*2 = 0x8) */
826 #define SHR_MEM_FORMAT_REV_ID                       ('A'<<24)
827 #define SHR_MEM_FORMAT_REV_MASK                     0xff000000
828         /* validity bits */
829 #define SHR_MEM_VALIDITY_PCI_CFG                    0x00100000
830 #define SHR_MEM_VALIDITY_MB                         0x00200000
831 #define SHR_MEM_VALIDITY_DEV_INFO                   0x00400000
832 #define SHR_MEM_VALIDITY_RESERVED                   0x00000007
833         /* One licensing bit should be set */
834 #define SHR_MEM_VALIDITY_LIC_KEY_IN_EFFECT_MASK     0x00000038
835 #define SHR_MEM_VALIDITY_LIC_MANUF_KEY_IN_EFFECT    0x00000008
836 #define SHR_MEM_VALIDITY_LIC_UPGRADE_KEY_IN_EFFECT  0x00000010
837 #define SHR_MEM_VALIDITY_LIC_NO_KEY_IN_EFFECT       0x00000020
838         /* Active MFW */
839 #define SHR_MEM_VALIDITY_ACTIVE_MFW_UNKNOWN         0x00000000
840 #define SHR_MEM_VALIDITY_ACTIVE_MFW_IPMI            0x00000040
841 #define SHR_MEM_VALIDITY_ACTIVE_MFW_UMP             0x00000080
842 #define SHR_MEM_VALIDITY_ACTIVE_MFW_NCSI            0x000000c0
843 #define SHR_MEM_VALIDITY_ACTIVE_MFW_NONE            0x000001c0
844 #define SHR_MEM_VALIDITY_ACTIVE_MFW_MASK            0x000001c0
845
846         struct dev_info         dev_info;                /* 0x8     (0x438) */
847
848         u8                      reserved[52*PORT_MAX];
849
850         /* FW information (for internal FW use) */
851         u32                     fw_info_fio_offset;    /* 0x4a8       (0x4) */
852         struct mgmtfw_state     mgmtfw_state;          /* 0x4ac     (0x1b8) */
853
854         struct drv_port_mb      port_mb[PORT_MAX];     /* 0x664 (16*2=0x20) */
855         struct drv_func_mb      func_mb[E1H_FUNC_MAX];
856
857         struct mf_cfg           mf_cfg;
858
859 };                                                     /* 0x6dc */
860
861
862 struct emac_stats {
863     u32     rx_stat_ifhcinoctets;
864     u32     rx_stat_ifhcinbadoctets;
865     u32     rx_stat_etherstatsfragments;
866     u32     rx_stat_ifhcinucastpkts;
867     u32     rx_stat_ifhcinmulticastpkts;
868     u32     rx_stat_ifhcinbroadcastpkts;
869     u32     rx_stat_dot3statsfcserrors;
870     u32     rx_stat_dot3statsalignmenterrors;
871     u32     rx_stat_dot3statscarriersenseerrors;
872     u32     rx_stat_xonpauseframesreceived;
873     u32     rx_stat_xoffpauseframesreceived;
874     u32     rx_stat_maccontrolframesreceived;
875     u32     rx_stat_xoffstateentered;
876     u32     rx_stat_dot3statsframestoolong;
877     u32     rx_stat_etherstatsjabbers;
878     u32     rx_stat_etherstatsundersizepkts;
879     u32     rx_stat_etherstatspkts64octets;
880     u32     rx_stat_etherstatspkts65octetsto127octets;
881     u32     rx_stat_etherstatspkts128octetsto255octets;
882     u32     rx_stat_etherstatspkts256octetsto511octets;
883     u32     rx_stat_etherstatspkts512octetsto1023octets;
884     u32     rx_stat_etherstatspkts1024octetsto1522octets;
885     u32     rx_stat_etherstatspktsover1522octets;
886
887     u32     rx_stat_falsecarriererrors;
888
889     u32     tx_stat_ifhcoutoctets;
890     u32     tx_stat_ifhcoutbadoctets;
891     u32     tx_stat_etherstatscollisions;
892     u32     tx_stat_outxonsent;
893     u32     tx_stat_outxoffsent;
894     u32     tx_stat_flowcontroldone;
895     u32     tx_stat_dot3statssinglecollisionframes;
896     u32     tx_stat_dot3statsmultiplecollisionframes;
897     u32     tx_stat_dot3statsdeferredtransmissions;
898     u32     tx_stat_dot3statsexcessivecollisions;
899     u32     tx_stat_dot3statslatecollisions;
900     u32     tx_stat_ifhcoutucastpkts;
901     u32     tx_stat_ifhcoutmulticastpkts;
902     u32     tx_stat_ifhcoutbroadcastpkts;
903     u32     tx_stat_etherstatspkts64octets;
904     u32     tx_stat_etherstatspkts65octetsto127octets;
905     u32     tx_stat_etherstatspkts128octetsto255octets;
906     u32     tx_stat_etherstatspkts256octetsto511octets;
907     u32     tx_stat_etherstatspkts512octetsto1023octets;
908     u32     tx_stat_etherstatspkts1024octetsto1522octets;
909     u32     tx_stat_etherstatspktsover1522octets;
910     u32     tx_stat_dot3statsinternalmactransmiterrors;
911 };
912
913
914 struct bmac_stats {
915     u32     tx_stat_gtpkt_lo;
916     u32     tx_stat_gtpkt_hi;
917     u32     tx_stat_gtxpf_lo;
918     u32     tx_stat_gtxpf_hi;
919     u32     tx_stat_gtfcs_lo;
920     u32     tx_stat_gtfcs_hi;
921     u32     tx_stat_gtmca_lo;
922     u32     tx_stat_gtmca_hi;
923     u32     tx_stat_gtbca_lo;
924     u32     tx_stat_gtbca_hi;
925     u32     tx_stat_gtfrg_lo;
926     u32     tx_stat_gtfrg_hi;
927     u32     tx_stat_gtovr_lo;
928     u32     tx_stat_gtovr_hi;
929     u32     tx_stat_gt64_lo;
930     u32     tx_stat_gt64_hi;
931     u32     tx_stat_gt127_lo;
932     u32     tx_stat_gt127_hi;
933     u32     tx_stat_gt255_lo;
934     u32     tx_stat_gt255_hi;
935     u32     tx_stat_gt511_lo;
936     u32     tx_stat_gt511_hi;
937     u32     tx_stat_gt1023_lo;
938     u32     tx_stat_gt1023_hi;
939     u32     tx_stat_gt1518_lo;
940     u32     tx_stat_gt1518_hi;
941     u32     tx_stat_gt2047_lo;
942     u32     tx_stat_gt2047_hi;
943     u32     tx_stat_gt4095_lo;
944     u32     tx_stat_gt4095_hi;
945     u32     tx_stat_gt9216_lo;
946     u32     tx_stat_gt9216_hi;
947     u32     tx_stat_gt16383_lo;
948     u32     tx_stat_gt16383_hi;
949     u32     tx_stat_gtmax_lo;
950     u32     tx_stat_gtmax_hi;
951     u32     tx_stat_gtufl_lo;
952     u32     tx_stat_gtufl_hi;
953     u32     tx_stat_gterr_lo;
954     u32     tx_stat_gterr_hi;
955     u32     tx_stat_gtbyt_lo;
956     u32     tx_stat_gtbyt_hi;
957
958     u32     rx_stat_gr64_lo;
959     u32     rx_stat_gr64_hi;
960     u32     rx_stat_gr127_lo;
961     u32     rx_stat_gr127_hi;
962     u32     rx_stat_gr255_lo;
963     u32     rx_stat_gr255_hi;
964     u32     rx_stat_gr511_lo;
965     u32     rx_stat_gr511_hi;
966     u32     rx_stat_gr1023_lo;
967     u32     rx_stat_gr1023_hi;
968     u32     rx_stat_gr1518_lo;
969     u32     rx_stat_gr1518_hi;
970     u32     rx_stat_gr2047_lo;
971     u32     rx_stat_gr2047_hi;
972     u32     rx_stat_gr4095_lo;
973     u32     rx_stat_gr4095_hi;
974     u32     rx_stat_gr9216_lo;
975     u32     rx_stat_gr9216_hi;
976     u32     rx_stat_gr16383_lo;
977     u32     rx_stat_gr16383_hi;
978     u32     rx_stat_grmax_lo;
979     u32     rx_stat_grmax_hi;
980     u32     rx_stat_grpkt_lo;
981     u32     rx_stat_grpkt_hi;
982     u32     rx_stat_grfcs_lo;
983     u32     rx_stat_grfcs_hi;
984     u32     rx_stat_grmca_lo;
985     u32     rx_stat_grmca_hi;
986     u32     rx_stat_grbca_lo;
987     u32     rx_stat_grbca_hi;
988     u32     rx_stat_grxcf_lo;
989     u32     rx_stat_grxcf_hi;
990     u32     rx_stat_grxpf_lo;
991     u32     rx_stat_grxpf_hi;
992     u32     rx_stat_grxuo_lo;
993     u32     rx_stat_grxuo_hi;
994     u32     rx_stat_grjbr_lo;
995     u32     rx_stat_grjbr_hi;
996     u32     rx_stat_grovr_lo;
997     u32     rx_stat_grovr_hi;
998     u32     rx_stat_grflr_lo;
999     u32     rx_stat_grflr_hi;
1000     u32     rx_stat_grmeg_lo;
1001     u32     rx_stat_grmeg_hi;
1002     u32     rx_stat_grmeb_lo;
1003     u32     rx_stat_grmeb_hi;
1004     u32     rx_stat_grbyt_lo;
1005     u32     rx_stat_grbyt_hi;
1006     u32     rx_stat_grund_lo;
1007     u32     rx_stat_grund_hi;
1008     u32     rx_stat_grfrg_lo;
1009     u32     rx_stat_grfrg_hi;
1010     u32     rx_stat_grerb_lo;
1011     u32     rx_stat_grerb_hi;
1012     u32     rx_stat_grfre_lo;
1013     u32     rx_stat_grfre_hi;
1014     u32     rx_stat_gripj_lo;
1015     u32     rx_stat_gripj_hi;
1016 };
1017
1018
1019 union mac_stats {
1020     struct emac_stats   emac_stats;
1021     struct bmac_stats   bmac_stats;
1022 };
1023
1024
1025 struct mac_stx {
1026     /* in_bad_octets */
1027     u32     rx_stat_ifhcinbadoctets_hi;
1028     u32     rx_stat_ifhcinbadoctets_lo;
1029
1030     /* out_bad_octets */
1031     u32     tx_stat_ifhcoutbadoctets_hi;
1032     u32     tx_stat_ifhcoutbadoctets_lo;
1033
1034     /* crc_receive_errors */
1035     u32     rx_stat_dot3statsfcserrors_hi;
1036     u32     rx_stat_dot3statsfcserrors_lo;
1037     /* alignment_errors */
1038     u32     rx_stat_dot3statsalignmenterrors_hi;
1039     u32     rx_stat_dot3statsalignmenterrors_lo;
1040     /* carrier_sense_errors */
1041     u32     rx_stat_dot3statscarriersenseerrors_hi;
1042     u32     rx_stat_dot3statscarriersenseerrors_lo;
1043     /* false_carrier_detections */
1044     u32     rx_stat_falsecarriererrors_hi;
1045     u32     rx_stat_falsecarriererrors_lo;
1046
1047     /* runt_packets_received */
1048     u32     rx_stat_etherstatsundersizepkts_hi;
1049     u32     rx_stat_etherstatsundersizepkts_lo;
1050     /* jabber_packets_received */
1051     u32     rx_stat_dot3statsframestoolong_hi;
1052     u32     rx_stat_dot3statsframestoolong_lo;
1053
1054     /* error_runt_packets_received */
1055     u32     rx_stat_etherstatsfragments_hi;
1056     u32     rx_stat_etherstatsfragments_lo;
1057     /* error_jabber_packets_received */
1058     u32     rx_stat_etherstatsjabbers_hi;
1059     u32     rx_stat_etherstatsjabbers_lo;
1060
1061     /* control_frames_received */
1062     u32     rx_stat_maccontrolframesreceived_hi;
1063     u32     rx_stat_maccontrolframesreceived_lo;
1064     u32     rx_stat_bmac_xpf_hi;
1065     u32     rx_stat_bmac_xpf_lo;
1066     u32     rx_stat_bmac_xcf_hi;
1067     u32     rx_stat_bmac_xcf_lo;
1068
1069     /* xoff_state_entered */
1070     u32     rx_stat_xoffstateentered_hi;
1071     u32     rx_stat_xoffstateentered_lo;
1072     /* pause_xon_frames_received */
1073     u32     rx_stat_xonpauseframesreceived_hi;
1074     u32     rx_stat_xonpauseframesreceived_lo;
1075     /* pause_xoff_frames_received */
1076     u32     rx_stat_xoffpauseframesreceived_hi;
1077     u32     rx_stat_xoffpauseframesreceived_lo;
1078     /* pause_xon_frames_transmitted */
1079     u32     tx_stat_outxonsent_hi;
1080     u32     tx_stat_outxonsent_lo;
1081     /* pause_xoff_frames_transmitted */
1082     u32     tx_stat_outxoffsent_hi;
1083     u32     tx_stat_outxoffsent_lo;
1084     /* flow_control_done */
1085     u32     tx_stat_flowcontroldone_hi;
1086     u32     tx_stat_flowcontroldone_lo;
1087
1088     /* ether_stats_collisions */
1089     u32     tx_stat_etherstatscollisions_hi;
1090     u32     tx_stat_etherstatscollisions_lo;
1091     /* single_collision_transmit_frames */
1092     u32     tx_stat_dot3statssinglecollisionframes_hi;
1093     u32     tx_stat_dot3statssinglecollisionframes_lo;
1094     /* multiple_collision_transmit_frames */
1095     u32     tx_stat_dot3statsmultiplecollisionframes_hi;
1096     u32     tx_stat_dot3statsmultiplecollisionframes_lo;
1097     /* deferred_transmissions */
1098     u32     tx_stat_dot3statsdeferredtransmissions_hi;
1099     u32     tx_stat_dot3statsdeferredtransmissions_lo;
1100     /* excessive_collision_frames */
1101     u32     tx_stat_dot3statsexcessivecollisions_hi;
1102     u32     tx_stat_dot3statsexcessivecollisions_lo;
1103     /* late_collision_frames */
1104     u32     tx_stat_dot3statslatecollisions_hi;
1105     u32     tx_stat_dot3statslatecollisions_lo;
1106
1107     /* frames_transmitted_64_bytes */
1108     u32     tx_stat_etherstatspkts64octets_hi;
1109     u32     tx_stat_etherstatspkts64octets_lo;
1110     /* frames_transmitted_65_127_bytes */
1111     u32     tx_stat_etherstatspkts65octetsto127octets_hi;
1112     u32     tx_stat_etherstatspkts65octetsto127octets_lo;
1113     /* frames_transmitted_128_255_bytes */
1114     u32     tx_stat_etherstatspkts128octetsto255octets_hi;
1115     u32     tx_stat_etherstatspkts128octetsto255octets_lo;
1116     /* frames_transmitted_256_511_bytes */
1117     u32     tx_stat_etherstatspkts256octetsto511octets_hi;
1118     u32     tx_stat_etherstatspkts256octetsto511octets_lo;
1119     /* frames_transmitted_512_1023_bytes */
1120     u32     tx_stat_etherstatspkts512octetsto1023octets_hi;
1121     u32     tx_stat_etherstatspkts512octetsto1023octets_lo;
1122     /* frames_transmitted_1024_1522_bytes */
1123     u32     tx_stat_etherstatspkts1024octetsto1522octets_hi;
1124     u32     tx_stat_etherstatspkts1024octetsto1522octets_lo;
1125     /* frames_transmitted_1523_9022_bytes */
1126     u32     tx_stat_etherstatspktsover1522octets_hi;
1127     u32     tx_stat_etherstatspktsover1522octets_lo;
1128     u32     tx_stat_bmac_2047_hi;
1129     u32     tx_stat_bmac_2047_lo;
1130     u32     tx_stat_bmac_4095_hi;
1131     u32     tx_stat_bmac_4095_lo;
1132     u32     tx_stat_bmac_9216_hi;
1133     u32     tx_stat_bmac_9216_lo;
1134     u32     tx_stat_bmac_16383_hi;
1135     u32     tx_stat_bmac_16383_lo;
1136
1137     /* internal_mac_transmit_errors */
1138     u32     tx_stat_dot3statsinternalmactransmiterrors_hi;
1139     u32     tx_stat_dot3statsinternalmactransmiterrors_lo;
1140
1141     /* if_out_discards */
1142     u32     tx_stat_bmac_ufl_hi;
1143     u32     tx_stat_bmac_ufl_lo;
1144 };
1145
1146
1147 #define MAC_STX_IDX_MAX                     2
1148
1149 struct host_port_stats {
1150     u32            host_port_stats_start;
1151
1152     struct mac_stx mac_stx[MAC_STX_IDX_MAX];
1153
1154     u32            brb_drop_hi;
1155     u32            brb_drop_lo;
1156
1157     u32            host_port_stats_end;
1158 };
1159
1160
1161 struct host_func_stats {
1162     u32     host_func_stats_start;
1163
1164     u32     total_bytes_received_hi;
1165     u32     total_bytes_received_lo;
1166
1167     u32     total_bytes_transmitted_hi;
1168     u32     total_bytes_transmitted_lo;
1169
1170     u32     total_unicast_packets_received_hi;
1171     u32     total_unicast_packets_received_lo;
1172
1173     u32     total_multicast_packets_received_hi;
1174     u32     total_multicast_packets_received_lo;
1175
1176     u32     total_broadcast_packets_received_hi;
1177     u32     total_broadcast_packets_received_lo;
1178
1179     u32     total_unicast_packets_transmitted_hi;
1180     u32     total_unicast_packets_transmitted_lo;
1181
1182     u32     total_multicast_packets_transmitted_hi;
1183     u32     total_multicast_packets_transmitted_lo;
1184
1185     u32     total_broadcast_packets_transmitted_hi;
1186     u32     total_broadcast_packets_transmitted_lo;
1187
1188     u32     valid_bytes_received_hi;
1189     u32     valid_bytes_received_lo;
1190
1191     u32     host_func_stats_end;
1192 };
1193
1194
1195 #define BCM_5710_FW_MAJOR_VERSION                       4
1196 #define BCM_5710_FW_MINOR_VERSION                       8
1197 #define BCM_5710_FW_REVISION_VERSION                    53
1198 #define BCM_5710_FW_ENGINEERING_VERSION                 0
1199 #define BCM_5710_FW_COMPILE_FLAGS                       1
1200
1201
1202 /*
1203  * attention bits
1204  */
1205 struct atten_def_status_block {
1206         u32 attn_bits;
1207         u32 attn_bits_ack;
1208         u8 status_block_id;
1209         u8 reserved0;
1210         u16 attn_bits_index;
1211         u32 reserved1;
1212 };
1213
1214
1215 /*
1216  * common data for all protocols
1217  */
1218 struct doorbell_hdr {
1219         u8 header;
1220 #define DOORBELL_HDR_RX (0x1<<0)
1221 #define DOORBELL_HDR_RX_SHIFT 0
1222 #define DOORBELL_HDR_DB_TYPE (0x1<<1)
1223 #define DOORBELL_HDR_DB_TYPE_SHIFT 1
1224 #define DOORBELL_HDR_DPM_SIZE (0x3<<2)
1225 #define DOORBELL_HDR_DPM_SIZE_SHIFT 2
1226 #define DOORBELL_HDR_CONN_TYPE (0xF<<4)
1227 #define DOORBELL_HDR_CONN_TYPE_SHIFT 4
1228 };
1229
1230 /*
1231  * doorbell message sent to the chip
1232  */
1233 struct doorbell {
1234 #if defined(__BIG_ENDIAN)
1235         u16 zero_fill2;
1236         u8 zero_fill1;
1237         struct doorbell_hdr header;
1238 #elif defined(__LITTLE_ENDIAN)
1239         struct doorbell_hdr header;
1240         u8 zero_fill1;
1241         u16 zero_fill2;
1242 #endif
1243 };
1244
1245
1246 /*
1247  * IGU driver acknowledgement register
1248  */
1249 struct igu_ack_register {
1250 #if defined(__BIG_ENDIAN)
1251         u16 sb_id_and_flags;
1252 #define IGU_ACK_REGISTER_STATUS_BLOCK_ID (0x1F<<0)
1253 #define IGU_ACK_REGISTER_STATUS_BLOCK_ID_SHIFT 0
1254 #define IGU_ACK_REGISTER_STORM_ID (0x7<<5)
1255 #define IGU_ACK_REGISTER_STORM_ID_SHIFT 5
1256 #define IGU_ACK_REGISTER_UPDATE_INDEX (0x1<<8)
1257 #define IGU_ACK_REGISTER_UPDATE_INDEX_SHIFT 8
1258 #define IGU_ACK_REGISTER_INTERRUPT_MODE (0x3<<9)
1259 #define IGU_ACK_REGISTER_INTERRUPT_MODE_SHIFT 9
1260 #define IGU_ACK_REGISTER_RESERVED (0x1F<<11)
1261 #define IGU_ACK_REGISTER_RESERVED_SHIFT 11
1262         u16 status_block_index;
1263 #elif defined(__LITTLE_ENDIAN)
1264         u16 status_block_index;
1265         u16 sb_id_and_flags;
1266 #define IGU_ACK_REGISTER_STATUS_BLOCK_ID (0x1F<<0)
1267 #define IGU_ACK_REGISTER_STATUS_BLOCK_ID_SHIFT 0
1268 #define IGU_ACK_REGISTER_STORM_ID (0x7<<5)
1269 #define IGU_ACK_REGISTER_STORM_ID_SHIFT 5
1270 #define IGU_ACK_REGISTER_UPDATE_INDEX (0x1<<8)
1271 #define IGU_ACK_REGISTER_UPDATE_INDEX_SHIFT 8
1272 #define IGU_ACK_REGISTER_INTERRUPT_MODE (0x3<<9)
1273 #define IGU_ACK_REGISTER_INTERRUPT_MODE_SHIFT 9
1274 #define IGU_ACK_REGISTER_RESERVED (0x1F<<11)
1275 #define IGU_ACK_REGISTER_RESERVED_SHIFT 11
1276 #endif
1277 };
1278
1279
1280 /*
1281  * Parser parsing flags field
1282  */
1283 struct parsing_flags {
1284         u16 flags;
1285 #define PARSING_FLAGS_ETHERNET_ADDRESS_TYPE (0x1<<0)
1286 #define PARSING_FLAGS_ETHERNET_ADDRESS_TYPE_SHIFT 0
1287 #define PARSING_FLAGS_VLAN (0x1<<1)
1288 #define PARSING_FLAGS_VLAN_SHIFT 1
1289 #define PARSING_FLAGS_EXTRA_VLAN (0x1<<2)
1290 #define PARSING_FLAGS_EXTRA_VLAN_SHIFT 2
1291 #define PARSING_FLAGS_OVER_ETHERNET_PROTOCOL (0x3<<3)
1292 #define PARSING_FLAGS_OVER_ETHERNET_PROTOCOL_SHIFT 3
1293 #define PARSING_FLAGS_IP_OPTIONS (0x1<<5)
1294 #define PARSING_FLAGS_IP_OPTIONS_SHIFT 5
1295 #define PARSING_FLAGS_FRAGMENTATION_STATUS (0x1<<6)
1296 #define PARSING_FLAGS_FRAGMENTATION_STATUS_SHIFT 6
1297 #define PARSING_FLAGS_OVER_IP_PROTOCOL (0x3<<7)
1298 #define PARSING_FLAGS_OVER_IP_PROTOCOL_SHIFT 7
1299 #define PARSING_FLAGS_PURE_ACK_INDICATION (0x1<<9)
1300 #define PARSING_FLAGS_PURE_ACK_INDICATION_SHIFT 9
1301 #define PARSING_FLAGS_TCP_OPTIONS_EXIST (0x1<<10)
1302 #define PARSING_FLAGS_TCP_OPTIONS_EXIST_SHIFT 10
1303 #define PARSING_FLAGS_TIME_STAMP_EXIST_FLAG (0x1<<11)
1304 #define PARSING_FLAGS_TIME_STAMP_EXIST_FLAG_SHIFT 11
1305 #define PARSING_FLAGS_CONNECTION_MATCH (0x1<<12)
1306 #define PARSING_FLAGS_CONNECTION_MATCH_SHIFT 12
1307 #define PARSING_FLAGS_LLC_SNAP (0x1<<13)
1308 #define PARSING_FLAGS_LLC_SNAP_SHIFT 13
1309 #define PARSING_FLAGS_RESERVED0 (0x3<<14)
1310 #define PARSING_FLAGS_RESERVED0_SHIFT 14
1311 };
1312
1313
1314 struct regpair {
1315         u32 lo;
1316         u32 hi;
1317 };
1318
1319
1320 /*
1321  * dmae command structure
1322  */
1323 struct dmae_command {
1324         u32 opcode;
1325 #define DMAE_COMMAND_SRC (0x1<<0)
1326 #define DMAE_COMMAND_SRC_SHIFT 0
1327 #define DMAE_COMMAND_DST (0x3<<1)
1328 #define DMAE_COMMAND_DST_SHIFT 1
1329 #define DMAE_COMMAND_C_DST (0x1<<3)
1330 #define DMAE_COMMAND_C_DST_SHIFT 3
1331 #define DMAE_COMMAND_C_TYPE_ENABLE (0x1<<4)
1332 #define DMAE_COMMAND_C_TYPE_ENABLE_SHIFT 4
1333 #define DMAE_COMMAND_C_TYPE_CRC_ENABLE (0x1<<5)
1334 #define DMAE_COMMAND_C_TYPE_CRC_ENABLE_SHIFT 5
1335 #define DMAE_COMMAND_C_TYPE_CRC_OFFSET (0x7<<6)
1336 #define DMAE_COMMAND_C_TYPE_CRC_OFFSET_SHIFT 6
1337 #define DMAE_COMMAND_ENDIANITY (0x3<<9)
1338 #define DMAE_COMMAND_ENDIANITY_SHIFT 9
1339 #define DMAE_COMMAND_PORT (0x1<<11)
1340 #define DMAE_COMMAND_PORT_SHIFT 11
1341 #define DMAE_COMMAND_CRC_RESET (0x1<<12)
1342 #define DMAE_COMMAND_CRC_RESET_SHIFT 12
1343 #define DMAE_COMMAND_SRC_RESET (0x1<<13)
1344 #define DMAE_COMMAND_SRC_RESET_SHIFT 13
1345 #define DMAE_COMMAND_DST_RESET (0x1<<14)
1346 #define DMAE_COMMAND_DST_RESET_SHIFT 14
1347 #define DMAE_COMMAND_E1HVN (0x3<<15)
1348 #define DMAE_COMMAND_E1HVN_SHIFT 15
1349 #define DMAE_COMMAND_RESERVED0 (0x7FFF<<17)
1350 #define DMAE_COMMAND_RESERVED0_SHIFT 17
1351         u32 src_addr_lo;
1352         u32 src_addr_hi;
1353         u32 dst_addr_lo;
1354         u32 dst_addr_hi;
1355 #if defined(__BIG_ENDIAN)
1356         u16 reserved1;
1357         u16 len;
1358 #elif defined(__LITTLE_ENDIAN)
1359         u16 len;
1360         u16 reserved1;
1361 #endif
1362         u32 comp_addr_lo;
1363         u32 comp_addr_hi;
1364         u32 comp_val;
1365         u32 crc32;
1366         u32 crc32_c;
1367 #if defined(__BIG_ENDIAN)
1368         u16 crc16_c;
1369         u16 crc16;
1370 #elif defined(__LITTLE_ENDIAN)
1371         u16 crc16;
1372         u16 crc16_c;
1373 #endif
1374 #if defined(__BIG_ENDIAN)
1375         u16 reserved2;
1376         u16 crc_t10;
1377 #elif defined(__LITTLE_ENDIAN)
1378         u16 crc_t10;
1379         u16 reserved2;
1380 #endif
1381 #if defined(__BIG_ENDIAN)
1382         u16 xsum8;
1383         u16 xsum16;
1384 #elif defined(__LITTLE_ENDIAN)
1385         u16 xsum16;
1386         u16 xsum8;
1387 #endif
1388 };
1389
1390
1391 struct double_regpair {
1392         u32 regpair0_lo;
1393         u32 regpair0_hi;
1394         u32 regpair1_lo;
1395         u32 regpair1_hi;
1396 };
1397
1398
1399 /*
1400  * The eth storm context of Ustorm (configuration part)
1401  */
1402 struct ustorm_eth_st_context_config {
1403 #if defined(__BIG_ENDIAN)
1404         u8 flags;
1405 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_MC_ALIGNMENT (0x1<<0)
1406 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_MC_ALIGNMENT_SHIFT 0
1407 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_DYNAMIC_HC (0x1<<1)
1408 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_DYNAMIC_HC_SHIFT 1
1409 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_TPA (0x1<<2)
1410 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_TPA_SHIFT 2
1411 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_SGE_RING (0x1<<3)
1412 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_SGE_RING_SHIFT 3
1413 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_STATISTICS (0x1<<4)
1414 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_STATISTICS_SHIFT 4
1415 #define __USTORM_ETH_ST_CONTEXT_CONFIG_RESERVED0 (0x7<<5)
1416 #define __USTORM_ETH_ST_CONTEXT_CONFIG_RESERVED0_SHIFT 5
1417         u8 status_block_id;
1418         u8 clientId;
1419         u8 sb_index_numbers;
1420 #define USTORM_ETH_ST_CONTEXT_CONFIG_CQE_SB_INDEX_NUMBER (0xF<<0)
1421 #define USTORM_ETH_ST_CONTEXT_CONFIG_CQE_SB_INDEX_NUMBER_SHIFT 0
1422 #define USTORM_ETH_ST_CONTEXT_CONFIG_BD_SB_INDEX_NUMBER (0xF<<4)
1423 #define USTORM_ETH_ST_CONTEXT_CONFIG_BD_SB_INDEX_NUMBER_SHIFT 4
1424 #elif defined(__LITTLE_ENDIAN)
1425         u8 sb_index_numbers;
1426 #define USTORM_ETH_ST_CONTEXT_CONFIG_CQE_SB_INDEX_NUMBER (0xF<<0)
1427 #define USTORM_ETH_ST_CONTEXT_CONFIG_CQE_SB_INDEX_NUMBER_SHIFT 0
1428 #define USTORM_ETH_ST_CONTEXT_CONFIG_BD_SB_INDEX_NUMBER (0xF<<4)
1429 #define USTORM_ETH_ST_CONTEXT_CONFIG_BD_SB_INDEX_NUMBER_SHIFT 4
1430         u8 clientId;
1431         u8 status_block_id;
1432         u8 flags;
1433 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_MC_ALIGNMENT (0x1<<0)
1434 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_MC_ALIGNMENT_SHIFT 0
1435 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_DYNAMIC_HC (0x1<<1)
1436 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_DYNAMIC_HC_SHIFT 1
1437 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_TPA (0x1<<2)
1438 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_TPA_SHIFT 2
1439 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_SGE_RING (0x1<<3)
1440 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_SGE_RING_SHIFT 3
1441 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_STATISTICS (0x1<<4)
1442 #define USTORM_ETH_ST_CONTEXT_CONFIG_ENABLE_STATISTICS_SHIFT 4
1443 #define __USTORM_ETH_ST_CONTEXT_CONFIG_RESERVED0 (0x7<<5)
1444 #define __USTORM_ETH_ST_CONTEXT_CONFIG_RESERVED0_SHIFT 5
1445 #endif
1446 #if defined(__BIG_ENDIAN)
1447         u16 bd_buff_size;
1448         u8 statistics_counter_id;
1449         u8 mc_alignment_log_size;
1450 #elif defined(__LITTLE_ENDIAN)
1451         u8 mc_alignment_log_size;
1452         u8 statistics_counter_id;
1453         u16 bd_buff_size;
1454 #endif
1455 #if defined(__BIG_ENDIAN)
1456         u8 __local_sge_prod;
1457         u8 __local_bd_prod;
1458         u16 sge_buff_size;
1459 #elif defined(__LITTLE_ENDIAN)
1460         u16 sge_buff_size;
1461         u8 __local_bd_prod;
1462         u8 __local_sge_prod;
1463 #endif
1464         u32 reserved;
1465         u32 bd_page_base_lo;
1466         u32 bd_page_base_hi;
1467         u32 sge_page_base_lo;
1468         u32 sge_page_base_hi;
1469 };
1470
1471 /*
1472  * The eth Rx Buffer Descriptor
1473  */
1474 struct eth_rx_bd {
1475         u32 addr_lo;
1476         u32 addr_hi;
1477 };
1478
1479 /*
1480  * The eth Rx SGE Descriptor
1481  */
1482 struct eth_rx_sge {
1483         u32 addr_lo;
1484         u32 addr_hi;
1485 };
1486
1487 /*
1488  * Local BDs and SGEs rings (in ETH)
1489  */
1490 struct eth_local_rx_rings {
1491         struct eth_rx_bd __local_bd_ring[16];
1492         struct eth_rx_sge __local_sge_ring[12];
1493 };
1494
1495 /*
1496  * The eth storm context of Ustorm
1497  */
1498 struct ustorm_eth_st_context {
1499         struct ustorm_eth_st_context_config common;
1500         struct eth_local_rx_rings __rings;
1501 };
1502
1503 /*
1504  * The eth storm context of Tstorm
1505  */
1506 struct tstorm_eth_st_context {
1507         u32 __reserved0[28];
1508 };
1509
1510 /*
1511  * The eth aggregative context section of Xstorm
1512  */
1513 struct xstorm_eth_extra_ag_context_section {
1514 #if defined(__BIG_ENDIAN)
1515         u8 __tcp_agg_vars1;
1516         u8 __reserved50;
1517         u16 __mss;
1518 #elif defined(__LITTLE_ENDIAN)
1519         u16 __mss;
1520         u8 __reserved50;
1521         u8 __tcp_agg_vars1;
1522 #endif
1523         u32 __snd_nxt;
1524         u32 __tx_wnd;
1525         u32 __snd_una;
1526         u32 __reserved53;
1527 #if defined(__BIG_ENDIAN)
1528         u8 __agg_val8_th;
1529         u8 __agg_val8;
1530         u16 __tcp_agg_vars2;
1531 #elif defined(__LITTLE_ENDIAN)
1532         u16 __tcp_agg_vars2;
1533         u8 __agg_val8;
1534         u8 __agg_val8_th;
1535 #endif
1536         u32 __reserved58;
1537         u32 __reserved59;
1538         u32 __reserved60;
1539         u32 __reserved61;
1540 #if defined(__BIG_ENDIAN)
1541         u16 __agg_val7_th;
1542         u16 __agg_val7;
1543 #elif defined(__LITTLE_ENDIAN)
1544         u16 __agg_val7;
1545         u16 __agg_val7_th;
1546 #endif
1547 #if defined(__BIG_ENDIAN)
1548         u8 __tcp_agg_vars5;
1549         u8 __tcp_agg_vars4;
1550         u8 __tcp_agg_vars3;
1551         u8 __reserved62;
1552 #elif defined(__LITTLE_ENDIAN)
1553         u8 __reserved62;
1554         u8 __tcp_agg_vars3;
1555         u8 __tcp_agg_vars4;
1556         u8 __tcp_agg_vars5;
1557 #endif
1558         u32 __tcp_agg_vars6;
1559 #if defined(__BIG_ENDIAN)
1560         u16 __agg_misc6;
1561         u16 __tcp_agg_vars7;
1562 #elif defined(__LITTLE_ENDIAN)
1563         u16 __tcp_agg_vars7;
1564         u16 __agg_misc6;
1565 #endif
1566         u32 __agg_val10;
1567         u32 __agg_val10_th;
1568 #if defined(__BIG_ENDIAN)
1569         u16 __reserved3;
1570         u8 __reserved2;
1571         u8 __da_only_cnt;
1572 #elif defined(__LITTLE_ENDIAN)
1573         u8 __da_only_cnt;
1574         u8 __reserved2;
1575         u16 __reserved3;
1576 #endif
1577 };
1578
1579 /*
1580  * The eth aggregative context of Xstorm
1581  */
1582 struct xstorm_eth_ag_context {
1583 #if defined(__BIG_ENDIAN)
1584         u16 __bd_prod;
1585         u8 __agg_vars1;
1586         u8 __state;
1587 #elif defined(__LITTLE_ENDIAN)
1588         u8 __state;
1589         u8 __agg_vars1;
1590         u16 __bd_prod;
1591 #endif
1592 #if defined(__BIG_ENDIAN)
1593         u8 cdu_reserved;
1594         u8 __agg_vars4;
1595         u8 __agg_vars3;
1596         u8 __agg_vars2;
1597 #elif defined(__LITTLE_ENDIAN)
1598         u8 __agg_vars2;
1599         u8 __agg_vars3;
1600         u8 __agg_vars4;
1601         u8 cdu_reserved;
1602 #endif
1603         u32 __more_packets_to_send;
1604 #if defined(__BIG_ENDIAN)
1605         u16 __agg_vars5;
1606         u16 __agg_val4_th;
1607 #elif defined(__LITTLE_ENDIAN)
1608         u16 __agg_val4_th;
1609         u16 __agg_vars5;
1610 #endif
1611         struct xstorm_eth_extra_ag_context_section __extra_section;
1612 #if defined(__BIG_ENDIAN)
1613         u16 __agg_vars7;
1614         u8 __agg_val3_th;
1615         u8 __agg_vars6;
1616 #elif defined(__LITTLE_ENDIAN)
1617         u8 __agg_vars6;
1618         u8 __agg_val3_th;
1619         u16 __agg_vars7;
1620 #endif
1621 #if defined(__BIG_ENDIAN)
1622         u16 __agg_val11_th;
1623         u16 __agg_val11;
1624 #elif defined(__LITTLE_ENDIAN)
1625         u16 __agg_val11;
1626         u16 __agg_val11_th;
1627 #endif
1628 #if defined(__BIG_ENDIAN)
1629         u8 __reserved1;
1630         u8 __agg_val6_th;
1631         u16 __agg_val9;
1632 #elif defined(__LITTLE_ENDIAN)
1633         u16 __agg_val9;
1634         u8 __agg_val6_th;
1635         u8 __reserved1;
1636 #endif
1637 #if defined(__BIG_ENDIAN)
1638         u16 __agg_val2_th;
1639         u16 __agg_val2;
1640 #elif defined(__LITTLE_ENDIAN)
1641         u16 __agg_val2;
1642         u16 __agg_val2_th;
1643 #endif
1644         u32 __agg_vars8;
1645 #if defined(__BIG_ENDIAN)
1646         u16 __agg_misc0;
1647         u16 __agg_val4;
1648 #elif defined(__LITTLE_ENDIAN)
1649         u16 __agg_val4;
1650         u16 __agg_misc0;
1651 #endif
1652 #if defined(__BIG_ENDIAN)
1653         u8 __agg_val3;
1654         u8 __agg_val6;
1655         u8 __agg_val5_th;
1656         u8 __agg_val5;
1657 #elif defined(__LITTLE_ENDIAN)
1658         u8 __agg_val5;
1659         u8 __agg_val5_th;
1660         u8 __agg_val6;
1661         u8 __agg_val3;
1662 #endif
1663 #if defined(__BIG_ENDIAN)
1664         u16 __agg_misc1;
1665         u16 __bd_ind_max_val;
1666 #elif defined(__LITTLE_ENDIAN)
1667         u16 __bd_ind_max_val;
1668         u16 __agg_misc1;
1669 #endif
1670         u32 __reserved57;
1671         u32 __agg_misc4;
1672         u32 __agg_misc5;
1673 };
1674
1675 /*
1676  * The eth aggregative context section of Tstorm
1677  */
1678 struct tstorm_eth_extra_ag_context_section {
1679         u32 __agg_val1;
1680 #if defined(__BIG_ENDIAN)
1681         u8 __tcp_agg_vars2;
1682         u8 __agg_val3;
1683         u16 __agg_val2;
1684 #elif defined(__LITTLE_ENDIAN)
1685         u16 __agg_val2;
1686         u8 __agg_val3;
1687         u8 __tcp_agg_vars2;
1688 #endif
1689 #if defined(__BIG_ENDIAN)
1690         u16 __agg_val5;
1691         u8 __agg_val6;
1692         u8 __tcp_agg_vars3;
1693 #elif defined(__LITTLE_ENDIAN)
1694         u8 __tcp_agg_vars3;
1695         u8 __agg_val6;
1696         u16 __agg_val5;
1697 #endif
1698         u32 __reserved63;
1699         u32 __reserved64;
1700         u32 __reserved65;
1701         u32 __reserved66;
1702         u32 __reserved67;
1703         u32 __tcp_agg_vars1;
1704         u32 __reserved61;
1705         u32 __reserved62;
1706         u32 __reserved2;
1707 };
1708
1709 /*
1710  * The eth aggregative context of Tstorm
1711  */
1712 struct tstorm_eth_ag_context {
1713 #if defined(__BIG_ENDIAN)
1714         u16 __reserved54;
1715         u8 __agg_vars1;
1716         u8 __state;
1717 #elif defined(__LITTLE_ENDIAN)
1718         u8 __state;
1719         u8 __agg_vars1;
1720         u16 __reserved54;
1721 #endif
1722 #if defined(__BIG_ENDIAN)
1723         u16 __agg_val4;
1724         u16 __agg_vars2;
1725 #elif defined(__LITTLE_ENDIAN)
1726         u16 __agg_vars2;
1727         u16 __agg_val4;
1728 #endif
1729         struct tstorm_eth_extra_ag_context_section __extra_section;
1730 };
1731
1732 /*
1733  * The eth aggregative context of Cstorm
1734  */
1735 struct cstorm_eth_ag_context {
1736         u32 __agg_vars1;
1737 #if defined(__BIG_ENDIAN)
1738         u8 __aux1_th;
1739         u8 __aux1_val;
1740         u16 __agg_vars2;
1741 #elif defined(__LITTLE_ENDIAN)
1742         u16 __agg_vars2;
1743         u8 __aux1_val;
1744         u8 __aux1_th;
1745 #endif
1746         u32 __num_of_treated_packet;
1747         u32 __last_packet_treated;
1748 #if defined(__BIG_ENDIAN)
1749         u16 __reserved58;
1750         u16 __reserved57;
1751 #elif defined(__LITTLE_ENDIAN)
1752         u16 __reserved57;
1753         u16 __reserved58;
1754 #endif
1755 #if defined(__BIG_ENDIAN)
1756         u8 __reserved62;
1757         u8 __reserved61;
1758         u8 __reserved60;
1759         u8 __reserved59;
1760 #elif defined(__LITTLE_ENDIAN)
1761         u8 __reserved59;
1762         u8 __reserved60;
1763         u8 __reserved61;
1764         u8 __reserved62;
1765 #endif
1766 #if defined(__BIG_ENDIAN)
1767         u16 __reserved64;
1768         u16 __reserved63;
1769 #elif defined(__LITTLE_ENDIAN)
1770         u16 __reserved63;
1771         u16 __reserved64;
1772 #endif
1773         u32 __reserved65;
1774 #if defined(__BIG_ENDIAN)
1775         u16 __agg_vars3;
1776         u16 __rq_inv_cnt;
1777 #elif defined(__LITTLE_ENDIAN)
1778         u16 __rq_inv_cnt;
1779         u16 __agg_vars3;
1780 #endif
1781 #if defined(__BIG_ENDIAN)
1782         u16 __packet_index_th;
1783         u16 __packet_index;
1784 #elif defined(__LITTLE_ENDIAN)
1785         u16 __packet_index;
1786         u16 __packet_index_th;
1787 #endif
1788 };
1789
1790 /*
1791  * The eth aggregative context of Ustorm
1792  */
1793 struct ustorm_eth_ag_context {
1794 #if defined(__BIG_ENDIAN)
1795         u8 __aux_counter_flags;
1796         u8 __agg_vars2;
1797         u8 __agg_vars1;
1798         u8 __state;
1799 #elif defined(__LITTLE_ENDIAN)
1800         u8 __state;
1801         u8 __agg_vars1;
1802         u8 __agg_vars2;
1803         u8 __aux_counter_flags;
1804 #endif
1805 #if defined(__BIG_ENDIAN)
1806         u8 cdu_usage;
1807         u8 __agg_misc2;
1808         u16 __agg_misc1;
1809 #elif defined(__LITTLE_ENDIAN)
1810         u16 __agg_misc1;
1811         u8 __agg_misc2;
1812         u8 cdu_usage;
1813 #endif
1814         u32 __agg_misc4;
1815 #if defined(__BIG_ENDIAN)
1816         u8 __agg_val3_th;
1817         u8 __agg_val3;
1818         u16 __agg_misc3;
1819 #elif defined(__LITTLE_ENDIAN)
1820         u16 __agg_misc3;
1821         u8 __agg_val3;
1822         u8 __agg_val3_th;
1823 #endif
1824         u32 __agg_val1;
1825         u32 __agg_misc4_th;
1826 #if defined(__BIG_ENDIAN)
1827         u16 __agg_val2_th;
1828         u16 __agg_val2;
1829 #elif defined(__LITTLE_ENDIAN)
1830         u16 __agg_val2;
1831         u16 __agg_val2_th;
1832 #endif
1833 #if defined(__BIG_ENDIAN)
1834         u16 __reserved2;
1835         u8 __decision_rules;
1836         u8 __decision_rule_enable_bits;
1837 #elif defined(__LITTLE_ENDIAN)
1838         u8 __decision_rule_enable_bits;
1839         u8 __decision_rules;
1840         u16 __reserved2;
1841 #endif
1842 };
1843
1844 /*
1845  * Timers connection context
1846  */
1847 struct timers_block_context {
1848         u32 __reserved_0;
1849         u32 __reserved_1;
1850         u32 __reserved_2;
1851         u32 flags;
1852 #define __TIMERS_BLOCK_CONTEXT_NUM_OF_ACTIVE_TIMERS (0x3<<0)
1853 #define __TIMERS_BLOCK_CONTEXT_NUM_OF_ACTIVE_TIMERS_SHIFT 0
1854 #define TIMERS_BLOCK_CONTEXT_CONN_VALID_FLG (0x1<<2)
1855 #define TIMERS_BLOCK_CONTEXT_CONN_VALID_FLG_SHIFT 2
1856 #define __TIMERS_BLOCK_CONTEXT_RESERVED0 (0x1FFFFFFF<<3)
1857 #define __TIMERS_BLOCK_CONTEXT_RESERVED0_SHIFT 3
1858 };
1859
1860 /*
1861  * structure for easy accessibility to assembler
1862  */
1863 struct eth_tx_bd_flags {
1864         u8 as_bitfield;
1865 #define ETH_TX_BD_FLAGS_VLAN_TAG (0x1<<0)
1866 #define ETH_TX_BD_FLAGS_VLAN_TAG_SHIFT 0
1867 #define ETH_TX_BD_FLAGS_IP_CSUM (0x1<<1)
1868 #define ETH_TX_BD_FLAGS_IP_CSUM_SHIFT 1
1869 #define ETH_TX_BD_FLAGS_TCP_CSUM (0x1<<2)
1870 #define ETH_TX_BD_FLAGS_TCP_CSUM_SHIFT 2
1871 #define ETH_TX_BD_FLAGS_END_BD (0x1<<3)
1872 #define ETH_TX_BD_FLAGS_END_BD_SHIFT 3
1873 #define ETH_TX_BD_FLAGS_START_BD (0x1<<4)
1874 #define ETH_TX_BD_FLAGS_START_BD_SHIFT 4
1875 #define ETH_TX_BD_FLAGS_HDR_POOL (0x1<<5)
1876 #define ETH_TX_BD_FLAGS_HDR_POOL_SHIFT 5
1877 #define ETH_TX_BD_FLAGS_SW_LSO (0x1<<6)
1878 #define ETH_TX_BD_FLAGS_SW_LSO_SHIFT 6
1879 #define ETH_TX_BD_FLAGS_IPV6 (0x1<<7)
1880 #define ETH_TX_BD_FLAGS_IPV6_SHIFT 7
1881 };
1882
1883 /*
1884  * The eth Tx Buffer Descriptor
1885  */
1886 struct eth_tx_bd {
1887         u32 addr_lo;
1888         u32 addr_hi;
1889         u16 nbd;
1890         u16 nbytes;
1891         u16 vlan;
1892         struct eth_tx_bd_flags bd_flags;
1893         u8 general_data;
1894 #define ETH_TX_BD_HDR_NBDS (0x3F<<0)
1895 #define ETH_TX_BD_HDR_NBDS_SHIFT 0
1896 #define ETH_TX_BD_ETH_ADDR_TYPE (0x3<<6)
1897 #define ETH_TX_BD_ETH_ADDR_TYPE_SHIFT 6
1898 };
1899
1900 /*
1901  * Tx parsing BD structure for ETH,Relevant in START
1902  */
1903 struct eth_tx_parse_bd {
1904         u8 global_data;
1905 #define ETH_TX_PARSE_BD_IP_HDR_START_OFFSET (0xF<<0)
1906 #define ETH_TX_PARSE_BD_IP_HDR_START_OFFSET_SHIFT 0
1907 #define ETH_TX_PARSE_BD_CS_ANY_FLG (0x1<<4)
1908 #define ETH_TX_PARSE_BD_CS_ANY_FLG_SHIFT 4
1909 #define ETH_TX_PARSE_BD_PSEUDO_CS_WITHOUT_LEN (0x1<<5)
1910 #define ETH_TX_PARSE_BD_PSEUDO_CS_WITHOUT_LEN_SHIFT 5
1911 #define ETH_TX_PARSE_BD_LLC_SNAP_EN (0x1<<6)
1912 #define ETH_TX_PARSE_BD_LLC_SNAP_EN_SHIFT 6
1913 #define ETH_TX_PARSE_BD_NS_FLG (0x1<<7)
1914 #define ETH_TX_PARSE_BD_NS_FLG_SHIFT 7
1915         u8 tcp_flags;
1916 #define ETH_TX_PARSE_BD_FIN_FLG (0x1<<0)
1917 #define ETH_TX_PARSE_BD_FIN_FLG_SHIFT 0
1918 #define ETH_TX_PARSE_BD_SYN_FLG (0x1<<1)
1919 #define ETH_TX_PARSE_BD_SYN_FLG_SHIFT 1
1920 #define ETH_TX_PARSE_BD_RST_FLG (0x1<<2)
1921 #define ETH_TX_PARSE_BD_RST_FLG_SHIFT 2
1922 #define ETH_TX_PARSE_BD_PSH_FLG (0x1<<3)
1923 #define ETH_TX_PARSE_BD_PSH_FLG_SHIFT 3
1924 #define ETH_TX_PARSE_BD_ACK_FLG (0x1<<4)
1925 #define ETH_TX_PARSE_BD_ACK_FLG_SHIFT 4
1926 #define ETH_TX_PARSE_BD_URG_FLG (0x1<<5)
1927 #define ETH_TX_PARSE_BD_URG_FLG_SHIFT 5
1928 #define ETH_TX_PARSE_BD_ECE_FLG (0x1<<6)
1929 #define ETH_TX_PARSE_BD_ECE_FLG_SHIFT 6
1930 #define ETH_TX_PARSE_BD_CWR_FLG (0x1<<7)
1931 #define ETH_TX_PARSE_BD_CWR_FLG_SHIFT 7
1932         u8 ip_hlen;
1933         s8 cs_offset;
1934         u16 total_hlen;
1935         u16 lso_mss;
1936         u16 tcp_pseudo_csum;
1937         u16 ip_id;
1938         u32 tcp_send_seq;
1939 };
1940
1941 /*
1942  * The last BD in the BD memory will hold a pointer to the next BD memory
1943  */
1944 struct eth_tx_next_bd {
1945         u32 addr_lo;
1946         u32 addr_hi;
1947         u8 reserved[8];
1948 };
1949
1950 /*
1951  * union for 3 Bd types
1952  */
1953 union eth_tx_bd_types {
1954         struct eth_tx_bd reg_bd;
1955         struct eth_tx_parse_bd parse_bd;
1956         struct eth_tx_next_bd next_bd;
1957 };
1958
1959 /*
1960  * The eth storm context of Xstorm
1961  */
1962 struct xstorm_eth_st_context {
1963         u32 tx_bd_page_base_lo;
1964         u32 tx_bd_page_base_hi;
1965 #if defined(__BIG_ENDIAN)
1966         u16 tx_bd_cons;
1967         u8 statistics_data;
1968 #define XSTORM_ETH_ST_CONTEXT_STATISTICS_COUNTER_ID (0x7F<<0)
1969 #define XSTORM_ETH_ST_CONTEXT_STATISTICS_COUNTER_ID_SHIFT 0
1970 #define XSTORM_ETH_ST_CONTEXT_STATISTICS_ENABLE (0x1<<7)
1971 #define XSTORM_ETH_ST_CONTEXT_STATISTICS_ENABLE_SHIFT 7
1972         u8 __local_tx_bd_prod;
1973 #elif defined(__LITTLE_ENDIAN)
1974         u8 __local_tx_bd_prod;
1975         u8 statistics_data;
1976 #define XSTORM_ETH_ST_CONTEXT_STATISTICS_COUNTER_ID (0x7F<<0)
1977 #define XSTORM_ETH_ST_CONTEXT_STATISTICS_COUNTER_ID_SHIFT 0
1978 #define XSTORM_ETH_ST_CONTEXT_STATISTICS_ENABLE (0x1<<7)
1979 #define XSTORM_ETH_ST_CONTEXT_STATISTICS_ENABLE_SHIFT 7
1980         u16 tx_bd_cons;
1981 #endif
1982         u32 db_data_addr_lo;
1983         u32 db_data_addr_hi;
1984         u32 __pkt_cons;
1985         u32 __gso_next;
1986         u32 is_eth_conn_1b;
1987         union eth_tx_bd_types __bds[13];
1988 };
1989
1990 /*
1991  * The eth storm context of Cstorm
1992  */
1993 struct cstorm_eth_st_context {
1994 #if defined(__BIG_ENDIAN)
1995         u16 __reserved0;
1996         u8 sb_index_number;
1997         u8 status_block_id;
1998 #elif defined(__LITTLE_ENDIAN)
1999         u8 status_block_id;
2000         u8 sb_index_number;
2001         u16 __reserved0;
2002 #endif
2003         u32 __reserved1[3];
2004 };
2005
2006 /*
2007  * Ethernet connection context
2008  */
2009 struct eth_context {
2010         struct ustorm_eth_st_context ustorm_st_context;
2011         struct tstorm_eth_st_context tstorm_st_context;
2012         struct xstorm_eth_ag_context xstorm_ag_context;
2013         struct tstorm_eth_ag_context tstorm_ag_context;
2014         struct cstorm_eth_ag_context cstorm_ag_context;
2015         struct ustorm_eth_ag_context ustorm_ag_context;
2016         struct timers_block_context timers_context;
2017         struct xstorm_eth_st_context xstorm_st_context;
2018         struct cstorm_eth_st_context cstorm_st_context;
2019 };
2020
2021
2022 /*
2023  * Ethernet doorbell
2024  */
2025 struct eth_tx_doorbell {
2026 #if defined(__BIG_ENDIAN)
2027         u16 npackets;
2028         u8 params;
2029 #define ETH_TX_DOORBELL_NUM_BDS (0x3F<<0)
2030 #define ETH_TX_DOORBELL_NUM_BDS_SHIFT 0
2031 #define ETH_TX_DOORBELL_RESERVED_TX_FIN_FLAG (0x1<<6)
2032 #define ETH_TX_DOORBELL_RESERVED_TX_FIN_FLAG_SHIFT 6
2033 #define ETH_TX_DOORBELL_SPARE (0x1<<7)
2034 #define ETH_TX_DOORBELL_SPARE_SHIFT 7
2035         struct doorbell_hdr hdr;
2036 #elif defined(__LITTLE_ENDIAN)
2037         struct doorbell_hdr hdr;
2038         u8 params;
2039 #define ETH_TX_DOORBELL_NUM_BDS (0x3F<<0)
2040 #define ETH_TX_DOORBELL_NUM_BDS_SHIFT 0
2041 #define ETH_TX_DOORBELL_RESERVED_TX_FIN_FLAG (0x1<<6)
2042 #define ETH_TX_DOORBELL_RESERVED_TX_FIN_FLAG_SHIFT 6
2043 #define ETH_TX_DOORBELL_SPARE (0x1<<7)
2044 #define ETH_TX_DOORBELL_SPARE_SHIFT 7
2045         u16 npackets;
2046 #endif
2047 };
2048
2049
2050 /*
2051  * ustorm status block
2052  */
2053 struct ustorm_def_status_block {
2054         u16 index_values[HC_USTORM_DEF_SB_NUM_INDICES];
2055         u16 status_block_index;
2056         u8 func;
2057         u8 status_block_id;
2058         u32 __flags;
2059 };
2060
2061 /*
2062  * cstorm status block
2063  */
2064 struct cstorm_def_status_block {
2065         u16 index_values[HC_CSTORM_DEF_SB_NUM_INDICES];
2066         u16 status_block_index;
2067         u8 func;
2068         u8 status_block_id;
2069         u32 __flags;
2070 };
2071
2072 /*
2073  * xstorm status block
2074  */
2075 struct xstorm_def_status_block {
2076         u16 index_values[HC_XSTORM_DEF_SB_NUM_INDICES];
2077         u16 status_block_index;
2078         u8 func;
2079         u8 status_block_id;
2080         u32 __flags;
2081 };
2082
2083 /*
2084  * tstorm status block
2085  */
2086 struct tstorm_def_status_block {
2087         u16 index_values[HC_TSTORM_DEF_SB_NUM_INDICES];
2088         u16 status_block_index;
2089         u8 func;
2090         u8 status_block_id;
2091         u32 __flags;
2092 };
2093
2094 /*
2095  * host status block
2096  */
2097 struct host_def_status_block {
2098         struct atten_def_status_block atten_status_block;
2099         struct ustorm_def_status_block u_def_status_block;
2100         struct cstorm_def_status_block c_def_status_block;
2101         struct xstorm_def_status_block x_def_status_block;
2102         struct tstorm_def_status_block t_def_status_block;
2103 };
2104
2105
2106 /*
2107  * ustorm status block
2108  */
2109 struct ustorm_status_block {
2110         u16 index_values[HC_USTORM_SB_NUM_INDICES];
2111         u16 status_block_index;
2112         u8 func;
2113         u8 status_block_id;
2114         u32 __flags;
2115 };
2116
2117 /*
2118  * cstorm status block
2119  */
2120 struct cstorm_status_block {
2121         u16 index_values[HC_CSTORM_SB_NUM_INDICES];
2122         u16 status_block_index;
2123         u8 func;
2124         u8 status_block_id;
2125         u32 __flags;
2126 };
2127
2128 /*
2129  * host status block
2130  */
2131 struct host_status_block {
2132         struct ustorm_status_block u_status_block;
2133         struct cstorm_status_block c_status_block;
2134 };
2135
2136
2137 /*
2138  * The data for RSS setup ramrod
2139  */
2140 struct eth_client_setup_ramrod_data {
2141         u32 client_id;
2142         u8 is_rdma;
2143         u8 is_fcoe;
2144         u16 reserved1;
2145 };
2146
2147
2148 /*
2149  * L2 dynamic host coalescing init parameters
2150  */
2151 struct eth_dynamic_hc_config {
2152         u32 threshold[3];
2153         u8 hc_timeout[4];
2154 };
2155
2156
2157 /*
2158  * regular eth FP CQE parameters struct
2159  */
2160 struct eth_fast_path_rx_cqe {
2161         u8 type_error_flags;
2162 #define ETH_FAST_PATH_RX_CQE_TYPE (0x1<<0)
2163 #define ETH_FAST_PATH_RX_CQE_TYPE_SHIFT 0
2164 #define ETH_FAST_PATH_RX_CQE_PHY_DECODE_ERR_FLG (0x1<<1)
2165 #define ETH_FAST_PATH_RX_CQE_PHY_DECODE_ERR_FLG_SHIFT 1
2166 #define ETH_FAST_PATH_RX_CQE_IP_BAD_XSUM_FLG (0x1<<2)
2167 #define ETH_FAST_PATH_RX_CQE_IP_BAD_XSUM_FLG_SHIFT 2
2168 #define ETH_FAST_PATH_RX_CQE_L4_BAD_XSUM_FLG (0x1<<3)
2169 #define ETH_FAST_PATH_RX_CQE_L4_BAD_XSUM_FLG_SHIFT 3
2170 #define ETH_FAST_PATH_RX_CQE_START_FLG (0x1<<4)
2171 #define ETH_FAST_PATH_RX_CQE_START_FLG_SHIFT 4
2172 #define ETH_FAST_PATH_RX_CQE_END_FLG (0x1<<5)
2173 #define ETH_FAST_PATH_RX_CQE_END_FLG_SHIFT 5
2174 #define ETH_FAST_PATH_RX_CQE_RESERVED0 (0x3<<6)
2175 #define ETH_FAST_PATH_RX_CQE_RESERVED0_SHIFT 6
2176         u8 status_flags;
2177 #define ETH_FAST_PATH_RX_CQE_RSS_HASH_TYPE (0x7<<0)
2178 #define ETH_FAST_PATH_RX_CQE_RSS_HASH_TYPE_SHIFT 0
2179 #define ETH_FAST_PATH_RX_CQE_RSS_HASH_FLG (0x1<<3)
2180 #define ETH_FAST_PATH_RX_CQE_RSS_HASH_FLG_SHIFT 3
2181 #define ETH_FAST_PATH_RX_CQE_BROADCAST_FLG (0x1<<4)
2182 #define ETH_FAST_PATH_RX_CQE_BROADCAST_FLG_SHIFT 4
2183 #define ETH_FAST_PATH_RX_CQE_MAC_MATCH_FLG (0x1<<5)
2184 #define ETH_FAST_PATH_RX_CQE_MAC_MATCH_FLG_SHIFT 5
2185 #define ETH_FAST_PATH_RX_CQE_IP_XSUM_NO_VALIDATION_FLG (0x1<<6)
2186 #define ETH_FAST_PATH_RX_CQE_IP_XSUM_NO_VALIDATION_FLG_SHIFT 6
2187 #define ETH_FAST_PATH_RX_CQE_L4_XSUM_NO_VALIDATION_FLG (0x1<<7)
2188 #define ETH_FAST_PATH_RX_CQE_L4_XSUM_NO_VALIDATION_FLG_SHIFT 7
2189         u8 placement_offset;
2190         u8 queue_index;
2191         u32 rss_hash_result;
2192         u16 vlan_tag;
2193         u16 pkt_len;
2194         u16 len_on_bd;
2195         struct parsing_flags pars_flags;
2196         u16 sgl[8];
2197 };
2198
2199
2200 /*
2201  * The data for RSS setup ramrod
2202  */
2203 struct eth_halt_ramrod_data {
2204         u32 client_id;
2205         u32 reserved0;
2206 };
2207
2208
2209 /*
2210  * The data for statistics query ramrod
2211  */
2212 struct eth_query_ramrod_data {
2213 #if defined(__BIG_ENDIAN)
2214         u8 reserved0;
2215         u8 collect_port;
2216         u16 drv_counter;
2217 #elif defined(__LITTLE_ENDIAN)
2218         u16 drv_counter;
2219         u8 collect_port;
2220         u8 reserved0;
2221 #endif
2222         u32 ctr_id_vector;
2223 };
2224
2225
2226 /*
2227  * Place holder for ramrods protocol specific data
2228  */
2229 struct ramrod_data {
2230         u32 data_lo;
2231         u32 data_hi;
2232 };
2233
2234 /*
2235  * union for ramrod data for Ethernet protocol (CQE) (force size of 16 bits)
2236  */
2237 union eth_ramrod_data {
2238         struct ramrod_data general;
2239 };
2240
2241
2242 /*
2243  * Rx Last BD in page (in ETH)
2244  */
2245 struct eth_rx_bd_next_page {
2246         u32 addr_lo;
2247         u32 addr_hi;
2248         u8 reserved[8];
2249 };
2250
2251
2252 /*
2253  * Eth Rx Cqe structure- general structure for ramrods
2254  */
2255 struct common_ramrod_eth_rx_cqe {
2256         u8 ramrod_type;
2257 #define COMMON_RAMROD_ETH_RX_CQE_TYPE (0x1<<0)
2258 #define COMMON_RAMROD_ETH_RX_CQE_TYPE_SHIFT 0
2259 #define COMMON_RAMROD_ETH_RX_CQE_RESERVED0 (0x7F<<1)
2260 #define COMMON_RAMROD_ETH_RX_CQE_RESERVED0_SHIFT 1
2261         u8 conn_type;
2262         u16 reserved1;
2263         u32 conn_and_cmd_data;
2264 #define COMMON_RAMROD_ETH_RX_CQE_CID (0xFFFFFF<<0)
2265 #define COMMON_RAMROD_ETH_RX_CQE_CID_SHIFT 0
2266 #define COMMON_RAMROD_ETH_RX_CQE_CMD_ID (0xFF<<24)
2267 #define COMMON_RAMROD_ETH_RX_CQE_CMD_ID_SHIFT 24
2268         struct ramrod_data protocol_data;
2269         u32 reserved2[4];
2270 };
2271
2272 /*
2273  * Rx Last CQE in page (in ETH)
2274  */
2275 struct eth_rx_cqe_next_page {
2276         u32 addr_lo;
2277         u32 addr_hi;
2278         u32 reserved[6];
2279 };
2280
2281 /*
2282  * union for all eth rx cqe types (fix their sizes)
2283  */
2284 union eth_rx_cqe {
2285         struct eth_fast_path_rx_cqe fast_path_cqe;
2286         struct common_ramrod_eth_rx_cqe ramrod_cqe;
2287         struct eth_rx_cqe_next_page next_page_cqe;
2288 };
2289
2290
2291 /*
2292  * common data for all protocols
2293  */
2294 struct spe_hdr {
2295         u32 conn_and_cmd_data;
2296 #define SPE_HDR_CID (0xFFFFFF<<0)
2297 #define SPE_HDR_CID_SHIFT 0
2298 #define SPE_HDR_CMD_ID (0xFF<<24)
2299 #define SPE_HDR_CMD_ID_SHIFT 24
2300         u16 type;
2301 #define SPE_HDR_CONN_TYPE (0xFF<<0)
2302 #define SPE_HDR_CONN_TYPE_SHIFT 0
2303 #define SPE_HDR_COMMON_RAMROD (0xFF<<8)
2304 #define SPE_HDR_COMMON_RAMROD_SHIFT 8
2305         u16 reserved;
2306 };
2307
2308 /*
2309  * Ethernet slow path element
2310  */
2311 union eth_specific_data {
2312         u8 protocol_data[8];
2313         struct regpair mac_config_addr;
2314         struct eth_client_setup_ramrod_data client_setup_ramrod_data;
2315         struct eth_halt_ramrod_data halt_ramrod_data;
2316         struct regpair leading_cqe_addr;
2317         struct regpair update_data_addr;
2318         struct eth_query_ramrod_data query_ramrod_data;
2319 };
2320
2321 /*
2322  * Ethernet slow path element
2323  */
2324 struct eth_spe {
2325         struct spe_hdr hdr;
2326         union eth_specific_data data;
2327 };
2328
2329
2330 /*
2331  * doorbell data in host memory
2332  */
2333 struct eth_tx_db_data {
2334         u32 packets_prod;
2335         u16 bds_prod;
2336         u16 reserved;
2337 };
2338
2339
2340 /*
2341  * Common configuration parameters per function in Tstorm
2342  */
2343 struct tstorm_eth_function_common_config {
2344 #if defined(__BIG_ENDIAN)
2345         u8 leading_client_id;
2346         u8 rss_result_mask;
2347         u16 config_flags;
2348 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV4_CAPABILITY (0x1<<0)
2349 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV4_CAPABILITY_SHIFT 0
2350 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV4_TCP_CAPABILITY (0x1<<1)
2351 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV4_TCP_CAPABILITY_SHIFT 1
2352 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV6_CAPABILITY (0x1<<2)
2353 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV6_CAPABILITY_SHIFT 2
2354 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV6_TCP_CAPABILITY (0x1<<3)
2355 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV6_TCP_CAPABILITY_SHIFT 3
2356 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_MODE (0x7<<4)
2357 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_MODE_SHIFT 4
2358 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_DEFAULT_ENABLE (0x1<<7)
2359 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_DEFAULT_ENABLE_SHIFT 7
2360 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_VLAN_IN_CAM (0x1<<8)
2361 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_VLAN_IN_CAM_SHIFT 8
2362 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_E1HOV_IN_CAM (0x1<<9)
2363 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_E1HOV_IN_CAM_SHIFT 9
2364 #define __TSTORM_ETH_FUNCTION_COMMON_CONFIG_RESERVED0 (0x3F<<10)
2365 #define __TSTORM_ETH_FUNCTION_COMMON_CONFIG_RESERVED0_SHIFT 10
2366 #elif defined(__LITTLE_ENDIAN)
2367         u16 config_flags;
2368 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV4_CAPABILITY (0x1<<0)
2369 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV4_CAPABILITY_SHIFT 0
2370 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV4_TCP_CAPABILITY (0x1<<1)
2371 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV4_TCP_CAPABILITY_SHIFT 1
2372 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV6_CAPABILITY (0x1<<2)
2373 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV6_CAPABILITY_SHIFT 2
2374 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV6_TCP_CAPABILITY (0x1<<3)
2375 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_IPV6_TCP_CAPABILITY_SHIFT 3
2376 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_MODE (0x7<<4)
2377 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_RSS_MODE_SHIFT 4
2378 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_DEFAULT_ENABLE (0x1<<7)
2379 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_DEFAULT_ENABLE_SHIFT 7
2380 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_VLAN_IN_CAM (0x1<<8)
2381 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_VLAN_IN_CAM_SHIFT 8
2382 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_E1HOV_IN_CAM (0x1<<9)
2383 #define TSTORM_ETH_FUNCTION_COMMON_CONFIG_E1HOV_IN_CAM_SHIFT 9
2384 #define __TSTORM_ETH_FUNCTION_COMMON_CONFIG_RESERVED0 (0x3F<<10)
2385 #define __TSTORM_ETH_FUNCTION_COMMON_CONFIG_RESERVED0_SHIFT 10
2386         u8 rss_result_mask;
2387         u8 leading_client_id;
2388 #endif
2389         u16 vlan_id[2];
2390 };
2391
2392 /*
2393  * parameters for eth update ramrod
2394  */
2395 struct eth_update_ramrod_data {
2396         struct tstorm_eth_function_common_config func_config;
2397         u8 indirectionTable[128];
2398 };
2399
2400
2401 /*
2402  * MAC filtering configuration command header
2403  */
2404 struct mac_configuration_hdr {
2405         u8 length;
2406         u8 offset;
2407         u16 client_id;
2408         u32 reserved1;
2409 };
2410
2411 /*
2412  * MAC address in list for ramrod
2413  */
2414 struct tstorm_cam_entry {
2415         u16 lsb_mac_addr;
2416         u16 middle_mac_addr;
2417         u16 msb_mac_addr;
2418         u16 flags;
2419 #define TSTORM_CAM_ENTRY_PORT_ID (0x1<<0)
2420 #define TSTORM_CAM_ENTRY_PORT_ID_SHIFT 0
2421 #define TSTORM_CAM_ENTRY_RSRVVAL0 (0x7<<1)
2422 #define TSTORM_CAM_ENTRY_RSRVVAL0_SHIFT 1
2423 #define TSTORM_CAM_ENTRY_RESERVED0 (0xFFF<<4)
2424 #define TSTORM_CAM_ENTRY_RESERVED0_SHIFT 4
2425 };
2426
2427 /*
2428  * MAC filtering: CAM target table entry
2429  */
2430 struct tstorm_cam_target_table_entry {
2431         u8 flags;
2432 #define TSTORM_CAM_TARGET_TABLE_ENTRY_BROADCAST (0x1<<0)
2433 #define TSTORM_CAM_TARGET_TABLE_ENTRY_BROADCAST_SHIFT 0
2434 #define TSTORM_CAM_TARGET_TABLE_ENTRY_OVERRIDE_VLAN_REMOVAL (0x1<<1)
2435 #define TSTORM_CAM_TARGET_TABLE_ENTRY_OVERRIDE_VLAN_REMOVAL_SHIFT 1
2436 #define TSTORM_CAM_TARGET_TABLE_ENTRY_ACTION_TYPE (0x1<<2)
2437 #define TSTORM_CAM_TARGET_TABLE_ENTRY_ACTION_TYPE_SHIFT 2
2438 #define TSTORM_CAM_TARGET_TABLE_ENTRY_RDMA_MAC (0x1<<3)
2439 #define TSTORM_CAM_TARGET_TABLE_ENTRY_RDMA_MAC_SHIFT 3
2440 #define TSTORM_CAM_TARGET_TABLE_ENTRY_RESERVED0 (0xF<<4)
2441 #define TSTORM_CAM_TARGET_TABLE_ENTRY_RESERVED0_SHIFT 4
2442         u8 client_id;
2443         u16 vlan_id;
2444 };
2445
2446 /*
2447  * MAC address in list for ramrod
2448  */
2449 struct mac_configuration_entry {
2450         struct tstorm_cam_entry cam_entry;
2451         struct tstorm_cam_target_table_entry target_table_entry;
2452 };
2453
2454 /*
2455  * MAC filtering configuration command
2456  */
2457 struct mac_configuration_cmd {
2458         struct mac_configuration_hdr hdr;
2459         struct mac_configuration_entry config_table[64];
2460 };
2461
2462
2463 /*
2464  * MAC address in list for ramrod
2465  */
2466 struct mac_configuration_entry_e1h {
2467         u16 lsb_mac_addr;
2468         u16 middle_mac_addr;
2469         u16 msb_mac_addr;
2470         u16 vlan_id;
2471         u16 e1hov_id;
2472         u8 client_id;
2473         u8 flags;
2474 #define MAC_CONFIGURATION_ENTRY_E1H_PORT (0x1<<0)
2475 #define MAC_CONFIGURATION_ENTRY_E1H_PORT_SHIFT 0
2476 #define MAC_CONFIGURATION_ENTRY_E1H_ACTION_TYPE (0x1<<1)
2477 #define MAC_CONFIGURATION_ENTRY_E1H_ACTION_TYPE_SHIFT 1
2478 #define MAC_CONFIGURATION_ENTRY_E1H_RDMA_MAC (0x1<<2)
2479 #define MAC_CONFIGURATION_ENTRY_E1H_RDMA_MAC_SHIFT 2
2480 #define MAC_CONFIGURATION_ENTRY_E1H_RESERVED0 (0x1F<<3)
2481 #define MAC_CONFIGURATION_ENTRY_E1H_RESERVED0_SHIFT 3
2482 };
2483
2484 /*
2485  * MAC filtering configuration command
2486  */
2487 struct mac_configuration_cmd_e1h {
2488         struct mac_configuration_hdr hdr;
2489         struct mac_configuration_entry_e1h config_table[32];
2490 };
2491
2492
2493 /*
2494  * approximate-match multicast filtering for E1H per function in Tstorm
2495  */
2496 struct tstorm_eth_approximate_match_multicast_filtering {
2497         u32 mcast_add_hash_bit_array[8];
2498 };
2499
2500
2501 /*
2502  * Configuration parameters per client in Tstorm
2503  */
2504 struct tstorm_eth_client_config {
2505 #if defined(__BIG_ENDIAN)
2506         u8 max_sges_for_packet;
2507         u8 statistics_counter_id;
2508         u16 mtu;
2509 #elif defined(__LITTLE_ENDIAN)
2510         u16 mtu;
2511         u8 statistics_counter_id;
2512         u8 max_sges_for_packet;
2513 #endif
2514 #if defined(__BIG_ENDIAN)
2515         u16 drop_flags;
2516 #define TSTORM_ETH_CLIENT_CONFIG_DROP_IP_CS_ERR (0x1<<0)
2517 #define TSTORM_ETH_CLIENT_CONFIG_DROP_IP_CS_ERR_SHIFT 0
2518 #define TSTORM_ETH_CLIENT_CONFIG_DROP_TCP_CS_ERR (0x1<<1)
2519 #define TSTORM_ETH_CLIENT_CONFIG_DROP_TCP_CS_ERR_SHIFT 1
2520 #define TSTORM_ETH_CLIENT_CONFIG_DROP_TTL0 (0x1<<2)
2521 #define TSTORM_ETH_CLIENT_CONFIG_DROP_TTL0_SHIFT 2
2522 #define TSTORM_ETH_CLIENT_CONFIG_DROP_UDP_CS_ERR (0x1<<3)
2523 #define TSTORM_ETH_CLIENT_CONFIG_DROP_UDP_CS_ERR_SHIFT 3
2524 #define __TSTORM_ETH_CLIENT_CONFIG_RESERVED1 (0xFFF<<4)
2525 #define __TSTORM_ETH_CLIENT_CONFIG_RESERVED1_SHIFT 4
2526         u16 config_flags;
2527 #define TSTORM_ETH_CLIENT_CONFIG_VLAN_REM_ENABLE (0x1<<0)
2528 #define TSTORM_ETH_CLIENT_CONFIG_VLAN_REM_ENABLE_SHIFT 0
2529 #define TSTORM_ETH_CLIENT_CONFIG_E1HOV_REM_ENABLE (0x1<<1)
2530 #define TSTORM_ETH_CLIENT_CONFIG_E1HOV_REM_ENABLE_SHIFT 1
2531 #define TSTORM_ETH_CLIENT_CONFIG_STATSITICS_ENABLE (0x1<<2)
2532 #define TSTORM_ETH_CLIENT_CONFIG_STATSITICS_ENABLE_SHIFT 2
2533 #define TSTORM_ETH_CLIENT_CONFIG_ENABLE_SGE_RING (0x1<<3)
2534 #define TSTORM_ETH_CLIENT_CONFIG_ENABLE_SGE_RING_SHIFT 3
2535 #define __TSTORM_ETH_CLIENT_CONFIG_RESERVED0 (0xFFF<<4)
2536 #define __TSTORM_ETH_CLIENT_CONFIG_RESERVED0_SHIFT 4
2537 #elif defined(__LITTLE_ENDIAN)
2538         u16 config_flags;
2539 #define TSTORM_ETH_CLIENT_CONFIG_VLAN_REM_ENABLE (0x1<<0)
2540 #define TSTORM_ETH_CLIENT_CONFIG_VLAN_REM_ENABLE_SHIFT 0
2541 #define TSTORM_ETH_CLIENT_CONFIG_E1HOV_REM_ENABLE (0x1<<1)
2542 #define TSTORM_ETH_CLIENT_CONFIG_E1HOV_REM_ENABLE_SHIFT 1
2543 #define TSTORM_ETH_CLIENT_CONFIG_STATSITICS_ENABLE (0x1<<2)
2544 #define TSTORM_ETH_CLIENT_CONFIG_STATSITICS_ENABLE_SHIFT 2
2545 #define TSTORM_ETH_CLIENT_CONFIG_ENABLE_SGE_RING (0x1<<3)
2546 #define TSTORM_ETH_CLIENT_CONFIG_ENABLE_SGE_RING_SHIFT 3
2547 #define __TSTORM_ETH_CLIENT_CONFIG_RESERVED0 (0xFFF<<4)
2548 #define __TSTORM_ETH_CLIENT_CONFIG_RESERVED0_SHIFT 4
2549         u16 drop_flags;
2550 #define TSTORM_ETH_CLIENT_CONFIG_DROP_IP_CS_ERR (0x1<<0)
2551 #define TSTORM_ETH_CLIENT_CONFIG_DROP_IP_CS_ERR_SHIFT 0
2552 #define TSTORM_ETH_CLIENT_CONFIG_DROP_TCP_CS_ERR (0x1<<1)
2553 #define TSTORM_ETH_CLIENT_CONFIG_DROP_TCP_CS_ERR_SHIFT 1
2554 #define TSTORM_ETH_CLIENT_CONFIG_DROP_TTL0 (0x1<<2)
2555 #define TSTORM_ETH_CLIENT_CONFIG_DROP_TTL0_SHIFT 2
2556 #define TSTORM_ETH_CLIENT_CONFIG_DROP_UDP_CS_ERR (0x1<<3)
2557 #define TSTORM_ETH_CLIENT_CONFIG_DROP_UDP_CS_ERR_SHIFT 3
2558 #define __TSTORM_ETH_CLIENT_CONFIG_RESERVED1 (0xFFF<<4)
2559 #define __TSTORM_ETH_CLIENT_CONFIG_RESERVED1_SHIFT 4
2560 #endif
2561 };
2562
2563
2564 /*
2565  * MAC filtering configuration parameters per port in Tstorm
2566  */
2567 struct tstorm_eth_mac_filter_config {
2568         u32 ucast_drop_all;
2569         u32 ucast_accept_all;
2570         u32 mcast_drop_all;
2571         u32 mcast_accept_all;
2572         u32 bcast_drop_all;
2573         u32 bcast_accept_all;
2574         u32 strict_vlan;
2575         u32 vlan_filter[2];
2576         u32 reserved;
2577 };
2578
2579
2580 /*
2581  * common flag to indicate existance of TPA.
2582  */
2583 struct tstorm_eth_tpa_exist {
2584 #if defined(__BIG_ENDIAN)
2585         u16 reserved1;
2586         u8 reserved0;
2587         u8 tpa_exist;
2588 #elif defined(__LITTLE_ENDIAN)
2589         u8 tpa_exist;
2590         u8 reserved0;
2591         u16 reserved1;
2592 #endif
2593         u32 reserved2;
2594 };
2595
2596
2597 /*
2598  * rx rings pause data for E1h only
2599  */
2600 struct ustorm_eth_rx_pause_data_e1h {
2601 #if defined(__BIG_ENDIAN)
2602         u16 bd_thr_low;
2603         u16 cqe_thr_low;
2604 #elif defined(__LITTLE_ENDIAN)
2605         u16 cqe_thr_low;
2606         u16 bd_thr_low;
2607 #endif
2608 #if defined(__BIG_ENDIAN)
2609         u16 cos;
2610         u16 sge_thr_low;
2611 #elif defined(__LITTLE_ENDIAN)
2612         u16 sge_thr_low;
2613         u16 cos;
2614 #endif
2615 #if defined(__BIG_ENDIAN)
2616         u16 bd_thr_high;
2617         u16 cqe_thr_high;
2618 #elif defined(__LITTLE_ENDIAN)
2619         u16 cqe_thr_high;
2620         u16 bd_thr_high;
2621 #endif
2622 #if defined(__BIG_ENDIAN)
2623         u16 reserved0;
2624         u16 sge_thr_high;
2625 #elif defined(__LITTLE_ENDIAN)
2626         u16 sge_thr_high;
2627         u16 reserved0;
2628 #endif
2629 };
2630
2631
2632 /*
2633  * Three RX producers for ETH
2634  */
2635 struct ustorm_eth_rx_producers {
2636 #if defined(__BIG_ENDIAN)
2637         u16 bd_prod;
2638         u16 cqe_prod;
2639 #elif defined(__LITTLE_ENDIAN)
2640         u16 cqe_prod;
2641         u16 bd_prod;
2642 #endif
2643 #if defined(__BIG_ENDIAN)
2644         u16 reserved;
2645         u16 sge_prod;
2646 #elif defined(__LITTLE_ENDIAN)
2647         u16 sge_prod;
2648         u16 reserved;
2649 #endif
2650 };
2651
2652
2653 /*
2654  * per-port SAFC demo variables
2655  */
2656 struct cmng_flags_per_port {
2657         u8 con_number[NUM_OF_PROTOCOLS];
2658         u32 cmng_enables;
2659 #define CMNG_FLAGS_PER_PORT_FAIRNESS_VN (0x1<<0)
2660 #define CMNG_FLAGS_PER_PORT_FAIRNESS_VN_SHIFT 0
2661 #define CMNG_FLAGS_PER_PORT_RATE_SHAPING_VN (0x1<<1)
2662 #define CMNG_FLAGS_PER_PORT_RATE_SHAPING_VN_SHIFT 1
2663 #define CMNG_FLAGS_PER_PORT_FAIRNESS_PROTOCOL (0x1<<2)
2664 #define CMNG_FLAGS_PER_PORT_FAIRNESS_PROTOCOL_SHIFT 2
2665 #define CMNG_FLAGS_PER_PORT_RATE_SHAPING_PROTOCOL (0x1<<3)
2666 #define CMNG_FLAGS_PER_PORT_RATE_SHAPING_PROTOCOL_SHIFT 3
2667 #define CMNG_FLAGS_PER_PORT_FAIRNESS_COS (0x1<<4)
2668 #define CMNG_FLAGS_PER_PORT_FAIRNESS_COS_SHIFT 4
2669 #define __CMNG_FLAGS_PER_PORT_RESERVED0 (0x7FFFFFF<<5)
2670 #define __CMNG_FLAGS_PER_PORT_RESERVED0_SHIFT 5
2671 };
2672
2673
2674 /*
2675  * per-port rate shaping variables
2676  */
2677 struct rate_shaping_vars_per_port {
2678         u32 rs_periodic_timeout;
2679         u32 rs_threshold;
2680 };
2681
2682
2683 /*
2684  * per-port fairness variables
2685  */
2686 struct fairness_vars_per_port {
2687         u32 upper_bound;
2688         u32 fair_threshold;
2689         u32 fairness_timeout;
2690 };
2691
2692
2693 /*
2694  * per-port SAFC variables
2695  */
2696 struct safc_struct_per_port {
2697 #if defined(__BIG_ENDIAN)
2698         u16 __reserved1;
2699         u8 __reserved0;
2700         u8 safc_timeout_usec;
2701 #elif defined(__LITTLE_ENDIAN)
2702         u8 safc_timeout_usec;
2703         u8 __reserved0;
2704         u16 __reserved1;
2705 #endif
2706         u16 cos_to_pause_mask[NUM_OF_SAFC_BITS];
2707 };
2708
2709
2710 /*
2711  * Per-port congestion management variables
2712  */
2713 struct cmng_struct_per_port {
2714         struct rate_shaping_vars_per_port rs_vars;
2715         struct fairness_vars_per_port fair_vars;
2716         struct safc_struct_per_port safc_vars;
2717         struct cmng_flags_per_port flags;
2718 };
2719
2720
2721 /*
2722  * Protocol-common statistics collected by the Xstorm (per client)
2723  */
2724 struct xstorm_per_client_stats {
2725         struct regpair total_sent_bytes;
2726         u32 total_sent_pkts;
2727         u32 unicast_pkts_sent;
2728         struct regpair unicast_bytes_sent;
2729         struct regpair multicast_bytes_sent;
2730         u32 multicast_pkts_sent;
2731         u32 broadcast_pkts_sent;
2732         struct regpair broadcast_bytes_sent;
2733         u16 stats_counter;
2734         u16 reserved0;
2735         u32 reserved1;
2736 };
2737
2738
2739 /*
2740  * Common statistics collected by the Xstorm (per port)
2741  */
2742 struct xstorm_common_stats {
2743  struct xstorm_per_client_stats client_statistics[MAX_X_STAT_COUNTER_ID];
2744 };
2745
2746
2747 /*
2748  * Protocol-common statistics collected by the Tstorm (per port)
2749  */
2750 struct tstorm_per_port_stats {
2751         u32 mac_filter_discard;
2752         u32 xxoverflow_discard;
2753         u32 brb_truncate_discard;
2754         u32 mac_discard;
2755 };
2756
2757
2758 /*
2759  * Protocol-common statistics collected by the Tstorm (per client)
2760  */
2761 struct tstorm_per_client_stats {
2762         struct regpair total_rcv_bytes;
2763         struct regpair rcv_unicast_bytes;
2764         struct regpair rcv_broadcast_bytes;
2765         struct regpair rcv_multicast_bytes;
2766         struct regpair rcv_error_bytes;
2767         u32 checksum_discard;
2768         u32 packets_too_big_discard;
2769         u32 total_rcv_pkts;
2770         u32 rcv_unicast_pkts;
2771         u32 rcv_broadcast_pkts;
2772         u32 rcv_multicast_pkts;
2773         u32 no_buff_discard;
2774         u32 ttl0_discard;
2775         u16 stats_counter;
2776         u16 reserved0;
2777         u32 reserved1;
2778 };
2779
2780 /*
2781  * Protocol-common statistics collected by the Tstorm
2782  */
2783 struct tstorm_common_stats {
2784         struct tstorm_per_port_stats port_statistics;
2785  struct tstorm_per_client_stats client_statistics[MAX_T_STAT_COUNTER_ID];
2786 };
2787
2788 /*
2789  * Protocol-common statistics collected by the Ustorm (per client)
2790  */
2791 struct ustorm_per_client_stats {
2792         struct regpair ucast_no_buff_bytes;
2793         struct regpair mcast_no_buff_bytes;
2794         struct regpair bcast_no_buff_bytes;
2795         __le32 ucast_no_buff_pkts;
2796         __le32 mcast_no_buff_pkts;
2797         __le32 bcast_no_buff_pkts;
2798         __le16 stats_counter;
2799         __le16 reserved0;
2800 };
2801
2802 /*
2803  * Protocol-common statistics collected by the Ustorm
2804  */
2805 struct ustorm_common_stats {
2806  struct ustorm_per_client_stats client_statistics[MAX_U_STAT_COUNTER_ID];
2807 };
2808
2809 /*
2810  * Eth statistics query structure for the eth_stats_query ramrod
2811  */
2812 struct eth_stats_query {
2813         struct xstorm_common_stats xstorm_common;
2814         struct tstorm_common_stats tstorm_common;
2815         struct ustorm_common_stats ustorm_common;
2816 };
2817
2818
2819 /*
2820  * per-vnic fairness variables
2821  */
2822 struct fairness_vars_per_vn {
2823         u32 cos_credit_delta[MAX_COS_NUMBER];
2824         u32 protocol_credit_delta[NUM_OF_PROTOCOLS];
2825         u32 vn_credit_delta;
2826         u32 __reserved0;
2827 };
2828
2829
2830 /*
2831  * FW version stored in the Xstorm RAM
2832  */
2833 struct fw_version {
2834 #if defined(__BIG_ENDIAN)
2835         u8 engineering;
2836         u8 revision;
2837         u8 minor;
2838         u8 major;
2839 #elif defined(__LITTLE_ENDIAN)
2840         u8 major;
2841         u8 minor;
2842         u8 revision;
2843         u8 engineering;
2844 #endif
2845         u32 flags;
2846 #define FW_VERSION_OPTIMIZED (0x1<<0)
2847 #define FW_VERSION_OPTIMIZED_SHIFT 0
2848 #define FW_VERSION_BIG_ENDIEN (0x1<<1)
2849 #define FW_VERSION_BIG_ENDIEN_SHIFT 1
2850 #define FW_VERSION_CHIP_VERSION (0x3<<2)
2851 #define FW_VERSION_CHIP_VERSION_SHIFT 2
2852 #define __FW_VERSION_RESERVED (0xFFFFFFF<<4)
2853 #define __FW_VERSION_RESERVED_SHIFT 4
2854 };
2855
2856
2857 /*
2858  * FW version stored in first line of pram
2859  */
2860 struct pram_fw_version {
2861         u8 major;
2862         u8 minor;
2863         u8 revision;
2864         u8 engineering;
2865         u8 flags;
2866 #define PRAM_FW_VERSION_OPTIMIZED (0x1<<0)
2867 #define PRAM_FW_VERSION_OPTIMIZED_SHIFT 0
2868 #define PRAM_FW_VERSION_STORM_ID (0x3<<1)
2869 #define PRAM_FW_VERSION_STORM_ID_SHIFT 1
2870 #define PRAM_FW_VERSION_BIG_ENDIEN (0x1<<3)
2871 #define PRAM_FW_VERSION_BIG_ENDIEN_SHIFT 3
2872 #define PRAM_FW_VERSION_CHIP_VERSION (0x3<<4)
2873 #define PRAM_FW_VERSION_CHIP_VERSION_SHIFT 4
2874 #define __PRAM_FW_VERSION_RESERVED0 (0x3<<6)
2875 #define __PRAM_FW_VERSION_RESERVED0_SHIFT 6
2876 };
2877
2878
2879 /*
2880  * a single rate shaping counter. can be used as protocol or vnic counter
2881  */
2882 struct rate_shaping_counter {
2883         u32 quota;
2884 #if defined(__BIG_ENDIAN)
2885         u16 __reserved0;
2886         u16 rate;
2887 #elif defined(__LITTLE_ENDIAN)
2888         u16 rate;
2889         u16 __reserved0;
2890 #endif
2891 };
2892
2893
2894 /*
2895  * per-vnic rate shaping variables
2896  */
2897 struct rate_shaping_vars_per_vn {
2898         struct rate_shaping_counter protocol_counters[NUM_OF_PROTOCOLS];
2899         struct rate_shaping_counter vn_counter;
2900 };
2901
2902
2903 /*
2904  * The send queue element
2905  */
2906 struct slow_path_element {
2907         struct spe_hdr hdr;
2908         u8 protocol_data[8];
2909 };
2910
2911
2912 /*
2913  * eth/toe flags that indicate if to query
2914  */
2915 struct stats_indication_flags {
2916         u32 collect_eth;
2917         u32 collect_toe;
2918 };
2919
2920