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