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