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