1 /* Broadcom NetXtreme-C/E network driver.
3 * Copyright (c) 2014-2016 Broadcom Corporation
4 * Copyright (c) 2014-2018 Broadcom Limited
5 * Copyright (c) 2018-2022 Broadcom Inc.
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation.
11 * DO NOT MODIFY!!! This file is automatically generated.
17 /* hwrm_cmd_hdr (size:128b/16B) */
26 /* hwrm_resp_hdr (size:64b/8B) */
27 struct hwrm_resp_hdr {
34 #define CMD_DISCR_TLV_ENCAP 0x8000UL
35 #define CMD_DISCR_LAST CMD_DISCR_TLV_ENCAP
38 #define TLV_TYPE_HWRM_REQUEST 0x1UL
39 #define TLV_TYPE_HWRM_RESPONSE 0x2UL
40 #define TLV_TYPE_ROCE_SP_COMMAND 0x3UL
41 #define TLV_TYPE_QUERY_ROCE_CC_GEN1 0x4UL
42 #define TLV_TYPE_MODIFY_ROCE_CC_GEN1 0x5UL
43 #define TLV_TYPE_ENGINE_CKV_ALIAS_ECC_PUBLIC_KEY 0x8001UL
44 #define TLV_TYPE_ENGINE_CKV_IV 0x8003UL
45 #define TLV_TYPE_ENGINE_CKV_AUTH_TAG 0x8004UL
46 #define TLV_TYPE_ENGINE_CKV_CIPHERTEXT 0x8005UL
47 #define TLV_TYPE_ENGINE_CKV_HOST_ALGORITHMS 0x8006UL
48 #define TLV_TYPE_ENGINE_CKV_HOST_ECC_PUBLIC_KEY 0x8007UL
49 #define TLV_TYPE_ENGINE_CKV_ECDSA_SIGNATURE 0x8008UL
50 #define TLV_TYPE_ENGINE_CKV_FW_ECC_PUBLIC_KEY 0x8009UL
51 #define TLV_TYPE_ENGINE_CKV_FW_ALGORITHMS 0x800aUL
52 #define TLV_TYPE_LAST TLV_TYPE_ENGINE_CKV_FW_ALGORITHMS
55 /* tlv (size:64b/8B) */
60 #define TLV_FLAGS_MORE 0x1UL
61 #define TLV_FLAGS_MORE_LAST 0x0UL
62 #define TLV_FLAGS_MORE_NOT_LAST 0x1UL
63 #define TLV_FLAGS_REQUIRED 0x2UL
64 #define TLV_FLAGS_REQUIRED_NO (0x0UL << 1)
65 #define TLV_FLAGS_REQUIRED_YES (0x1UL << 1)
66 #define TLV_FLAGS_REQUIRED_LAST TLV_FLAGS_REQUIRED_YES
71 /* input (size:128b/16B) */
80 /* output (size:64b/8B) */
88 /* hwrm_short_input (size:128b/16B) */
89 struct hwrm_short_input {
92 #define SHORT_REQ_SIGNATURE_SHORT_CMD 0x4321UL
93 #define SHORT_REQ_SIGNATURE_LAST SHORT_REQ_SIGNATURE_SHORT_CMD
95 #define SHORT_REQ_TARGET_ID_DEFAULT 0x0UL
96 #define SHORT_REQ_TARGET_ID_TOOLS 0xfffdUL
97 #define SHORT_REQ_TARGET_ID_LAST SHORT_REQ_TARGET_ID_TOOLS
102 /* cmd_nums (size:64b/8B) */
105 #define HWRM_VER_GET 0x0UL
106 #define HWRM_FUNC_ECHO_RESPONSE 0xbUL
107 #define HWRM_ERROR_RECOVERY_QCFG 0xcUL
108 #define HWRM_FUNC_DRV_IF_CHANGE 0xdUL
109 #define HWRM_FUNC_BUF_UNRGTR 0xeUL
110 #define HWRM_FUNC_VF_CFG 0xfUL
111 #define HWRM_RESERVED1 0x10UL
112 #define HWRM_FUNC_RESET 0x11UL
113 #define HWRM_FUNC_GETFID 0x12UL
114 #define HWRM_FUNC_VF_ALLOC 0x13UL
115 #define HWRM_FUNC_VF_FREE 0x14UL
116 #define HWRM_FUNC_QCAPS 0x15UL
117 #define HWRM_FUNC_QCFG 0x16UL
118 #define HWRM_FUNC_CFG 0x17UL
119 #define HWRM_FUNC_QSTATS 0x18UL
120 #define HWRM_FUNC_CLR_STATS 0x19UL
121 #define HWRM_FUNC_DRV_UNRGTR 0x1aUL
122 #define HWRM_FUNC_VF_RESC_FREE 0x1bUL
123 #define HWRM_FUNC_VF_VNIC_IDS_QUERY 0x1cUL
124 #define HWRM_FUNC_DRV_RGTR 0x1dUL
125 #define HWRM_FUNC_DRV_QVER 0x1eUL
126 #define HWRM_FUNC_BUF_RGTR 0x1fUL
127 #define HWRM_PORT_PHY_CFG 0x20UL
128 #define HWRM_PORT_MAC_CFG 0x21UL
129 #define HWRM_PORT_TS_QUERY 0x22UL
130 #define HWRM_PORT_QSTATS 0x23UL
131 #define HWRM_PORT_LPBK_QSTATS 0x24UL
132 #define HWRM_PORT_CLR_STATS 0x25UL
133 #define HWRM_PORT_LPBK_CLR_STATS 0x26UL
134 #define HWRM_PORT_PHY_QCFG 0x27UL
135 #define HWRM_PORT_MAC_QCFG 0x28UL
136 #define HWRM_PORT_MAC_PTP_QCFG 0x29UL
137 #define HWRM_PORT_PHY_QCAPS 0x2aUL
138 #define HWRM_PORT_PHY_I2C_WRITE 0x2bUL
139 #define HWRM_PORT_PHY_I2C_READ 0x2cUL
140 #define HWRM_PORT_LED_CFG 0x2dUL
141 #define HWRM_PORT_LED_QCFG 0x2eUL
142 #define HWRM_PORT_LED_QCAPS 0x2fUL
143 #define HWRM_QUEUE_QPORTCFG 0x30UL
144 #define HWRM_QUEUE_QCFG 0x31UL
145 #define HWRM_QUEUE_CFG 0x32UL
146 #define HWRM_FUNC_VLAN_CFG 0x33UL
147 #define HWRM_FUNC_VLAN_QCFG 0x34UL
148 #define HWRM_QUEUE_PFCENABLE_QCFG 0x35UL
149 #define HWRM_QUEUE_PFCENABLE_CFG 0x36UL
150 #define HWRM_QUEUE_PRI2COS_QCFG 0x37UL
151 #define HWRM_QUEUE_PRI2COS_CFG 0x38UL
152 #define HWRM_QUEUE_COS2BW_QCFG 0x39UL
153 #define HWRM_QUEUE_COS2BW_CFG 0x3aUL
154 #define HWRM_QUEUE_DSCP_QCAPS 0x3bUL
155 #define HWRM_QUEUE_DSCP2PRI_QCFG 0x3cUL
156 #define HWRM_QUEUE_DSCP2PRI_CFG 0x3dUL
157 #define HWRM_VNIC_ALLOC 0x40UL
158 #define HWRM_VNIC_FREE 0x41UL
159 #define HWRM_VNIC_CFG 0x42UL
160 #define HWRM_VNIC_QCFG 0x43UL
161 #define HWRM_VNIC_TPA_CFG 0x44UL
162 #define HWRM_VNIC_TPA_QCFG 0x45UL
163 #define HWRM_VNIC_RSS_CFG 0x46UL
164 #define HWRM_VNIC_RSS_QCFG 0x47UL
165 #define HWRM_VNIC_PLCMODES_CFG 0x48UL
166 #define HWRM_VNIC_PLCMODES_QCFG 0x49UL
167 #define HWRM_VNIC_QCAPS 0x4aUL
168 #define HWRM_VNIC_UPDATE 0x4bUL
169 #define HWRM_RING_ALLOC 0x50UL
170 #define HWRM_RING_FREE 0x51UL
171 #define HWRM_RING_CMPL_RING_QAGGINT_PARAMS 0x52UL
172 #define HWRM_RING_CMPL_RING_CFG_AGGINT_PARAMS 0x53UL
173 #define HWRM_RING_AGGINT_QCAPS 0x54UL
174 #define HWRM_RING_SCHQ_ALLOC 0x55UL
175 #define HWRM_RING_SCHQ_CFG 0x56UL
176 #define HWRM_RING_SCHQ_FREE 0x57UL
177 #define HWRM_RING_RESET 0x5eUL
178 #define HWRM_RING_GRP_ALLOC 0x60UL
179 #define HWRM_RING_GRP_FREE 0x61UL
180 #define HWRM_RING_CFG 0x62UL
181 #define HWRM_RING_QCFG 0x63UL
182 #define HWRM_RESERVED5 0x64UL
183 #define HWRM_RESERVED6 0x65UL
184 #define HWRM_VNIC_RSS_COS_LB_CTX_ALLOC 0x70UL
185 #define HWRM_VNIC_RSS_COS_LB_CTX_FREE 0x71UL
186 #define HWRM_QUEUE_MPLS_QCAPS 0x80UL
187 #define HWRM_QUEUE_MPLSTC2PRI_QCFG 0x81UL
188 #define HWRM_QUEUE_MPLSTC2PRI_CFG 0x82UL
189 #define HWRM_QUEUE_VLANPRI_QCAPS 0x83UL
190 #define HWRM_QUEUE_VLANPRI2PRI_QCFG 0x84UL
191 #define HWRM_QUEUE_VLANPRI2PRI_CFG 0x85UL
192 #define HWRM_QUEUE_GLOBAL_CFG 0x86UL
193 #define HWRM_QUEUE_GLOBAL_QCFG 0x87UL
194 #define HWRM_CFA_L2_FILTER_ALLOC 0x90UL
195 #define HWRM_CFA_L2_FILTER_FREE 0x91UL
196 #define HWRM_CFA_L2_FILTER_CFG 0x92UL
197 #define HWRM_CFA_L2_SET_RX_MASK 0x93UL
198 #define HWRM_CFA_VLAN_ANTISPOOF_CFG 0x94UL
199 #define HWRM_CFA_TUNNEL_FILTER_ALLOC 0x95UL
200 #define HWRM_CFA_TUNNEL_FILTER_FREE 0x96UL
201 #define HWRM_CFA_ENCAP_RECORD_ALLOC 0x97UL
202 #define HWRM_CFA_ENCAP_RECORD_FREE 0x98UL
203 #define HWRM_CFA_NTUPLE_FILTER_ALLOC 0x99UL
204 #define HWRM_CFA_NTUPLE_FILTER_FREE 0x9aUL
205 #define HWRM_CFA_NTUPLE_FILTER_CFG 0x9bUL
206 #define HWRM_CFA_EM_FLOW_ALLOC 0x9cUL
207 #define HWRM_CFA_EM_FLOW_FREE 0x9dUL
208 #define HWRM_CFA_EM_FLOW_CFG 0x9eUL
209 #define HWRM_TUNNEL_DST_PORT_QUERY 0xa0UL
210 #define HWRM_TUNNEL_DST_PORT_ALLOC 0xa1UL
211 #define HWRM_TUNNEL_DST_PORT_FREE 0xa2UL
212 #define HWRM_STAT_CTX_ENG_QUERY 0xafUL
213 #define HWRM_STAT_CTX_ALLOC 0xb0UL
214 #define HWRM_STAT_CTX_FREE 0xb1UL
215 #define HWRM_STAT_CTX_QUERY 0xb2UL
216 #define HWRM_STAT_CTX_CLR_STATS 0xb3UL
217 #define HWRM_PORT_QSTATS_EXT 0xb4UL
218 #define HWRM_PORT_PHY_MDIO_WRITE 0xb5UL
219 #define HWRM_PORT_PHY_MDIO_READ 0xb6UL
220 #define HWRM_PORT_PHY_MDIO_BUS_ACQUIRE 0xb7UL
221 #define HWRM_PORT_PHY_MDIO_BUS_RELEASE 0xb8UL
222 #define HWRM_PORT_QSTATS_EXT_PFC_WD 0xb9UL
223 #define HWRM_RESERVED7 0xbaUL
224 #define HWRM_PORT_TX_FIR_CFG 0xbbUL
225 #define HWRM_PORT_TX_FIR_QCFG 0xbcUL
226 #define HWRM_PORT_ECN_QSTATS 0xbdUL
227 #define HWRM_FW_LIVEPATCH_QUERY 0xbeUL
228 #define HWRM_FW_LIVEPATCH 0xbfUL
229 #define HWRM_FW_RESET 0xc0UL
230 #define HWRM_FW_QSTATUS 0xc1UL
231 #define HWRM_FW_HEALTH_CHECK 0xc2UL
232 #define HWRM_FW_SYNC 0xc3UL
233 #define HWRM_FW_STATE_QCAPS 0xc4UL
234 #define HWRM_FW_STATE_QUIESCE 0xc5UL
235 #define HWRM_FW_STATE_BACKUP 0xc6UL
236 #define HWRM_FW_STATE_RESTORE 0xc7UL
237 #define HWRM_FW_SET_TIME 0xc8UL
238 #define HWRM_FW_GET_TIME 0xc9UL
239 #define HWRM_FW_SET_STRUCTURED_DATA 0xcaUL
240 #define HWRM_FW_GET_STRUCTURED_DATA 0xcbUL
241 #define HWRM_FW_IPC_MAILBOX 0xccUL
242 #define HWRM_FW_ECN_CFG 0xcdUL
243 #define HWRM_FW_ECN_QCFG 0xceUL
244 #define HWRM_FW_SECURE_CFG 0xcfUL
245 #define HWRM_EXEC_FWD_RESP 0xd0UL
246 #define HWRM_REJECT_FWD_RESP 0xd1UL
247 #define HWRM_FWD_RESP 0xd2UL
248 #define HWRM_FWD_ASYNC_EVENT_CMPL 0xd3UL
249 #define HWRM_OEM_CMD 0xd4UL
250 #define HWRM_PORT_PRBS_TEST 0xd5UL
251 #define HWRM_PORT_SFP_SIDEBAND_CFG 0xd6UL
252 #define HWRM_PORT_SFP_SIDEBAND_QCFG 0xd7UL
253 #define HWRM_FW_STATE_UNQUIESCE 0xd8UL
254 #define HWRM_PORT_DSC_DUMP 0xd9UL
255 #define HWRM_PORT_EP_TX_QCFG 0xdaUL
256 #define HWRM_PORT_EP_TX_CFG 0xdbUL
257 #define HWRM_PORT_CFG 0xdcUL
258 #define HWRM_PORT_QCFG 0xddUL
259 #define HWRM_TEMP_MONITOR_QUERY 0xe0UL
260 #define HWRM_REG_POWER_QUERY 0xe1UL
261 #define HWRM_CORE_FREQUENCY_QUERY 0xe2UL
262 #define HWRM_REG_POWER_HISTOGRAM 0xe3UL
263 #define HWRM_WOL_FILTER_ALLOC 0xf0UL
264 #define HWRM_WOL_FILTER_FREE 0xf1UL
265 #define HWRM_WOL_FILTER_QCFG 0xf2UL
266 #define HWRM_WOL_REASON_QCFG 0xf3UL
267 #define HWRM_CFA_METER_QCAPS 0xf4UL
268 #define HWRM_CFA_METER_PROFILE_ALLOC 0xf5UL
269 #define HWRM_CFA_METER_PROFILE_FREE 0xf6UL
270 #define HWRM_CFA_METER_PROFILE_CFG 0xf7UL
271 #define HWRM_CFA_METER_INSTANCE_ALLOC 0xf8UL
272 #define HWRM_CFA_METER_INSTANCE_FREE 0xf9UL
273 #define HWRM_CFA_METER_INSTANCE_CFG 0xfaUL
274 #define HWRM_CFA_VFR_ALLOC 0xfdUL
275 #define HWRM_CFA_VFR_FREE 0xfeUL
276 #define HWRM_CFA_VF_PAIR_ALLOC 0x100UL
277 #define HWRM_CFA_VF_PAIR_FREE 0x101UL
278 #define HWRM_CFA_VF_PAIR_INFO 0x102UL
279 #define HWRM_CFA_FLOW_ALLOC 0x103UL
280 #define HWRM_CFA_FLOW_FREE 0x104UL
281 #define HWRM_CFA_FLOW_FLUSH 0x105UL
282 #define HWRM_CFA_FLOW_STATS 0x106UL
283 #define HWRM_CFA_FLOW_INFO 0x107UL
284 #define HWRM_CFA_DECAP_FILTER_ALLOC 0x108UL
285 #define HWRM_CFA_DECAP_FILTER_FREE 0x109UL
286 #define HWRM_CFA_VLAN_ANTISPOOF_QCFG 0x10aUL
287 #define HWRM_CFA_REDIRECT_TUNNEL_TYPE_ALLOC 0x10bUL
288 #define HWRM_CFA_REDIRECT_TUNNEL_TYPE_FREE 0x10cUL
289 #define HWRM_CFA_PAIR_ALLOC 0x10dUL
290 #define HWRM_CFA_PAIR_FREE 0x10eUL
291 #define HWRM_CFA_PAIR_INFO 0x10fUL
292 #define HWRM_FW_IPC_MSG 0x110UL
293 #define HWRM_CFA_REDIRECT_TUNNEL_TYPE_INFO 0x111UL
294 #define HWRM_CFA_REDIRECT_QUERY_TUNNEL_TYPE 0x112UL
295 #define HWRM_CFA_FLOW_AGING_TIMER_RESET 0x113UL
296 #define HWRM_CFA_FLOW_AGING_CFG 0x114UL
297 #define HWRM_CFA_FLOW_AGING_QCFG 0x115UL
298 #define HWRM_CFA_FLOW_AGING_QCAPS 0x116UL
299 #define HWRM_CFA_CTX_MEM_RGTR 0x117UL
300 #define HWRM_CFA_CTX_MEM_UNRGTR 0x118UL
301 #define HWRM_CFA_CTX_MEM_QCTX 0x119UL
302 #define HWRM_CFA_CTX_MEM_QCAPS 0x11aUL
303 #define HWRM_CFA_COUNTER_QCAPS 0x11bUL
304 #define HWRM_CFA_COUNTER_CFG 0x11cUL
305 #define HWRM_CFA_COUNTER_QCFG 0x11dUL
306 #define HWRM_CFA_COUNTER_QSTATS 0x11eUL
307 #define HWRM_CFA_TCP_FLAG_PROCESS_QCFG 0x11fUL
308 #define HWRM_CFA_EEM_QCAPS 0x120UL
309 #define HWRM_CFA_EEM_CFG 0x121UL
310 #define HWRM_CFA_EEM_QCFG 0x122UL
311 #define HWRM_CFA_EEM_OP 0x123UL
312 #define HWRM_CFA_ADV_FLOW_MGNT_QCAPS 0x124UL
313 #define HWRM_CFA_TFLIB 0x125UL
314 #define HWRM_CFA_LAG_GROUP_MEMBER_RGTR 0x126UL
315 #define HWRM_CFA_LAG_GROUP_MEMBER_UNRGTR 0x127UL
316 #define HWRM_CFA_TLS_FILTER_ALLOC 0x128UL
317 #define HWRM_CFA_TLS_FILTER_FREE 0x129UL
318 #define HWRM_ENGINE_CKV_STATUS 0x12eUL
319 #define HWRM_ENGINE_CKV_CKEK_ADD 0x12fUL
320 #define HWRM_ENGINE_CKV_CKEK_DELETE 0x130UL
321 #define HWRM_ENGINE_CKV_KEY_ADD 0x131UL
322 #define HWRM_ENGINE_CKV_KEY_DELETE 0x132UL
323 #define HWRM_ENGINE_CKV_FLUSH 0x133UL
324 #define HWRM_ENGINE_CKV_RNG_GET 0x134UL
325 #define HWRM_ENGINE_CKV_KEY_GEN 0x135UL
326 #define HWRM_ENGINE_CKV_KEY_LABEL_CFG 0x136UL
327 #define HWRM_ENGINE_CKV_KEY_LABEL_QCFG 0x137UL
328 #define HWRM_ENGINE_QG_CONFIG_QUERY 0x13cUL
329 #define HWRM_ENGINE_QG_QUERY 0x13dUL
330 #define HWRM_ENGINE_QG_METER_PROFILE_CONFIG_QUERY 0x13eUL
331 #define HWRM_ENGINE_QG_METER_PROFILE_QUERY 0x13fUL
332 #define HWRM_ENGINE_QG_METER_PROFILE_ALLOC 0x140UL
333 #define HWRM_ENGINE_QG_METER_PROFILE_FREE 0x141UL
334 #define HWRM_ENGINE_QG_METER_QUERY 0x142UL
335 #define HWRM_ENGINE_QG_METER_BIND 0x143UL
336 #define HWRM_ENGINE_QG_METER_UNBIND 0x144UL
337 #define HWRM_ENGINE_QG_FUNC_BIND 0x145UL
338 #define HWRM_ENGINE_SG_CONFIG_QUERY 0x146UL
339 #define HWRM_ENGINE_SG_QUERY 0x147UL
340 #define HWRM_ENGINE_SG_METER_QUERY 0x148UL
341 #define HWRM_ENGINE_SG_METER_CONFIG 0x149UL
342 #define HWRM_ENGINE_SG_QG_BIND 0x14aUL
343 #define HWRM_ENGINE_QG_SG_UNBIND 0x14bUL
344 #define HWRM_ENGINE_CONFIG_QUERY 0x154UL
345 #define HWRM_ENGINE_STATS_CONFIG 0x155UL
346 #define HWRM_ENGINE_STATS_CLEAR 0x156UL
347 #define HWRM_ENGINE_STATS_QUERY 0x157UL
348 #define HWRM_ENGINE_STATS_QUERY_CONTINUOUS_ERROR 0x158UL
349 #define HWRM_ENGINE_RQ_ALLOC 0x15eUL
350 #define HWRM_ENGINE_RQ_FREE 0x15fUL
351 #define HWRM_ENGINE_CQ_ALLOC 0x160UL
352 #define HWRM_ENGINE_CQ_FREE 0x161UL
353 #define HWRM_ENGINE_NQ_ALLOC 0x162UL
354 #define HWRM_ENGINE_NQ_FREE 0x163UL
355 #define HWRM_ENGINE_ON_DIE_RQE_CREDITS 0x164UL
356 #define HWRM_ENGINE_FUNC_QCFG 0x165UL
357 #define HWRM_FUNC_RESOURCE_QCAPS 0x190UL
358 #define HWRM_FUNC_VF_RESOURCE_CFG 0x191UL
359 #define HWRM_FUNC_BACKING_STORE_QCAPS 0x192UL
360 #define HWRM_FUNC_BACKING_STORE_CFG 0x193UL
361 #define HWRM_FUNC_BACKING_STORE_QCFG 0x194UL
362 #define HWRM_FUNC_VF_BW_CFG 0x195UL
363 #define HWRM_FUNC_VF_BW_QCFG 0x196UL
364 #define HWRM_FUNC_HOST_PF_IDS_QUERY 0x197UL
365 #define HWRM_FUNC_QSTATS_EXT 0x198UL
366 #define HWRM_STAT_EXT_CTX_QUERY 0x199UL
367 #define HWRM_FUNC_SPD_CFG 0x19aUL
368 #define HWRM_FUNC_SPD_QCFG 0x19bUL
369 #define HWRM_FUNC_PTP_PIN_QCFG 0x19cUL
370 #define HWRM_FUNC_PTP_PIN_CFG 0x19dUL
371 #define HWRM_FUNC_PTP_CFG 0x19eUL
372 #define HWRM_FUNC_PTP_TS_QUERY 0x19fUL
373 #define HWRM_FUNC_PTP_EXT_CFG 0x1a0UL
374 #define HWRM_FUNC_PTP_EXT_QCFG 0x1a1UL
375 #define HWRM_FUNC_KEY_CTX_ALLOC 0x1a2UL
376 #define HWRM_FUNC_BACKING_STORE_CFG_V2 0x1a3UL
377 #define HWRM_FUNC_BACKING_STORE_QCFG_V2 0x1a4UL
378 #define HWRM_FUNC_DBR_PACING_CFG 0x1a5UL
379 #define HWRM_FUNC_DBR_PACING_QCFG 0x1a6UL
380 #define HWRM_FUNC_DBR_PACING_BROADCAST_EVENT 0x1a7UL
381 #define HWRM_FUNC_BACKING_STORE_QCAPS_V2 0x1a8UL
382 #define HWRM_FUNC_DBR_PACING_NQLIST_QUERY 0x1a9UL
383 #define HWRM_FUNC_DBR_RECOVERY_COMPLETED 0x1aaUL
384 #define HWRM_FUNC_SYNCE_CFG 0x1abUL
385 #define HWRM_FUNC_SYNCE_QCFG 0x1acUL
386 #define HWRM_SELFTEST_QLIST 0x200UL
387 #define HWRM_SELFTEST_EXEC 0x201UL
388 #define HWRM_SELFTEST_IRQ 0x202UL
389 #define HWRM_SELFTEST_RETRIEVE_SERDES_DATA 0x203UL
390 #define HWRM_PCIE_QSTATS 0x204UL
391 #define HWRM_MFG_FRU_WRITE_CONTROL 0x205UL
392 #define HWRM_MFG_TIMERS_QUERY 0x206UL
393 #define HWRM_MFG_OTP_CFG 0x207UL
394 #define HWRM_MFG_OTP_QCFG 0x208UL
395 #define HWRM_MFG_HDMA_TEST 0x209UL
396 #define HWRM_MFG_FRU_EEPROM_WRITE 0x20aUL
397 #define HWRM_MFG_FRU_EEPROM_READ 0x20bUL
398 #define HWRM_MFG_SOC_IMAGE 0x20cUL
399 #define HWRM_MFG_SOC_QSTATUS 0x20dUL
400 #define HWRM_MFG_PARAM_SEEPROM_SYNC 0x20eUL
401 #define HWRM_MFG_PARAM_SEEPROM_READ 0x20fUL
402 #define HWRM_MFG_PARAM_SEEPROM_HEALTH 0x210UL
403 #define HWRM_MFG_PRVSN_EXPORT_CSR 0x211UL
404 #define HWRM_MFG_PRVSN_IMPORT_CERT 0x212UL
405 #define HWRM_MFG_PRVSN_GET_STATE 0x213UL
406 #define HWRM_MFG_GET_NVM_MEASUREMENT 0x214UL
407 #define HWRM_MFG_PSOC_QSTATUS 0x215UL
408 #define HWRM_MFG_SELFTEST_QLIST 0x216UL
409 #define HWRM_MFG_SELFTEST_EXEC 0x217UL
410 #define HWRM_STAT_GENERIC_QSTATS 0x218UL
411 #define HWRM_TF 0x2bcUL
412 #define HWRM_TF_VERSION_GET 0x2bdUL
413 #define HWRM_TF_SESSION_OPEN 0x2c6UL
414 #define HWRM_TF_SESSION_ATTACH 0x2c7UL
415 #define HWRM_TF_SESSION_REGISTER 0x2c8UL
416 #define HWRM_TF_SESSION_UNREGISTER 0x2c9UL
417 #define HWRM_TF_SESSION_CLOSE 0x2caUL
418 #define HWRM_TF_SESSION_QCFG 0x2cbUL
419 #define HWRM_TF_SESSION_RESC_QCAPS 0x2ccUL
420 #define HWRM_TF_SESSION_RESC_ALLOC 0x2cdUL
421 #define HWRM_TF_SESSION_RESC_FREE 0x2ceUL
422 #define HWRM_TF_SESSION_RESC_FLUSH 0x2cfUL
423 #define HWRM_TF_SESSION_RESC_INFO 0x2d0UL
424 #define HWRM_TF_SESSION_HOTUP_STATE_SET 0x2d1UL
425 #define HWRM_TF_SESSION_HOTUP_STATE_GET 0x2d2UL
426 #define HWRM_TF_TBL_TYPE_GET 0x2daUL
427 #define HWRM_TF_TBL_TYPE_SET 0x2dbUL
428 #define HWRM_TF_TBL_TYPE_BULK_GET 0x2dcUL
429 #define HWRM_TF_CTXT_MEM_ALLOC 0x2e2UL
430 #define HWRM_TF_CTXT_MEM_FREE 0x2e3UL
431 #define HWRM_TF_CTXT_MEM_RGTR 0x2e4UL
432 #define HWRM_TF_CTXT_MEM_UNRGTR 0x2e5UL
433 #define HWRM_TF_EXT_EM_QCAPS 0x2e6UL
434 #define HWRM_TF_EXT_EM_OP 0x2e7UL
435 #define HWRM_TF_EXT_EM_CFG 0x2e8UL
436 #define HWRM_TF_EXT_EM_QCFG 0x2e9UL
437 #define HWRM_TF_EM_INSERT 0x2eaUL
438 #define HWRM_TF_EM_DELETE 0x2ebUL
439 #define HWRM_TF_EM_HASH_INSERT 0x2ecUL
440 #define HWRM_TF_EM_MOVE 0x2edUL
441 #define HWRM_TF_TCAM_SET 0x2f8UL
442 #define HWRM_TF_TCAM_GET 0x2f9UL
443 #define HWRM_TF_TCAM_MOVE 0x2faUL
444 #define HWRM_TF_TCAM_FREE 0x2fbUL
445 #define HWRM_TF_GLOBAL_CFG_SET 0x2fcUL
446 #define HWRM_TF_GLOBAL_CFG_GET 0x2fdUL
447 #define HWRM_TF_IF_TBL_SET 0x2feUL
448 #define HWRM_TF_IF_TBL_GET 0x2ffUL
449 #define HWRM_TFC_TBL_SCOPE_QCAPS 0x380UL
450 #define HWRM_TFC_TBL_SCOPE_ID_ALLOC 0x381UL
451 #define HWRM_TFC_TBL_SCOPE_CONFIG 0x382UL
452 #define HWRM_TFC_TBL_SCOPE_DECONFIG 0x383UL
453 #define HWRM_TFC_TBL_SCOPE_FID_ADD 0x384UL
454 #define HWRM_TFC_TBL_SCOPE_FID_REM 0x385UL
455 #define HWRM_TFC_TBL_SCOPE_POOL_ALLOC 0x386UL
456 #define HWRM_TFC_TBL_SCOPE_POOL_FREE 0x387UL
457 #define HWRM_TFC_SESSION_ID_ALLOC 0x388UL
458 #define HWRM_TFC_SESSION_FID_ADD 0x389UL
459 #define HWRM_TFC_SESSION_FID_REM 0x38aUL
460 #define HWRM_TFC_IDENT_ALLOC 0x38bUL
461 #define HWRM_TFC_IDENT_FREE 0x38cUL
462 #define HWRM_TFC_IDX_TBL_ALLOC 0x38dUL
463 #define HWRM_TFC_IDX_TBL_ALLOC_SET 0x38eUL
464 #define HWRM_TFC_IDX_TBL_SET 0x38fUL
465 #define HWRM_TFC_IDX_TBL_GET 0x390UL
466 #define HWRM_TFC_IDX_TBL_FREE 0x391UL
467 #define HWRM_TFC_GLOBAL_ID_ALLOC 0x392UL
468 #define HWRM_SV 0x400UL
469 #define HWRM_DBG_READ_DIRECT 0xff10UL
470 #define HWRM_DBG_READ_INDIRECT 0xff11UL
471 #define HWRM_DBG_WRITE_DIRECT 0xff12UL
472 #define HWRM_DBG_WRITE_INDIRECT 0xff13UL
473 #define HWRM_DBG_DUMP 0xff14UL
474 #define HWRM_DBG_ERASE_NVM 0xff15UL
475 #define HWRM_DBG_CFG 0xff16UL
476 #define HWRM_DBG_COREDUMP_LIST 0xff17UL
477 #define HWRM_DBG_COREDUMP_INITIATE 0xff18UL
478 #define HWRM_DBG_COREDUMP_RETRIEVE 0xff19UL
479 #define HWRM_DBG_FW_CLI 0xff1aUL
480 #define HWRM_DBG_I2C_CMD 0xff1bUL
481 #define HWRM_DBG_RING_INFO_GET 0xff1cUL
482 #define HWRM_DBG_CRASHDUMP_HEADER 0xff1dUL
483 #define HWRM_DBG_CRASHDUMP_ERASE 0xff1eUL
484 #define HWRM_DBG_DRV_TRACE 0xff1fUL
485 #define HWRM_DBG_QCAPS 0xff20UL
486 #define HWRM_DBG_QCFG 0xff21UL
487 #define HWRM_DBG_CRASHDUMP_MEDIUM_CFG 0xff22UL
488 #define HWRM_DBG_USEQ_ALLOC 0xff23UL
489 #define HWRM_DBG_USEQ_FREE 0xff24UL
490 #define HWRM_DBG_USEQ_FLUSH 0xff25UL
491 #define HWRM_DBG_USEQ_QCAPS 0xff26UL
492 #define HWRM_DBG_USEQ_CW_CFG 0xff27UL
493 #define HWRM_DBG_USEQ_SCHED_CFG 0xff28UL
494 #define HWRM_DBG_USEQ_RUN 0xff29UL
495 #define HWRM_DBG_USEQ_DELIVERY_REQ 0xff2aUL
496 #define HWRM_DBG_USEQ_RESP_HDR 0xff2bUL
497 #define HWRM_NVM_DEFRAG 0xffecUL
498 #define HWRM_NVM_REQ_ARBITRATION 0xffedUL
499 #define HWRM_NVM_FACTORY_DEFAULTS 0xffeeUL
500 #define HWRM_NVM_VALIDATE_OPTION 0xffefUL
501 #define HWRM_NVM_FLUSH 0xfff0UL
502 #define HWRM_NVM_GET_VARIABLE 0xfff1UL
503 #define HWRM_NVM_SET_VARIABLE 0xfff2UL
504 #define HWRM_NVM_INSTALL_UPDATE 0xfff3UL
505 #define HWRM_NVM_MODIFY 0xfff4UL
506 #define HWRM_NVM_VERIFY_UPDATE 0xfff5UL
507 #define HWRM_NVM_GET_DEV_INFO 0xfff6UL
508 #define HWRM_NVM_ERASE_DIR_ENTRY 0xfff7UL
509 #define HWRM_NVM_MOD_DIR_ENTRY 0xfff8UL
510 #define HWRM_NVM_FIND_DIR_ENTRY 0xfff9UL
511 #define HWRM_NVM_GET_DIR_ENTRIES 0xfffaUL
512 #define HWRM_NVM_GET_DIR_INFO 0xfffbUL
513 #define HWRM_NVM_RAW_DUMP 0xfffcUL
514 #define HWRM_NVM_READ 0xfffdUL
515 #define HWRM_NVM_WRITE 0xfffeUL
516 #define HWRM_NVM_RAW_WRITE_BLK 0xffffUL
517 #define HWRM_LAST HWRM_NVM_RAW_WRITE_BLK
521 /* ret_codes (size:64b/8B) */
524 #define HWRM_ERR_CODE_SUCCESS 0x0UL
525 #define HWRM_ERR_CODE_FAIL 0x1UL
526 #define HWRM_ERR_CODE_INVALID_PARAMS 0x2UL
527 #define HWRM_ERR_CODE_RESOURCE_ACCESS_DENIED 0x3UL
528 #define HWRM_ERR_CODE_RESOURCE_ALLOC_ERROR 0x4UL
529 #define HWRM_ERR_CODE_INVALID_FLAGS 0x5UL
530 #define HWRM_ERR_CODE_INVALID_ENABLES 0x6UL
531 #define HWRM_ERR_CODE_UNSUPPORTED_TLV 0x7UL
532 #define HWRM_ERR_CODE_NO_BUFFER 0x8UL
533 #define HWRM_ERR_CODE_UNSUPPORTED_OPTION_ERR 0x9UL
534 #define HWRM_ERR_CODE_HOT_RESET_PROGRESS 0xaUL
535 #define HWRM_ERR_CODE_HOT_RESET_FAIL 0xbUL
536 #define HWRM_ERR_CODE_NO_FLOW_COUNTER_DURING_ALLOC 0xcUL
537 #define HWRM_ERR_CODE_KEY_HASH_COLLISION 0xdUL
538 #define HWRM_ERR_CODE_KEY_ALREADY_EXISTS 0xeUL
539 #define HWRM_ERR_CODE_HWRM_ERROR 0xfUL
540 #define HWRM_ERR_CODE_BUSY 0x10UL
541 #define HWRM_ERR_CODE_RESOURCE_LOCKED 0x11UL
542 #define HWRM_ERR_CODE_PF_UNAVAILABLE 0x12UL
543 #define HWRM_ERR_CODE_TLV_ENCAPSULATED_RESPONSE 0x8000UL
544 #define HWRM_ERR_CODE_UNKNOWN_ERR 0xfffeUL
545 #define HWRM_ERR_CODE_CMD_NOT_SUPPORTED 0xffffUL
546 #define HWRM_ERR_CODE_LAST HWRM_ERR_CODE_CMD_NOT_SUPPORTED
550 /* hwrm_err_output (size:128b/16B) */
551 struct hwrm_err_output {
561 #define HWRM_NA_SIGNATURE ((__le32)(-1))
562 #define HWRM_MAX_REQ_LEN 128
563 #define HWRM_MAX_RESP_LEN 704
564 #define HW_HASH_INDEX_SIZE 0x80
565 #define HW_HASH_KEY_SIZE 40
566 #define HWRM_RESP_VALID_KEY 1
567 #define HWRM_TARGET_ID_BONO 0xFFF8
568 #define HWRM_TARGET_ID_KONG 0xFFF9
569 #define HWRM_TARGET_ID_APE 0xFFFA
570 #define HWRM_TARGET_ID_TOOLS 0xFFFD
571 #define HWRM_VERSION_MAJOR 1
572 #define HWRM_VERSION_MINOR 10
573 #define HWRM_VERSION_UPDATE 2
574 #define HWRM_VERSION_RSVD 118
575 #define HWRM_VERSION_STR "1.10.2.118"
577 /* hwrm_ver_get_input (size:192b/24B) */
578 struct hwrm_ver_get_input {
590 /* hwrm_ver_get_output (size:1408b/176B) */
591 struct hwrm_ver_get_output {
599 u8 hwrm_intf_rsvd_8b;
608 u8 netctrl_fw_maj_8b;
609 u8 netctrl_fw_min_8b;
610 u8 netctrl_fw_bld_8b;
611 u8 netctrl_fw_rsvd_8b;
613 #define VER_GET_RESP_DEV_CAPS_CFG_SECURE_FW_UPD_SUPPORTED 0x1UL
614 #define VER_GET_RESP_DEV_CAPS_CFG_FW_DCBX_AGENT_SUPPORTED 0x2UL
615 #define VER_GET_RESP_DEV_CAPS_CFG_SHORT_CMD_SUPPORTED 0x4UL
616 #define VER_GET_RESP_DEV_CAPS_CFG_SHORT_CMD_REQUIRED 0x8UL
617 #define VER_GET_RESP_DEV_CAPS_CFG_KONG_MB_CHNL_SUPPORTED 0x10UL
618 #define VER_GET_RESP_DEV_CAPS_CFG_FLOW_HANDLE_64BIT_SUPPORTED 0x20UL
619 #define VER_GET_RESP_DEV_CAPS_CFG_L2_FILTER_TYPES_ROCE_OR_L2_SUPPORTED 0x40UL
620 #define VER_GET_RESP_DEV_CAPS_CFG_VIRTIO_VSWITCH_OFFLOAD_SUPPORTED 0x80UL
621 #define VER_GET_RESP_DEV_CAPS_CFG_TRUSTED_VF_SUPPORTED 0x100UL
622 #define VER_GET_RESP_DEV_CAPS_CFG_FLOW_AGING_SUPPORTED 0x200UL
623 #define VER_GET_RESP_DEV_CAPS_CFG_ADV_FLOW_COUNTERS_SUPPORTED 0x400UL
624 #define VER_GET_RESP_DEV_CAPS_CFG_CFA_EEM_SUPPORTED 0x800UL
625 #define VER_GET_RESP_DEV_CAPS_CFG_CFA_ADV_FLOW_MGNT_SUPPORTED 0x1000UL
626 #define VER_GET_RESP_DEV_CAPS_CFG_CFA_TFLIB_SUPPORTED 0x2000UL
627 #define VER_GET_RESP_DEV_CAPS_CFG_CFA_TRUFLOW_SUPPORTED 0x4000UL
628 #define VER_GET_RESP_DEV_CAPS_CFG_SECURE_BOOT_CAPABLE 0x8000UL
633 char hwrm_fw_name[16];
634 char mgmt_fw_name[16];
635 char netctrl_fw_name[16];
636 char active_pkg_name[16];
637 char roce_fw_name[16];
642 u8 chip_platform_type;
643 #define VER_GET_RESP_CHIP_PLATFORM_TYPE_ASIC 0x0UL
644 #define VER_GET_RESP_CHIP_PLATFORM_TYPE_FPGA 0x1UL
645 #define VER_GET_RESP_CHIP_PLATFORM_TYPE_PALLADIUM 0x2UL
646 #define VER_GET_RESP_CHIP_PLATFORM_TYPE_LAST VER_GET_RESP_CHIP_PLATFORM_TYPE_PALLADIUM
647 __le16 max_req_win_len;
649 __le16 def_req_timeout;
651 #define VER_GET_RESP_FLAGS_DEV_NOT_RDY 0x1UL
652 #define VER_GET_RESP_FLAGS_EXT_VER_AVAIL 0x2UL
653 #define VER_GET_RESP_FLAGS_DEV_NOT_RDY_BACKING_STORE 0x4UL
656 __le16 hwrm_intf_major;
657 __le16 hwrm_intf_minor;
658 __le16 hwrm_intf_build;
659 __le16 hwrm_intf_patch;
660 __le16 hwrm_fw_major;
661 __le16 hwrm_fw_minor;
662 __le16 hwrm_fw_build;
663 __le16 hwrm_fw_patch;
664 __le16 mgmt_fw_major;
665 __le16 mgmt_fw_minor;
666 __le16 mgmt_fw_build;
667 __le16 mgmt_fw_patch;
668 __le16 netctrl_fw_major;
669 __le16 netctrl_fw_minor;
670 __le16 netctrl_fw_build;
671 __le16 netctrl_fw_patch;
672 __le16 roce_fw_major;
673 __le16 roce_fw_minor;
674 __le16 roce_fw_build;
675 __le16 roce_fw_patch;
676 __le16 max_ext_req_len;
677 __le16 max_req_timeout;
682 /* eject_cmpl (size:128b/16B) */
685 #define EJECT_CMPL_TYPE_MASK 0x3fUL
686 #define EJECT_CMPL_TYPE_SFT 0
687 #define EJECT_CMPL_TYPE_STAT_EJECT 0x1aUL
688 #define EJECT_CMPL_TYPE_LAST EJECT_CMPL_TYPE_STAT_EJECT
689 #define EJECT_CMPL_FLAGS_MASK 0xffc0UL
690 #define EJECT_CMPL_FLAGS_SFT 6
691 #define EJECT_CMPL_FLAGS_ERROR 0x40UL
695 #define EJECT_CMPL_V 0x1UL
696 #define EJECT_CMPL_ERRORS_MASK 0xfffeUL
697 #define EJECT_CMPL_ERRORS_SFT 1
698 #define EJECT_CMPL_ERRORS_BUFFER_ERROR_MASK 0xeUL
699 #define EJECT_CMPL_ERRORS_BUFFER_ERROR_SFT 1
700 #define EJECT_CMPL_ERRORS_BUFFER_ERROR_NO_BUFFER (0x0UL << 1)
701 #define EJECT_CMPL_ERRORS_BUFFER_ERROR_DID_NOT_FIT (0x1UL << 1)
702 #define EJECT_CMPL_ERRORS_BUFFER_ERROR_BAD_FORMAT (0x3UL << 1)
703 #define EJECT_CMPL_ERRORS_BUFFER_ERROR_FLUSH (0x5UL << 1)
704 #define EJECT_CMPL_ERRORS_BUFFER_ERROR_LAST EJECT_CMPL_ERRORS_BUFFER_ERROR_FLUSH
709 /* hwrm_cmpl (size:128b/16B) */
712 #define CMPL_TYPE_MASK 0x3fUL
713 #define CMPL_TYPE_SFT 0
714 #define CMPL_TYPE_HWRM_DONE 0x20UL
715 #define CMPL_TYPE_LAST CMPL_TYPE_HWRM_DONE
723 /* hwrm_fwd_req_cmpl (size:128b/16B) */
724 struct hwrm_fwd_req_cmpl {
726 #define FWD_REQ_CMPL_TYPE_MASK 0x3fUL
727 #define FWD_REQ_CMPL_TYPE_SFT 0
728 #define FWD_REQ_CMPL_TYPE_HWRM_FWD_REQ 0x22UL
729 #define FWD_REQ_CMPL_TYPE_LAST FWD_REQ_CMPL_TYPE_HWRM_FWD_REQ
730 #define FWD_REQ_CMPL_REQ_LEN_MASK 0xffc0UL
731 #define FWD_REQ_CMPL_REQ_LEN_SFT 6
734 __le32 req_buf_addr_v[2];
735 #define FWD_REQ_CMPL_V 0x1UL
736 #define FWD_REQ_CMPL_REQ_BUF_ADDR_MASK 0xfffffffeUL
737 #define FWD_REQ_CMPL_REQ_BUF_ADDR_SFT 1
740 /* hwrm_fwd_resp_cmpl (size:128b/16B) */
741 struct hwrm_fwd_resp_cmpl {
743 #define FWD_RESP_CMPL_TYPE_MASK 0x3fUL
744 #define FWD_RESP_CMPL_TYPE_SFT 0
745 #define FWD_RESP_CMPL_TYPE_HWRM_FWD_RESP 0x24UL
746 #define FWD_RESP_CMPL_TYPE_LAST FWD_RESP_CMPL_TYPE_HWRM_FWD_RESP
750 __le32 resp_buf_addr_v[2];
751 #define FWD_RESP_CMPL_V 0x1UL
752 #define FWD_RESP_CMPL_RESP_BUF_ADDR_MASK 0xfffffffeUL
753 #define FWD_RESP_CMPL_RESP_BUF_ADDR_SFT 1
756 /* hwrm_async_event_cmpl (size:128b/16B) */
757 struct hwrm_async_event_cmpl {
759 #define ASYNC_EVENT_CMPL_TYPE_MASK 0x3fUL
760 #define ASYNC_EVENT_CMPL_TYPE_SFT 0
761 #define ASYNC_EVENT_CMPL_TYPE_HWRM_ASYNC_EVENT 0x2eUL
762 #define ASYNC_EVENT_CMPL_TYPE_LAST ASYNC_EVENT_CMPL_TYPE_HWRM_ASYNC_EVENT
764 #define ASYNC_EVENT_CMPL_EVENT_ID_LINK_STATUS_CHANGE 0x0UL
765 #define ASYNC_EVENT_CMPL_EVENT_ID_LINK_MTU_CHANGE 0x1UL
766 #define ASYNC_EVENT_CMPL_EVENT_ID_LINK_SPEED_CHANGE 0x2UL
767 #define ASYNC_EVENT_CMPL_EVENT_ID_DCB_CONFIG_CHANGE 0x3UL
768 #define ASYNC_EVENT_CMPL_EVENT_ID_PORT_CONN_NOT_ALLOWED 0x4UL
769 #define ASYNC_EVENT_CMPL_EVENT_ID_LINK_SPEED_CFG_NOT_ALLOWED 0x5UL
770 #define ASYNC_EVENT_CMPL_EVENT_ID_LINK_SPEED_CFG_CHANGE 0x6UL
771 #define ASYNC_EVENT_CMPL_EVENT_ID_PORT_PHY_CFG_CHANGE 0x7UL
772 #define ASYNC_EVENT_CMPL_EVENT_ID_RESET_NOTIFY 0x8UL
773 #define ASYNC_EVENT_CMPL_EVENT_ID_ERROR_RECOVERY 0x9UL
774 #define ASYNC_EVENT_CMPL_EVENT_ID_RING_MONITOR_MSG 0xaUL
775 #define ASYNC_EVENT_CMPL_EVENT_ID_FUNC_DRVR_UNLOAD 0x10UL
776 #define ASYNC_EVENT_CMPL_EVENT_ID_FUNC_DRVR_LOAD 0x11UL
777 #define ASYNC_EVENT_CMPL_EVENT_ID_FUNC_FLR_PROC_CMPLT 0x12UL
778 #define ASYNC_EVENT_CMPL_EVENT_ID_PF_DRVR_UNLOAD 0x20UL
779 #define ASYNC_EVENT_CMPL_EVENT_ID_PF_DRVR_LOAD 0x21UL
780 #define ASYNC_EVENT_CMPL_EVENT_ID_VF_FLR 0x30UL
781 #define ASYNC_EVENT_CMPL_EVENT_ID_VF_MAC_ADDR_CHANGE 0x31UL
782 #define ASYNC_EVENT_CMPL_EVENT_ID_PF_VF_COMM_STATUS_CHANGE 0x32UL
783 #define ASYNC_EVENT_CMPL_EVENT_ID_VF_CFG_CHANGE 0x33UL
784 #define ASYNC_EVENT_CMPL_EVENT_ID_LLFC_PFC_CHANGE 0x34UL
785 #define ASYNC_EVENT_CMPL_EVENT_ID_DEFAULT_VNIC_CHANGE 0x35UL
786 #define ASYNC_EVENT_CMPL_EVENT_ID_HW_FLOW_AGED 0x36UL
787 #define ASYNC_EVENT_CMPL_EVENT_ID_DEBUG_NOTIFICATION 0x37UL
788 #define ASYNC_EVENT_CMPL_EVENT_ID_EEM_CACHE_FLUSH_REQ 0x38UL
789 #define ASYNC_EVENT_CMPL_EVENT_ID_EEM_CACHE_FLUSH_DONE 0x39UL
790 #define ASYNC_EVENT_CMPL_EVENT_ID_TCP_FLAG_ACTION_CHANGE 0x3aUL
791 #define ASYNC_EVENT_CMPL_EVENT_ID_EEM_FLOW_ACTIVE 0x3bUL
792 #define ASYNC_EVENT_CMPL_EVENT_ID_EEM_CFG_CHANGE 0x3cUL
793 #define ASYNC_EVENT_CMPL_EVENT_ID_TFLIB_DEFAULT_VNIC_CHANGE 0x3dUL
794 #define ASYNC_EVENT_CMPL_EVENT_ID_TFLIB_LINK_STATUS_CHANGE 0x3eUL
795 #define ASYNC_EVENT_CMPL_EVENT_ID_QUIESCE_DONE 0x3fUL
796 #define ASYNC_EVENT_CMPL_EVENT_ID_DEFERRED_RESPONSE 0x40UL
797 #define ASYNC_EVENT_CMPL_EVENT_ID_PFC_WATCHDOG_CFG_CHANGE 0x41UL
798 #define ASYNC_EVENT_CMPL_EVENT_ID_ECHO_REQUEST 0x42UL
799 #define ASYNC_EVENT_CMPL_EVENT_ID_PHC_UPDATE 0x43UL
800 #define ASYNC_EVENT_CMPL_EVENT_ID_PPS_TIMESTAMP 0x44UL
801 #define ASYNC_EVENT_CMPL_EVENT_ID_ERROR_REPORT 0x45UL
802 #define ASYNC_EVENT_CMPL_EVENT_ID_DOORBELL_PACING_THRESHOLD 0x46UL
803 #define ASYNC_EVENT_CMPL_EVENT_ID_RSS_CHANGE 0x47UL
804 #define ASYNC_EVENT_CMPL_EVENT_ID_DOORBELL_PACING_NQ_UPDATE 0x48UL
805 #define ASYNC_EVENT_CMPL_EVENT_ID_MAX_RGTR_EVENT_ID 0x49UL
806 #define ASYNC_EVENT_CMPL_EVENT_ID_FW_TRACE_MSG 0xfeUL
807 #define ASYNC_EVENT_CMPL_EVENT_ID_HWRM_ERROR 0xffUL
808 #define ASYNC_EVENT_CMPL_EVENT_ID_LAST ASYNC_EVENT_CMPL_EVENT_ID_HWRM_ERROR
811 #define ASYNC_EVENT_CMPL_V 0x1UL
812 #define ASYNC_EVENT_CMPL_OPAQUE_MASK 0xfeUL
813 #define ASYNC_EVENT_CMPL_OPAQUE_SFT 1
819 /* hwrm_async_event_cmpl_link_status_change (size:128b/16B) */
820 struct hwrm_async_event_cmpl_link_status_change {
822 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_TYPE_MASK 0x3fUL
823 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_TYPE_SFT 0
824 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_TYPE_HWRM_ASYNC_EVENT 0x2eUL
825 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_TYPE_LAST ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_TYPE_HWRM_ASYNC_EVENT
827 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_ID_LINK_STATUS_CHANGE 0x0UL
828 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_ID_LAST ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_ID_LINK_STATUS_CHANGE
831 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_V 0x1UL
832 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_OPAQUE_MASK 0xfeUL
833 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_OPAQUE_SFT 1
837 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_DATA1_LINK_CHANGE 0x1UL
838 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_DATA1_LINK_CHANGE_DOWN 0x0UL
839 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_DATA1_LINK_CHANGE_UP 0x1UL
840 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_DATA1_LINK_CHANGE_LAST ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_DATA1_LINK_CHANGE_UP
841 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_DATA1_PORT_MASK 0xeUL
842 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_DATA1_PORT_SFT 1
843 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_DATA1_PORT_ID_MASK 0xffff0UL
844 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_DATA1_PORT_ID_SFT 4
845 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_DATA1_PF_ID_MASK 0xff00000UL
846 #define ASYNC_EVENT_CMPL_LINK_STATUS_CHANGE_EVENT_DATA1_PF_ID_SFT 20
849 /* hwrm_async_event_cmpl_port_conn_not_allowed (size:128b/16B) */
850 struct hwrm_async_event_cmpl_port_conn_not_allowed {
852 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_TYPE_MASK 0x3fUL
853 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_TYPE_SFT 0
854 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_TYPE_HWRM_ASYNC_EVENT 0x2eUL
855 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_TYPE_LAST ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_TYPE_HWRM_ASYNC_EVENT
857 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_ID_PORT_CONN_NOT_ALLOWED 0x4UL
858 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_ID_LAST ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_ID_PORT_CONN_NOT_ALLOWED
861 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_V 0x1UL
862 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_OPAQUE_MASK 0xfeUL
863 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_OPAQUE_SFT 1
867 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_DATA1_PORT_ID_MASK 0xffffUL
868 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_DATA1_PORT_ID_SFT 0
869 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_DATA1_ENFORCEMENT_POLICY_MASK 0xff0000UL
870 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_DATA1_ENFORCEMENT_POLICY_SFT 16
871 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_DATA1_ENFORCEMENT_POLICY_NONE (0x0UL << 16)
872 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_DATA1_ENFORCEMENT_POLICY_DISABLETX (0x1UL << 16)
873 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_DATA1_ENFORCEMENT_POLICY_WARNINGMSG (0x2UL << 16)
874 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_DATA1_ENFORCEMENT_POLICY_PWRDOWN (0x3UL << 16)
875 #define ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_DATA1_ENFORCEMENT_POLICY_LAST ASYNC_EVENT_CMPL_PORT_CONN_NOT_ALLOWED_EVENT_DATA1_ENFORCEMENT_POLICY_PWRDOWN
878 /* hwrm_async_event_cmpl_link_speed_cfg_change (size:128b/16B) */
879 struct hwrm_async_event_cmpl_link_speed_cfg_change {
881 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_TYPE_MASK 0x3fUL
882 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_TYPE_SFT 0
883 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_TYPE_HWRM_ASYNC_EVENT 0x2eUL
884 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_TYPE_LAST ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_TYPE_HWRM_ASYNC_EVENT
886 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_EVENT_ID_LINK_SPEED_CFG_CHANGE 0x6UL
887 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_EVENT_ID_LAST ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_EVENT_ID_LINK_SPEED_CFG_CHANGE
890 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_V 0x1UL
891 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_OPAQUE_MASK 0xfeUL
892 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_OPAQUE_SFT 1
896 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_EVENT_DATA1_PORT_ID_MASK 0xffffUL
897 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_EVENT_DATA1_PORT_ID_SFT 0
898 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_EVENT_DATA1_SUPPORTED_LINK_SPEEDS_CHANGE 0x10000UL
899 #define ASYNC_EVENT_CMPL_LINK_SPEED_CFG_CHANGE_EVENT_DATA1_ILLEGAL_LINK_SPEED_CFG 0x20000UL
902 /* hwrm_async_event_cmpl_reset_notify (size:128b/16B) */
903 struct hwrm_async_event_cmpl_reset_notify {
905 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_TYPE_MASK 0x3fUL
906 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_TYPE_SFT 0
907 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_TYPE_HWRM_ASYNC_EVENT 0x2eUL
908 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_TYPE_LAST ASYNC_EVENT_CMPL_RESET_NOTIFY_TYPE_HWRM_ASYNC_EVENT
910 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_ID_RESET_NOTIFY 0x8UL
911 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_ID_LAST ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_ID_RESET_NOTIFY
913 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA2_FW_STATUS_CODE_MASK 0xffffUL
914 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA2_FW_STATUS_CODE_SFT 0
916 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_V 0x1UL
917 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_OPAQUE_MASK 0xfeUL
918 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_OPAQUE_SFT 1
922 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_DRIVER_ACTION_MASK 0xffUL
923 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_DRIVER_ACTION_SFT 0
924 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_DRIVER_ACTION_DRIVER_STOP_TX_QUEUE 0x1UL
925 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_DRIVER_ACTION_DRIVER_IFDOWN 0x2UL
926 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_DRIVER_ACTION_LAST ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_DRIVER_ACTION_DRIVER_IFDOWN
927 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_REASON_CODE_MASK 0xff00UL
928 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_REASON_CODE_SFT 8
929 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_REASON_CODE_MANAGEMENT_RESET_REQUEST (0x1UL << 8)
930 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_REASON_CODE_FW_EXCEPTION_FATAL (0x2UL << 8)
931 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_REASON_CODE_FW_EXCEPTION_NON_FATAL (0x3UL << 8)
932 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_REASON_CODE_FAST_RESET (0x4UL << 8)
933 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_REASON_CODE_FW_ACTIVATION (0x5UL << 8)
934 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_REASON_CODE_LAST ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_REASON_CODE_FW_ACTIVATION
935 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_DELAY_IN_100MS_TICKS_MASK 0xffff0000UL
936 #define ASYNC_EVENT_CMPL_RESET_NOTIFY_EVENT_DATA1_DELAY_IN_100MS_TICKS_SFT 16
939 /* hwrm_async_event_cmpl_error_recovery (size:128b/16B) */
940 struct hwrm_async_event_cmpl_error_recovery {
942 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_TYPE_MASK 0x3fUL
943 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_TYPE_SFT 0
944 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_TYPE_HWRM_ASYNC_EVENT 0x2eUL
945 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_RECOVERY_TYPE_HWRM_ASYNC_EVENT
947 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_EVENT_ID_ERROR_RECOVERY 0x9UL
948 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_EVENT_ID_LAST ASYNC_EVENT_CMPL_ERROR_RECOVERY_EVENT_ID_ERROR_RECOVERY
951 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_V 0x1UL
952 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_OPAQUE_MASK 0xfeUL
953 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_OPAQUE_SFT 1
957 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_EVENT_DATA1_FLAGS_MASK 0xffUL
958 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_EVENT_DATA1_FLAGS_SFT 0
959 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_EVENT_DATA1_FLAGS_MASTER_FUNC 0x1UL
960 #define ASYNC_EVENT_CMPL_ERROR_RECOVERY_EVENT_DATA1_FLAGS_RECOVERY_ENABLED 0x2UL
963 /* hwrm_async_event_cmpl_ring_monitor_msg (size:128b/16B) */
964 struct hwrm_async_event_cmpl_ring_monitor_msg {
966 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_TYPE_MASK 0x3fUL
967 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_TYPE_SFT 0
968 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_TYPE_HWRM_ASYNC_EVENT 0x2eUL
969 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_TYPE_LAST ASYNC_EVENT_CMPL_RING_MONITOR_MSG_TYPE_HWRM_ASYNC_EVENT
971 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_EVENT_ID_RING_MONITOR_MSG 0xaUL
972 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_EVENT_ID_LAST ASYNC_EVENT_CMPL_RING_MONITOR_MSG_EVENT_ID_RING_MONITOR_MSG
974 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_EVENT_DATA2_DISABLE_RING_TYPE_MASK 0xffUL
975 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_EVENT_DATA2_DISABLE_RING_TYPE_SFT 0
976 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_EVENT_DATA2_DISABLE_RING_TYPE_TX 0x0UL
977 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_EVENT_DATA2_DISABLE_RING_TYPE_RX 0x1UL
978 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_EVENT_DATA2_DISABLE_RING_TYPE_CMPL 0x2UL
979 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_EVENT_DATA2_DISABLE_RING_TYPE_LAST ASYNC_EVENT_CMPL_RING_MONITOR_MSG_EVENT_DATA2_DISABLE_RING_TYPE_CMPL
981 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_V 0x1UL
982 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_OPAQUE_MASK 0xfeUL
983 #define ASYNC_EVENT_CMPL_RING_MONITOR_MSG_OPAQUE_SFT 1
989 /* hwrm_async_event_cmpl_vf_cfg_change (size:128b/16B) */
990 struct hwrm_async_event_cmpl_vf_cfg_change {
992 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_TYPE_MASK 0x3fUL
993 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_TYPE_SFT 0
994 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_TYPE_HWRM_ASYNC_EVENT 0x2eUL
995 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_TYPE_LAST ASYNC_EVENT_CMPL_VF_CFG_CHANGE_TYPE_HWRM_ASYNC_EVENT
997 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_EVENT_ID_VF_CFG_CHANGE 0x33UL
998 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_EVENT_ID_LAST ASYNC_EVENT_CMPL_VF_CFG_CHANGE_EVENT_ID_VF_CFG_CHANGE
1000 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_EVENT_DATA2_VF_ID_MASK 0xffffUL
1001 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_EVENT_DATA2_VF_ID_SFT 0
1003 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_V 0x1UL
1004 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_OPAQUE_MASK 0xfeUL
1005 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_OPAQUE_SFT 1
1007 __le16 timestamp_hi;
1009 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_EVENT_DATA1_MTU_CHANGE 0x1UL
1010 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_EVENT_DATA1_MRU_CHANGE 0x2UL
1011 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_EVENT_DATA1_DFLT_MAC_ADDR_CHANGE 0x4UL
1012 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_EVENT_DATA1_DFLT_VLAN_CHANGE 0x8UL
1013 #define ASYNC_EVENT_CMPL_VF_CFG_CHANGE_EVENT_DATA1_TRUSTED_VF_CFG_CHANGE 0x10UL
1016 /* hwrm_async_event_cmpl_default_vnic_change (size:128b/16B) */
1017 struct hwrm_async_event_cmpl_default_vnic_change {
1019 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_TYPE_MASK 0x3fUL
1020 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_TYPE_SFT 0
1021 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1022 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_TYPE_LAST ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_TYPE_HWRM_ASYNC_EVENT
1023 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_UNUSED1_MASK 0xffc0UL
1024 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_UNUSED1_SFT 6
1026 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_ID_ALLOC_FREE_NOTIFICATION 0x35UL
1027 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_ID_LAST ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_ID_ALLOC_FREE_NOTIFICATION
1030 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_V 0x1UL
1031 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_OPAQUE_MASK 0xfeUL
1032 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_OPAQUE_SFT 1
1034 __le16 timestamp_hi;
1036 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_DATA1_DEF_VNIC_STATE_MASK 0x3UL
1037 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_DATA1_DEF_VNIC_STATE_SFT 0
1038 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_DATA1_DEF_VNIC_STATE_DEF_VNIC_ALLOC 0x1UL
1039 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_DATA1_DEF_VNIC_STATE_DEF_VNIC_FREE 0x2UL
1040 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_DATA1_DEF_VNIC_STATE_LAST ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_DATA1_DEF_VNIC_STATE_DEF_VNIC_FREE
1041 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_DATA1_PF_ID_MASK 0x3fcUL
1042 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_DATA1_PF_ID_SFT 2
1043 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_DATA1_VF_ID_MASK 0x3fffc00UL
1044 #define ASYNC_EVENT_CMPL_DEFAULT_VNIC_CHANGE_EVENT_DATA1_VF_ID_SFT 10
1047 /* hwrm_async_event_cmpl_hw_flow_aged (size:128b/16B) */
1048 struct hwrm_async_event_cmpl_hw_flow_aged {
1050 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_TYPE_MASK 0x3fUL
1051 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_TYPE_SFT 0
1052 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1053 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_TYPE_LAST ASYNC_EVENT_CMPL_HW_FLOW_AGED_TYPE_HWRM_ASYNC_EVENT
1055 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_EVENT_ID_HW_FLOW_AGED 0x36UL
1056 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_EVENT_ID_LAST ASYNC_EVENT_CMPL_HW_FLOW_AGED_EVENT_ID_HW_FLOW_AGED
1059 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_V 0x1UL
1060 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_OPAQUE_MASK 0xfeUL
1061 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_OPAQUE_SFT 1
1063 __le16 timestamp_hi;
1065 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_EVENT_DATA1_FLOW_ID_MASK 0x7fffffffUL
1066 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_EVENT_DATA1_FLOW_ID_SFT 0
1067 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_EVENT_DATA1_FLOW_DIRECTION 0x80000000UL
1068 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_EVENT_DATA1_FLOW_DIRECTION_RX (0x0UL << 31)
1069 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_EVENT_DATA1_FLOW_DIRECTION_TX (0x1UL << 31)
1070 #define ASYNC_EVENT_CMPL_HW_FLOW_AGED_EVENT_DATA1_FLOW_DIRECTION_LAST ASYNC_EVENT_CMPL_HW_FLOW_AGED_EVENT_DATA1_FLOW_DIRECTION_TX
1073 /* hwrm_async_event_cmpl_eem_cache_flush_req (size:128b/16B) */
1074 struct hwrm_async_event_cmpl_eem_cache_flush_req {
1076 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_REQ_TYPE_MASK 0x3fUL
1077 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_REQ_TYPE_SFT 0
1078 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_REQ_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1079 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_REQ_TYPE_LAST ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_REQ_TYPE_HWRM_ASYNC_EVENT
1081 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_REQ_EVENT_ID_EEM_CACHE_FLUSH_REQ 0x38UL
1082 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_REQ_EVENT_ID_LAST ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_REQ_EVENT_ID_EEM_CACHE_FLUSH_REQ
1085 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_REQ_V 0x1UL
1086 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_REQ_OPAQUE_MASK 0xfeUL
1087 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_REQ_OPAQUE_SFT 1
1089 __le16 timestamp_hi;
1093 /* hwrm_async_event_cmpl_eem_cache_flush_done (size:128b/16B) */
1094 struct hwrm_async_event_cmpl_eem_cache_flush_done {
1096 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_TYPE_MASK 0x3fUL
1097 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_TYPE_SFT 0
1098 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1099 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_TYPE_LAST ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_TYPE_HWRM_ASYNC_EVENT
1101 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_EVENT_ID_EEM_CACHE_FLUSH_DONE 0x39UL
1102 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_EVENT_ID_LAST ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_EVENT_ID_EEM_CACHE_FLUSH_DONE
1105 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_V 0x1UL
1106 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_OPAQUE_MASK 0xfeUL
1107 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_OPAQUE_SFT 1
1109 __le16 timestamp_hi;
1111 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_EVENT_DATA1_FID_MASK 0xffffUL
1112 #define ASYNC_EVENT_CMPL_EEM_CACHE_FLUSH_DONE_EVENT_DATA1_FID_SFT 0
1115 /* hwrm_async_event_cmpl_deferred_response (size:128b/16B) */
1116 struct hwrm_async_event_cmpl_deferred_response {
1118 #define ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_TYPE_MASK 0x3fUL
1119 #define ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_TYPE_SFT 0
1120 #define ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1121 #define ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_TYPE_LAST ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_TYPE_HWRM_ASYNC_EVENT
1123 #define ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_EVENT_ID_DEFERRED_RESPONSE 0x40UL
1124 #define ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_EVENT_ID_LAST ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_EVENT_ID_DEFERRED_RESPONSE
1126 #define ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_EVENT_DATA2_SEQ_ID_MASK 0xffffUL
1127 #define ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_EVENT_DATA2_SEQ_ID_SFT 0
1129 #define ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_V 0x1UL
1130 #define ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_OPAQUE_MASK 0xfeUL
1131 #define ASYNC_EVENT_CMPL_DEFERRED_RESPONSE_OPAQUE_SFT 1
1133 __le16 timestamp_hi;
1137 /* hwrm_async_event_cmpl_echo_request (size:128b/16B) */
1138 struct hwrm_async_event_cmpl_echo_request {
1140 #define ASYNC_EVENT_CMPL_ECHO_REQUEST_TYPE_MASK 0x3fUL
1141 #define ASYNC_EVENT_CMPL_ECHO_REQUEST_TYPE_SFT 0
1142 #define ASYNC_EVENT_CMPL_ECHO_REQUEST_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1143 #define ASYNC_EVENT_CMPL_ECHO_REQUEST_TYPE_LAST ASYNC_EVENT_CMPL_ECHO_REQUEST_TYPE_HWRM_ASYNC_EVENT
1145 #define ASYNC_EVENT_CMPL_ECHO_REQUEST_EVENT_ID_ECHO_REQUEST 0x42UL
1146 #define ASYNC_EVENT_CMPL_ECHO_REQUEST_EVENT_ID_LAST ASYNC_EVENT_CMPL_ECHO_REQUEST_EVENT_ID_ECHO_REQUEST
1149 #define ASYNC_EVENT_CMPL_ECHO_REQUEST_V 0x1UL
1150 #define ASYNC_EVENT_CMPL_ECHO_REQUEST_OPAQUE_MASK 0xfeUL
1151 #define ASYNC_EVENT_CMPL_ECHO_REQUEST_OPAQUE_SFT 1
1153 __le16 timestamp_hi;
1157 /* hwrm_async_event_cmpl_phc_update (size:128b/16B) */
1158 struct hwrm_async_event_cmpl_phc_update {
1160 #define ASYNC_EVENT_CMPL_PHC_UPDATE_TYPE_MASK 0x3fUL
1161 #define ASYNC_EVENT_CMPL_PHC_UPDATE_TYPE_SFT 0
1162 #define ASYNC_EVENT_CMPL_PHC_UPDATE_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1163 #define ASYNC_EVENT_CMPL_PHC_UPDATE_TYPE_LAST ASYNC_EVENT_CMPL_PHC_UPDATE_TYPE_HWRM_ASYNC_EVENT
1165 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_ID_PHC_UPDATE 0x43UL
1166 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_ID_LAST ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_ID_PHC_UPDATE
1168 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA2_PHC_MASTER_FID_MASK 0xffffUL
1169 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA2_PHC_MASTER_FID_SFT 0
1170 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA2_PHC_SEC_FID_MASK 0xffff0000UL
1171 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA2_PHC_SEC_FID_SFT 16
1173 #define ASYNC_EVENT_CMPL_PHC_UPDATE_V 0x1UL
1174 #define ASYNC_EVENT_CMPL_PHC_UPDATE_OPAQUE_MASK 0xfeUL
1175 #define ASYNC_EVENT_CMPL_PHC_UPDATE_OPAQUE_SFT 1
1177 __le16 timestamp_hi;
1179 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA1_FLAGS_MASK 0xfUL
1180 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA1_FLAGS_SFT 0
1181 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA1_FLAGS_PHC_MASTER 0x1UL
1182 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA1_FLAGS_PHC_SECONDARY 0x2UL
1183 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA1_FLAGS_PHC_FAILOVER 0x3UL
1184 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA1_FLAGS_PHC_RTC_UPDATE 0x4UL
1185 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA1_FLAGS_LAST ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA1_FLAGS_PHC_RTC_UPDATE
1186 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA1_PHC_TIME_MSB_MASK 0xffff0UL
1187 #define ASYNC_EVENT_CMPL_PHC_UPDATE_EVENT_DATA1_PHC_TIME_MSB_SFT 4
1190 /* hwrm_async_event_cmpl_pps_timestamp (size:128b/16B) */
1191 struct hwrm_async_event_cmpl_pps_timestamp {
1193 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_TYPE_MASK 0x3fUL
1194 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_TYPE_SFT 0
1195 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1196 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_TYPE_LAST ASYNC_EVENT_CMPL_PPS_TIMESTAMP_TYPE_HWRM_ASYNC_EVENT
1198 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_ID_PPS_TIMESTAMP 0x44UL
1199 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_ID_LAST ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_ID_PPS_TIMESTAMP
1201 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_DATA2_EVENT_TYPE 0x1UL
1202 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_DATA2_EVENT_TYPE_INTERNAL 0x0UL
1203 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_DATA2_EVENT_TYPE_EXTERNAL 0x1UL
1204 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_DATA2_EVENT_TYPE_LAST ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_DATA2_EVENT_TYPE_EXTERNAL
1205 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_DATA2_PIN_NUMBER_MASK 0xeUL
1206 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_DATA2_PIN_NUMBER_SFT 1
1207 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_DATA2_PPS_TIMESTAMP_UPPER_MASK 0xffff0UL
1208 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_DATA2_PPS_TIMESTAMP_UPPER_SFT 4
1210 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_V 0x1UL
1211 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_OPAQUE_MASK 0xfeUL
1212 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_OPAQUE_SFT 1
1214 __le16 timestamp_hi;
1216 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_DATA1_PPS_TIMESTAMP_LOWER_MASK 0xffffffffUL
1217 #define ASYNC_EVENT_CMPL_PPS_TIMESTAMP_EVENT_DATA1_PPS_TIMESTAMP_LOWER_SFT 0
1220 /* hwrm_async_event_cmpl_error_report (size:128b/16B) */
1221 struct hwrm_async_event_cmpl_error_report {
1223 #define ASYNC_EVENT_CMPL_ERROR_REPORT_TYPE_MASK 0x3fUL
1224 #define ASYNC_EVENT_CMPL_ERROR_REPORT_TYPE_SFT 0
1225 #define ASYNC_EVENT_CMPL_ERROR_REPORT_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1226 #define ASYNC_EVENT_CMPL_ERROR_REPORT_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_TYPE_HWRM_ASYNC_EVENT
1228 #define ASYNC_EVENT_CMPL_ERROR_REPORT_EVENT_ID_ERROR_REPORT 0x45UL
1229 #define ASYNC_EVENT_CMPL_ERROR_REPORT_EVENT_ID_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_EVENT_ID_ERROR_REPORT
1232 #define ASYNC_EVENT_CMPL_ERROR_REPORT_V 0x1UL
1233 #define ASYNC_EVENT_CMPL_ERROR_REPORT_OPAQUE_MASK 0xfeUL
1234 #define ASYNC_EVENT_CMPL_ERROR_REPORT_OPAQUE_SFT 1
1236 __le16 timestamp_hi;
1238 #define ASYNC_EVENT_CMPL_ERROR_REPORT_EVENT_DATA1_ERROR_TYPE_MASK 0xffUL
1239 #define ASYNC_EVENT_CMPL_ERROR_REPORT_EVENT_DATA1_ERROR_TYPE_SFT 0
1242 /* hwrm_async_event_cmpl_hwrm_error (size:128b/16B) */
1243 struct hwrm_async_event_cmpl_hwrm_error {
1245 #define ASYNC_EVENT_CMPL_HWRM_ERROR_TYPE_MASK 0x3fUL
1246 #define ASYNC_EVENT_CMPL_HWRM_ERROR_TYPE_SFT 0
1247 #define ASYNC_EVENT_CMPL_HWRM_ERROR_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1248 #define ASYNC_EVENT_CMPL_HWRM_ERROR_TYPE_LAST ASYNC_EVENT_CMPL_HWRM_ERROR_TYPE_HWRM_ASYNC_EVENT
1250 #define ASYNC_EVENT_CMPL_HWRM_ERROR_EVENT_ID_HWRM_ERROR 0xffUL
1251 #define ASYNC_EVENT_CMPL_HWRM_ERROR_EVENT_ID_LAST ASYNC_EVENT_CMPL_HWRM_ERROR_EVENT_ID_HWRM_ERROR
1253 #define ASYNC_EVENT_CMPL_HWRM_ERROR_EVENT_DATA2_SEVERITY_MASK 0xffUL
1254 #define ASYNC_EVENT_CMPL_HWRM_ERROR_EVENT_DATA2_SEVERITY_SFT 0
1255 #define ASYNC_EVENT_CMPL_HWRM_ERROR_EVENT_DATA2_SEVERITY_WARNING 0x0UL
1256 #define ASYNC_EVENT_CMPL_HWRM_ERROR_EVENT_DATA2_SEVERITY_NONFATAL 0x1UL
1257 #define ASYNC_EVENT_CMPL_HWRM_ERROR_EVENT_DATA2_SEVERITY_FATAL 0x2UL
1258 #define ASYNC_EVENT_CMPL_HWRM_ERROR_EVENT_DATA2_SEVERITY_LAST ASYNC_EVENT_CMPL_HWRM_ERROR_EVENT_DATA2_SEVERITY_FATAL
1260 #define ASYNC_EVENT_CMPL_HWRM_ERROR_V 0x1UL
1261 #define ASYNC_EVENT_CMPL_HWRM_ERROR_OPAQUE_MASK 0xfeUL
1262 #define ASYNC_EVENT_CMPL_HWRM_ERROR_OPAQUE_SFT 1
1264 __le16 timestamp_hi;
1266 #define ASYNC_EVENT_CMPL_HWRM_ERROR_EVENT_DATA1_TIMESTAMP 0x1UL
1269 /* hwrm_async_event_cmpl_error_report_base (size:128b/16B) */
1270 struct hwrm_async_event_cmpl_error_report_base {
1272 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_TYPE_MASK 0x3fUL
1273 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_TYPE_SFT 0
1274 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1275 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_TYPE_HWRM_ASYNC_EVENT
1277 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_ID_ERROR_REPORT 0x45UL
1278 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_ID_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_ID_ERROR_REPORT
1281 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_V 0x1UL
1282 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_OPAQUE_MASK 0xfeUL
1283 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_OPAQUE_SFT 1
1285 __le16 timestamp_hi;
1287 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_DATA1_ERROR_TYPE_MASK 0xffUL
1288 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_DATA1_ERROR_TYPE_SFT 0
1289 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_DATA1_ERROR_TYPE_RESERVED 0x0UL
1290 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_DATA1_ERROR_TYPE_PAUSE_STORM 0x1UL
1291 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_DATA1_ERROR_TYPE_INVALID_SIGNAL 0x2UL
1292 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_DATA1_ERROR_TYPE_NVM 0x3UL
1293 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_DATA1_ERROR_TYPE_DOORBELL_DROP_THRESHOLD 0x4UL
1294 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_DATA1_ERROR_TYPE_THERMAL_THRESHOLD 0x5UL
1295 #define ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_DATA1_ERROR_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_BASE_EVENT_DATA1_ERROR_TYPE_THERMAL_THRESHOLD
1298 /* hwrm_async_event_cmpl_error_report_pause_storm (size:128b/16B) */
1299 struct hwrm_async_event_cmpl_error_report_pause_storm {
1301 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_TYPE_MASK 0x3fUL
1302 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_TYPE_SFT 0
1303 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1304 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_TYPE_HWRM_ASYNC_EVENT
1306 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_EVENT_ID_ERROR_REPORT 0x45UL
1307 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_EVENT_ID_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_EVENT_ID_ERROR_REPORT
1310 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_V 0x1UL
1311 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_OPAQUE_MASK 0xfeUL
1312 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_OPAQUE_SFT 1
1314 __le16 timestamp_hi;
1316 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_EVENT_DATA1_ERROR_TYPE_MASK 0xffUL
1317 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_EVENT_DATA1_ERROR_TYPE_SFT 0
1318 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_EVENT_DATA1_ERROR_TYPE_PAUSE_STORM 0x1UL
1319 #define ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_EVENT_DATA1_ERROR_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_PAUSE_STORM_EVENT_DATA1_ERROR_TYPE_PAUSE_STORM
1322 /* hwrm_async_event_cmpl_error_report_invalid_signal (size:128b/16B) */
1323 struct hwrm_async_event_cmpl_error_report_invalid_signal {
1325 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_TYPE_MASK 0x3fUL
1326 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_TYPE_SFT 0
1327 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1328 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_TYPE_HWRM_ASYNC_EVENT
1330 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_EVENT_ID_ERROR_REPORT 0x45UL
1331 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_EVENT_ID_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_EVENT_ID_ERROR_REPORT
1333 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_EVENT_DATA2_PIN_ID_MASK 0xffUL
1334 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_EVENT_DATA2_PIN_ID_SFT 0
1336 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_V 0x1UL
1337 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_OPAQUE_MASK 0xfeUL
1338 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_OPAQUE_SFT 1
1340 __le16 timestamp_hi;
1342 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_EVENT_DATA1_ERROR_TYPE_MASK 0xffUL
1343 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_EVENT_DATA1_ERROR_TYPE_SFT 0
1344 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_EVENT_DATA1_ERROR_TYPE_INVALID_SIGNAL 0x2UL
1345 #define ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_EVENT_DATA1_ERROR_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_INVALID_SIGNAL_EVENT_DATA1_ERROR_TYPE_INVALID_SIGNAL
1348 /* hwrm_async_event_cmpl_error_report_nvm (size:128b/16B) */
1349 struct hwrm_async_event_cmpl_error_report_nvm {
1351 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_TYPE_MASK 0x3fUL
1352 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_TYPE_SFT 0
1353 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1354 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_TYPE_HWRM_ASYNC_EVENT
1356 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_ID_ERROR_REPORT 0x45UL
1357 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_ID_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_ID_ERROR_REPORT
1359 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA2_ERR_ADDR_MASK 0xffffffffUL
1360 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA2_ERR_ADDR_SFT 0
1362 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_V 0x1UL
1363 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_OPAQUE_MASK 0xfeUL
1364 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_OPAQUE_SFT 1
1366 __le16 timestamp_hi;
1368 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA1_ERROR_TYPE_MASK 0xffUL
1369 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA1_ERROR_TYPE_SFT 0
1370 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA1_ERROR_TYPE_NVM_ERROR 0x3UL
1371 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA1_ERROR_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA1_ERROR_TYPE_NVM_ERROR
1372 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA1_NVM_ERR_TYPE_MASK 0xff00UL
1373 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA1_NVM_ERR_TYPE_SFT 8
1374 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA1_NVM_ERR_TYPE_WRITE (0x1UL << 8)
1375 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA1_NVM_ERR_TYPE_ERASE (0x2UL << 8)
1376 #define ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA1_NVM_ERR_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_NVM_EVENT_DATA1_NVM_ERR_TYPE_ERASE
1379 /* hwrm_async_event_cmpl_error_report_doorbell_drop_threshold (size:128b/16B) */
1380 struct hwrm_async_event_cmpl_error_report_doorbell_drop_threshold {
1382 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_TYPE_MASK 0x3fUL
1383 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_TYPE_SFT 0
1384 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_TYPE_HWRM_ASYNC_EVENT 0x2eUL
1385 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_TYPE_HWRM_ASYNC_EVENT
1387 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_EVENT_ID_ERROR_REPORT 0x45UL
1388 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_EVENT_ID_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_EVENT_ID_ERROR_REPORT
1391 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_V 0x1UL
1392 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_OPAQUE_MASK 0xfeUL
1393 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_OPAQUE_SFT 1
1395 __le16 timestamp_hi;
1397 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_EVENT_DATA1_ERROR_TYPE_MASK 0xffUL
1398 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_EVENT_DATA1_ERROR_TYPE_SFT 0
1399 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_EVENT_DATA1_ERROR_TYPE_DOORBELL_DROP_THRESHOLD 0x4UL
1400 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_EVENT_DATA1_ERROR_TYPE_LAST ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_EVENT_DATA1_ERROR_TYPE_DOORBELL_DROP_THRESHOLD
1401 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_EVENT_DATA1_EPOCH_MASK 0xffffff00UL
1402 #define ASYNC_EVENT_CMPL_ERROR_REPORT_DOORBELL_DROP_THRESHOLD_EVENT_DATA1_EPOCH_SFT 8
1405 /* hwrm_func_reset_input (size:192b/24B) */
1406 struct hwrm_func_reset_input {
1413 #define FUNC_RESET_REQ_ENABLES_VF_ID_VALID 0x1UL
1415 u8 func_reset_level;
1416 #define FUNC_RESET_REQ_FUNC_RESET_LEVEL_RESETALL 0x0UL
1417 #define FUNC_RESET_REQ_FUNC_RESET_LEVEL_RESETME 0x1UL
1418 #define FUNC_RESET_REQ_FUNC_RESET_LEVEL_RESETCHILDREN 0x2UL
1419 #define FUNC_RESET_REQ_FUNC_RESET_LEVEL_RESETVF 0x3UL
1420 #define FUNC_RESET_REQ_FUNC_RESET_LEVEL_LAST FUNC_RESET_REQ_FUNC_RESET_LEVEL_RESETVF
1424 /* hwrm_func_reset_output (size:128b/16B) */
1425 struct hwrm_func_reset_output {
1434 /* hwrm_func_getfid_input (size:192b/24B) */
1435 struct hwrm_func_getfid_input {
1442 #define FUNC_GETFID_REQ_ENABLES_PCI_ID 0x1UL
1447 /* hwrm_func_getfid_output (size:128b/16B) */
1448 struct hwrm_func_getfid_output {
1458 /* hwrm_func_vf_alloc_input (size:192b/24B) */
1459 struct hwrm_func_vf_alloc_input {
1466 #define FUNC_VF_ALLOC_REQ_ENABLES_FIRST_VF_ID 0x1UL
1471 /* hwrm_func_vf_alloc_output (size:128b/16B) */
1472 struct hwrm_func_vf_alloc_output {
1482 /* hwrm_func_vf_free_input (size:192b/24B) */
1483 struct hwrm_func_vf_free_input {
1490 #define FUNC_VF_FREE_REQ_ENABLES_FIRST_VF_ID 0x1UL
1495 /* hwrm_func_vf_free_output (size:128b/16B) */
1496 struct hwrm_func_vf_free_output {
1505 /* hwrm_func_vf_cfg_input (size:448b/56B) */
1506 struct hwrm_func_vf_cfg_input {
1513 #define FUNC_VF_CFG_REQ_ENABLES_MTU 0x1UL
1514 #define FUNC_VF_CFG_REQ_ENABLES_GUEST_VLAN 0x2UL
1515 #define FUNC_VF_CFG_REQ_ENABLES_ASYNC_EVENT_CR 0x4UL
1516 #define FUNC_VF_CFG_REQ_ENABLES_DFLT_MAC_ADDR 0x8UL
1517 #define FUNC_VF_CFG_REQ_ENABLES_NUM_RSSCOS_CTXS 0x10UL
1518 #define FUNC_VF_CFG_REQ_ENABLES_NUM_CMPL_RINGS 0x20UL
1519 #define FUNC_VF_CFG_REQ_ENABLES_NUM_TX_RINGS 0x40UL
1520 #define FUNC_VF_CFG_REQ_ENABLES_NUM_RX_RINGS 0x80UL
1521 #define FUNC_VF_CFG_REQ_ENABLES_NUM_L2_CTXS 0x100UL
1522 #define FUNC_VF_CFG_REQ_ENABLES_NUM_VNICS 0x200UL
1523 #define FUNC_VF_CFG_REQ_ENABLES_NUM_STAT_CTXS 0x400UL
1524 #define FUNC_VF_CFG_REQ_ENABLES_NUM_HW_RING_GRPS 0x800UL
1525 #define FUNC_VF_CFG_REQ_ENABLES_NUM_TX_KEY_CTXS 0x1000UL
1526 #define FUNC_VF_CFG_REQ_ENABLES_NUM_RX_KEY_CTXS 0x2000UL
1529 __le16 async_event_cr;
1530 u8 dflt_mac_addr[6];
1532 #define FUNC_VF_CFG_REQ_FLAGS_TX_ASSETS_TEST 0x1UL
1533 #define FUNC_VF_CFG_REQ_FLAGS_RX_ASSETS_TEST 0x2UL
1534 #define FUNC_VF_CFG_REQ_FLAGS_CMPL_ASSETS_TEST 0x4UL
1535 #define FUNC_VF_CFG_REQ_FLAGS_RSSCOS_CTX_ASSETS_TEST 0x8UL
1536 #define FUNC_VF_CFG_REQ_FLAGS_RING_GRP_ASSETS_TEST 0x10UL
1537 #define FUNC_VF_CFG_REQ_FLAGS_STAT_CTX_ASSETS_TEST 0x20UL
1538 #define FUNC_VF_CFG_REQ_FLAGS_VNIC_ASSETS_TEST 0x40UL
1539 #define FUNC_VF_CFG_REQ_FLAGS_L2_CTX_ASSETS_TEST 0x80UL
1540 #define FUNC_VF_CFG_REQ_FLAGS_PPP_PUSH_MODE_ENABLE 0x100UL
1541 #define FUNC_VF_CFG_REQ_FLAGS_PPP_PUSH_MODE_DISABLE 0x200UL
1542 __le16 num_rsscos_ctxs;
1543 __le16 num_cmpl_rings;
1544 __le16 num_tx_rings;
1545 __le16 num_rx_rings;
1548 __le16 num_stat_ctxs;
1549 __le16 num_hw_ring_grps;
1550 __le16 num_tx_key_ctxs;
1551 __le16 num_rx_key_ctxs;
1554 /* hwrm_func_vf_cfg_output (size:128b/16B) */
1555 struct hwrm_func_vf_cfg_output {
1564 /* hwrm_func_qcaps_input (size:192b/24B) */
1565 struct hwrm_func_qcaps_input {
1575 /* hwrm_func_qcaps_output (size:768b/96B) */
1576 struct hwrm_func_qcaps_output {
1584 #define FUNC_QCAPS_RESP_FLAGS_PUSH_MODE_SUPPORTED 0x1UL
1585 #define FUNC_QCAPS_RESP_FLAGS_GLOBAL_MSIX_AUTOMASKING 0x2UL
1586 #define FUNC_QCAPS_RESP_FLAGS_PTP_SUPPORTED 0x4UL
1587 #define FUNC_QCAPS_RESP_FLAGS_ROCE_V1_SUPPORTED 0x8UL
1588 #define FUNC_QCAPS_RESP_FLAGS_ROCE_V2_SUPPORTED 0x10UL
1589 #define FUNC_QCAPS_RESP_FLAGS_WOL_MAGICPKT_SUPPORTED 0x20UL
1590 #define FUNC_QCAPS_RESP_FLAGS_WOL_BMP_SUPPORTED 0x40UL
1591 #define FUNC_QCAPS_RESP_FLAGS_TX_RING_RL_SUPPORTED 0x80UL
1592 #define FUNC_QCAPS_RESP_FLAGS_TX_BW_CFG_SUPPORTED 0x100UL
1593 #define FUNC_QCAPS_RESP_FLAGS_VF_TX_RING_RL_SUPPORTED 0x200UL
1594 #define FUNC_QCAPS_RESP_FLAGS_VF_BW_CFG_SUPPORTED 0x400UL
1595 #define FUNC_QCAPS_RESP_FLAGS_STD_TX_RING_MODE_SUPPORTED 0x800UL
1596 #define FUNC_QCAPS_RESP_FLAGS_GENEVE_TUN_FLAGS_SUPPORTED 0x1000UL
1597 #define FUNC_QCAPS_RESP_FLAGS_NVGRE_TUN_FLAGS_SUPPORTED 0x2000UL
1598 #define FUNC_QCAPS_RESP_FLAGS_GRE_TUN_FLAGS_SUPPORTED 0x4000UL
1599 #define FUNC_QCAPS_RESP_FLAGS_MPLS_TUN_FLAGS_SUPPORTED 0x8000UL
1600 #define FUNC_QCAPS_RESP_FLAGS_PCIE_STATS_SUPPORTED 0x10000UL
1601 #define FUNC_QCAPS_RESP_FLAGS_ADOPTED_PF_SUPPORTED 0x20000UL
1602 #define FUNC_QCAPS_RESP_FLAGS_ADMIN_PF_SUPPORTED 0x40000UL
1603 #define FUNC_QCAPS_RESP_FLAGS_LINK_ADMIN_STATUS_SUPPORTED 0x80000UL
1604 #define FUNC_QCAPS_RESP_FLAGS_WCB_PUSH_MODE 0x100000UL
1605 #define FUNC_QCAPS_RESP_FLAGS_DYNAMIC_TX_RING_ALLOC 0x200000UL
1606 #define FUNC_QCAPS_RESP_FLAGS_HOT_RESET_CAPABLE 0x400000UL
1607 #define FUNC_QCAPS_RESP_FLAGS_ERROR_RECOVERY_CAPABLE 0x800000UL
1608 #define FUNC_QCAPS_RESP_FLAGS_EXT_STATS_SUPPORTED 0x1000000UL
1609 #define FUNC_QCAPS_RESP_FLAGS_ERR_RECOVER_RELOAD 0x2000000UL
1610 #define FUNC_QCAPS_RESP_FLAGS_NOTIFY_VF_DEF_VNIC_CHNG_SUPPORTED 0x4000000UL
1611 #define FUNC_QCAPS_RESP_FLAGS_VLAN_ACCELERATION_TX_DISABLED 0x8000000UL
1612 #define FUNC_QCAPS_RESP_FLAGS_COREDUMP_CMD_SUPPORTED 0x10000000UL
1613 #define FUNC_QCAPS_RESP_FLAGS_CRASHDUMP_CMD_SUPPORTED 0x20000000UL
1614 #define FUNC_QCAPS_RESP_FLAGS_PFC_WD_STATS_SUPPORTED 0x40000000UL
1615 #define FUNC_QCAPS_RESP_FLAGS_DBG_QCAPS_CMD_SUPPORTED 0x80000000UL
1617 __le16 max_rsscos_ctx;
1618 __le16 max_cmpl_rings;
1619 __le16 max_tx_rings;
1620 __le16 max_rx_rings;
1625 __le16 max_stat_ctx;
1626 __le32 max_encap_records;
1627 __le32 max_decap_records;
1628 __le32 max_tx_em_flows;
1629 __le32 max_tx_wm_flows;
1630 __le32 max_rx_em_flows;
1631 __le32 max_rx_wm_flows;
1632 __le32 max_mcast_filters;
1634 __le32 max_hw_ring_grps;
1635 __le16 max_sp_tx_rings;
1636 __le16 max_msix_vfs;
1638 #define FUNC_QCAPS_RESP_FLAGS_EXT_ECN_MARK_SUPPORTED 0x1UL
1639 #define FUNC_QCAPS_RESP_FLAGS_EXT_ECN_STATS_SUPPORTED 0x2UL
1640 #define FUNC_QCAPS_RESP_FLAGS_EXT_EXT_HW_STATS_SUPPORTED 0x4UL
1641 #define FUNC_QCAPS_RESP_FLAGS_EXT_HOT_RESET_IF_SUPPORT 0x8UL
1642 #define FUNC_QCAPS_RESP_FLAGS_EXT_PROXY_MODE_SUPPORT 0x10UL
1643 #define FUNC_QCAPS_RESP_FLAGS_EXT_TX_PROXY_SRC_INTF_OVERRIDE_SUPPORT 0x20UL
1644 #define FUNC_QCAPS_RESP_FLAGS_EXT_SCHQ_SUPPORTED 0x40UL
1645 #define FUNC_QCAPS_RESP_FLAGS_EXT_PPP_PUSH_MODE_SUPPORTED 0x80UL
1646 #define FUNC_QCAPS_RESP_FLAGS_EXT_EVB_MODE_CFG_NOT_SUPPORTED 0x100UL
1647 #define FUNC_QCAPS_RESP_FLAGS_EXT_SOC_SPD_SUPPORTED 0x200UL
1648 #define FUNC_QCAPS_RESP_FLAGS_EXT_FW_LIVEPATCH_SUPPORTED 0x400UL
1649 #define FUNC_QCAPS_RESP_FLAGS_EXT_FAST_RESET_CAPABLE 0x800UL
1650 #define FUNC_QCAPS_RESP_FLAGS_EXT_TX_METADATA_CFG_CAPABLE 0x1000UL
1651 #define FUNC_QCAPS_RESP_FLAGS_EXT_NVM_OPTION_ACTION_SUPPORTED 0x2000UL
1652 #define FUNC_QCAPS_RESP_FLAGS_EXT_BD_METADATA_SUPPORTED 0x4000UL
1653 #define FUNC_QCAPS_RESP_FLAGS_EXT_ECHO_REQUEST_SUPPORTED 0x8000UL
1654 #define FUNC_QCAPS_RESP_FLAGS_EXT_NPAR_1_2_SUPPORTED 0x10000UL
1655 #define FUNC_QCAPS_RESP_FLAGS_EXT_PTP_PTM_SUPPORTED 0x20000UL
1656 #define FUNC_QCAPS_RESP_FLAGS_EXT_PTP_PPS_SUPPORTED 0x40000UL
1657 #define FUNC_QCAPS_RESP_FLAGS_EXT_VF_CFG_ASYNC_FOR_PF_SUPPORTED 0x80000UL
1658 #define FUNC_QCAPS_RESP_FLAGS_EXT_PARTITION_BW_SUPPORTED 0x100000UL
1659 #define FUNC_QCAPS_RESP_FLAGS_EXT_DFLT_VLAN_TPID_PCP_SUPPORTED 0x200000UL
1660 #define FUNC_QCAPS_RESP_FLAGS_EXT_KTLS_SUPPORTED 0x400000UL
1661 #define FUNC_QCAPS_RESP_FLAGS_EXT_EP_RATE_CONTROL 0x800000UL
1662 #define FUNC_QCAPS_RESP_FLAGS_EXT_MIN_BW_SUPPORTED 0x1000000UL
1663 #define FUNC_QCAPS_RESP_FLAGS_EXT_TX_COAL_CMPL_CAP 0x2000000UL
1664 #define FUNC_QCAPS_RESP_FLAGS_EXT_BS_V2_SUPPORTED 0x4000000UL
1665 #define FUNC_QCAPS_RESP_FLAGS_EXT_BS_V2_REQUIRED 0x8000000UL
1666 #define FUNC_QCAPS_RESP_FLAGS_EXT_PTP_64BIT_RTC_SUPPORTED 0x10000000UL
1667 #define FUNC_QCAPS_RESP_FLAGS_EXT_DBR_PACING_SUPPORTED 0x20000000UL
1668 #define FUNC_QCAPS_RESP_FLAGS_EXT_HW_DBR_DROP_RECOV_SUPPORTED 0x40000000UL
1669 #define FUNC_QCAPS_RESP_FLAGS_EXT_DISABLE_CQ_OVERFLOW_DETECTION_SUPPORTED 0x80000000UL
1672 #define FUNC_QCAPS_RESP_MPC_CHNLS_CAP_TCE 0x1UL
1673 #define FUNC_QCAPS_RESP_MPC_CHNLS_CAP_RCE 0x2UL
1674 #define FUNC_QCAPS_RESP_MPC_CHNLS_CAP_TE_CFA 0x4UL
1675 #define FUNC_QCAPS_RESP_MPC_CHNLS_CAP_RE_CFA 0x8UL
1676 #define FUNC_QCAPS_RESP_MPC_CHNLS_CAP_PRIMATE 0x10UL
1677 __le16 max_key_ctxs_alloc;
1679 #define FUNC_QCAPS_RESP_FLAGS_EXT2_RX_ALL_PKTS_TIMESTAMPS_SUPPORTED 0x1UL
1680 #define FUNC_QCAPS_RESP_FLAGS_EXT2_QUIC_SUPPORTED 0x2UL
1681 #define FUNC_QCAPS_RESP_FLAGS_EXT2_KDNET_SUPPORTED 0x4UL
1682 #define FUNC_QCAPS_RESP_FLAGS_EXT2_DBR_PACING_EXT_SUPPORTED 0x8UL
1683 #define FUNC_QCAPS_RESP_FLAGS_EXT2_SW_DBR_DROP_RECOVERY_SUPPORTED 0x10UL
1684 #define FUNC_QCAPS_RESP_FLAGS_EXT2_GENERIC_STATS_SUPPORTED 0x20UL
1685 #define FUNC_QCAPS_RESP_FLAGS_EXT2_UDP_GSO_SUPPORTED 0x40UL
1686 #define FUNC_QCAPS_RESP_FLAGS_EXT2_SYNCE_SUPPORTED 0x80UL
1687 #define FUNC_QCAPS_RESP_FLAGS_EXT2_DBR_PACING_V0_SUPPORTED 0x100UL
1688 #define FUNC_QCAPS_RESP_FLAGS_EXT2_TX_PKT_TS_CMPL_SUPPORTED 0x200UL
1689 __le16 tunnel_disable_flag;
1690 #define FUNC_QCAPS_RESP_TUNNEL_DISABLE_FLAG_DISABLE_VXLAN 0x1UL
1691 #define FUNC_QCAPS_RESP_TUNNEL_DISABLE_FLAG_DISABLE_NGE 0x2UL
1692 #define FUNC_QCAPS_RESP_TUNNEL_DISABLE_FLAG_DISABLE_NVGRE 0x4UL
1693 #define FUNC_QCAPS_RESP_TUNNEL_DISABLE_FLAG_DISABLE_L2GRE 0x8UL
1694 #define FUNC_QCAPS_RESP_TUNNEL_DISABLE_FLAG_DISABLE_GRE 0x10UL
1695 #define FUNC_QCAPS_RESP_TUNNEL_DISABLE_FLAG_DISABLE_IPINIP 0x20UL
1696 #define FUNC_QCAPS_RESP_TUNNEL_DISABLE_FLAG_DISABLE_MPLS 0x40UL
1697 #define FUNC_QCAPS_RESP_TUNNEL_DISABLE_FLAG_DISABLE_PPPOE 0x80UL
1702 /* hwrm_func_qcfg_input (size:192b/24B) */
1703 struct hwrm_func_qcfg_input {
1713 /* hwrm_func_qcfg_output (size:896b/112B) */
1714 struct hwrm_func_qcfg_output {
1723 #define FUNC_QCFG_RESP_FLAGS_OOB_WOL_MAGICPKT_ENABLED 0x1UL
1724 #define FUNC_QCFG_RESP_FLAGS_OOB_WOL_BMP_ENABLED 0x2UL
1725 #define FUNC_QCFG_RESP_FLAGS_FW_DCBX_AGENT_ENABLED 0x4UL
1726 #define FUNC_QCFG_RESP_FLAGS_STD_TX_RING_MODE_ENABLED 0x8UL
1727 #define FUNC_QCFG_RESP_FLAGS_FW_LLDP_AGENT_ENABLED 0x10UL
1728 #define FUNC_QCFG_RESP_FLAGS_MULTI_HOST 0x20UL
1729 #define FUNC_QCFG_RESP_FLAGS_TRUSTED_VF 0x40UL
1730 #define FUNC_QCFG_RESP_FLAGS_SECURE_MODE_ENABLED 0x80UL
1731 #define FUNC_QCFG_RESP_FLAGS_PREBOOT_LEGACY_L2_RINGS 0x100UL
1732 #define FUNC_QCFG_RESP_FLAGS_HOT_RESET_ALLOWED 0x200UL
1733 #define FUNC_QCFG_RESP_FLAGS_PPP_PUSH_MODE_ENABLED 0x400UL
1734 #define FUNC_QCFG_RESP_FLAGS_RING_MONITOR_ENABLED 0x800UL
1735 #define FUNC_QCFG_RESP_FLAGS_FAST_RESET_ALLOWED 0x1000UL
1736 #define FUNC_QCFG_RESP_FLAGS_MULTI_ROOT 0x2000UL
1737 #define FUNC_QCFG_RESP_FLAGS_ENABLE_RDMA_SRIOV 0x4000UL
1740 __le16 alloc_rsscos_ctx;
1741 __le16 alloc_cmpl_rings;
1742 __le16 alloc_tx_rings;
1743 __le16 alloc_rx_rings;
1744 __le16 alloc_l2_ctx;
1749 u8 port_partition_type;
1750 #define FUNC_QCFG_RESP_PORT_PARTITION_TYPE_SPF 0x0UL
1751 #define FUNC_QCFG_RESP_PORT_PARTITION_TYPE_MPFS 0x1UL
1752 #define FUNC_QCFG_RESP_PORT_PARTITION_TYPE_NPAR1_0 0x2UL
1753 #define FUNC_QCFG_RESP_PORT_PARTITION_TYPE_NPAR1_5 0x3UL
1754 #define FUNC_QCFG_RESP_PORT_PARTITION_TYPE_NPAR2_0 0x4UL
1755 #define FUNC_QCFG_RESP_PORT_PARTITION_TYPE_NPAR1_2 0x5UL
1756 #define FUNC_QCFG_RESP_PORT_PARTITION_TYPE_UNKNOWN 0xffUL
1757 #define FUNC_QCFG_RESP_PORT_PARTITION_TYPE_LAST FUNC_QCFG_RESP_PORT_PARTITION_TYPE_UNKNOWN
1759 #define FUNC_QCFG_RESP_PORT_PF_CNT_UNAVAIL 0x0UL
1760 #define FUNC_QCFG_RESP_PORT_PF_CNT_LAST FUNC_QCFG_RESP_PORT_PF_CNT_UNAVAIL
1761 __le16 dflt_vnic_id;
1762 __le16 max_mtu_configured;
1764 #define FUNC_QCFG_RESP_MIN_BW_BW_VALUE_MASK 0xfffffffUL
1765 #define FUNC_QCFG_RESP_MIN_BW_BW_VALUE_SFT 0
1766 #define FUNC_QCFG_RESP_MIN_BW_SCALE 0x10000000UL
1767 #define FUNC_QCFG_RESP_MIN_BW_SCALE_BITS (0x0UL << 28)
1768 #define FUNC_QCFG_RESP_MIN_BW_SCALE_BYTES (0x1UL << 28)
1769 #define FUNC_QCFG_RESP_MIN_BW_SCALE_LAST FUNC_QCFG_RESP_MIN_BW_SCALE_BYTES
1770 #define FUNC_QCFG_RESP_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
1771 #define FUNC_QCFG_RESP_MIN_BW_BW_VALUE_UNIT_SFT 29
1772 #define FUNC_QCFG_RESP_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
1773 #define FUNC_QCFG_RESP_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
1774 #define FUNC_QCFG_RESP_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
1775 #define FUNC_QCFG_RESP_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
1776 #define FUNC_QCFG_RESP_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
1777 #define FUNC_QCFG_RESP_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
1778 #define FUNC_QCFG_RESP_MIN_BW_BW_VALUE_UNIT_LAST FUNC_QCFG_RESP_MIN_BW_BW_VALUE_UNIT_INVALID
1780 #define FUNC_QCFG_RESP_MAX_BW_BW_VALUE_MASK 0xfffffffUL
1781 #define FUNC_QCFG_RESP_MAX_BW_BW_VALUE_SFT 0
1782 #define FUNC_QCFG_RESP_MAX_BW_SCALE 0x10000000UL
1783 #define FUNC_QCFG_RESP_MAX_BW_SCALE_BITS (0x0UL << 28)
1784 #define FUNC_QCFG_RESP_MAX_BW_SCALE_BYTES (0x1UL << 28)
1785 #define FUNC_QCFG_RESP_MAX_BW_SCALE_LAST FUNC_QCFG_RESP_MAX_BW_SCALE_BYTES
1786 #define FUNC_QCFG_RESP_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
1787 #define FUNC_QCFG_RESP_MAX_BW_BW_VALUE_UNIT_SFT 29
1788 #define FUNC_QCFG_RESP_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
1789 #define FUNC_QCFG_RESP_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
1790 #define FUNC_QCFG_RESP_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
1791 #define FUNC_QCFG_RESP_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
1792 #define FUNC_QCFG_RESP_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
1793 #define FUNC_QCFG_RESP_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
1794 #define FUNC_QCFG_RESP_MAX_BW_BW_VALUE_UNIT_LAST FUNC_QCFG_RESP_MAX_BW_BW_VALUE_UNIT_INVALID
1796 #define FUNC_QCFG_RESP_EVB_MODE_NO_EVB 0x0UL
1797 #define FUNC_QCFG_RESP_EVB_MODE_VEB 0x1UL
1798 #define FUNC_QCFG_RESP_EVB_MODE_VEPA 0x2UL
1799 #define FUNC_QCFG_RESP_EVB_MODE_LAST FUNC_QCFG_RESP_EVB_MODE_VEPA
1801 #define FUNC_QCFG_RESP_OPTIONS_CACHE_LINESIZE_MASK 0x3UL
1802 #define FUNC_QCFG_RESP_OPTIONS_CACHE_LINESIZE_SFT 0
1803 #define FUNC_QCFG_RESP_OPTIONS_CACHE_LINESIZE_SIZE_64 0x0UL
1804 #define FUNC_QCFG_RESP_OPTIONS_CACHE_LINESIZE_SIZE_128 0x1UL
1805 #define FUNC_QCFG_RESP_OPTIONS_CACHE_LINESIZE_LAST FUNC_QCFG_RESP_OPTIONS_CACHE_LINESIZE_SIZE_128
1806 #define FUNC_QCFG_RESP_OPTIONS_LINK_ADMIN_STATE_MASK 0xcUL
1807 #define FUNC_QCFG_RESP_OPTIONS_LINK_ADMIN_STATE_SFT 2
1808 #define FUNC_QCFG_RESP_OPTIONS_LINK_ADMIN_STATE_FORCED_DOWN (0x0UL << 2)
1809 #define FUNC_QCFG_RESP_OPTIONS_LINK_ADMIN_STATE_FORCED_UP (0x1UL << 2)
1810 #define FUNC_QCFG_RESP_OPTIONS_LINK_ADMIN_STATE_AUTO (0x2UL << 2)
1811 #define FUNC_QCFG_RESP_OPTIONS_LINK_ADMIN_STATE_LAST FUNC_QCFG_RESP_OPTIONS_LINK_ADMIN_STATE_AUTO
1812 #define FUNC_QCFG_RESP_OPTIONS_RSVD_MASK 0xf0UL
1813 #define FUNC_QCFG_RESP_OPTIONS_RSVD_SFT 4
1815 __le32 alloc_mcast_filters;
1816 __le32 alloc_hw_ring_grps;
1817 __le16 alloc_sp_tx_rings;
1818 __le16 alloc_stat_ctx;
1820 __le16 registered_vfs;
1821 __le16 l2_doorbell_bar_size_kb;
1824 __le32 reset_addr_poll;
1825 __le16 legacy_l2_db_size_kb;
1827 #define FUNC_QCFG_RESP_SVIF_INFO_SVIF_MASK 0x7fffUL
1828 #define FUNC_QCFG_RESP_SVIF_INFO_SVIF_SFT 0
1829 #define FUNC_QCFG_RESP_SVIF_INFO_SVIF_VALID 0x8000UL
1831 #define FUNC_QCFG_RESP_MPC_CHNLS_TCE_ENABLED 0x1UL
1832 #define FUNC_QCFG_RESP_MPC_CHNLS_RCE_ENABLED 0x2UL
1833 #define FUNC_QCFG_RESP_MPC_CHNLS_TE_CFA_ENABLED 0x4UL
1834 #define FUNC_QCFG_RESP_MPC_CHNLS_RE_CFA_ENABLED 0x8UL
1835 #define FUNC_QCFG_RESP_MPC_CHNLS_PRIMATE_ENABLED 0x10UL
1837 #define FUNC_QCFG_RESP_DB_PAGE_SIZE_4KB 0x0UL
1838 #define FUNC_QCFG_RESP_DB_PAGE_SIZE_8KB 0x1UL
1839 #define FUNC_QCFG_RESP_DB_PAGE_SIZE_16KB 0x2UL
1840 #define FUNC_QCFG_RESP_DB_PAGE_SIZE_32KB 0x3UL
1841 #define FUNC_QCFG_RESP_DB_PAGE_SIZE_64KB 0x4UL
1842 #define FUNC_QCFG_RESP_DB_PAGE_SIZE_128KB 0x5UL
1843 #define FUNC_QCFG_RESP_DB_PAGE_SIZE_256KB 0x6UL
1844 #define FUNC_QCFG_RESP_DB_PAGE_SIZE_512KB 0x7UL
1845 #define FUNC_QCFG_RESP_DB_PAGE_SIZE_1MB 0x8UL
1846 #define FUNC_QCFG_RESP_DB_PAGE_SIZE_2MB 0x9UL
1847 #define FUNC_QCFG_RESP_DB_PAGE_SIZE_4MB 0xaUL
1848 #define FUNC_QCFG_RESP_DB_PAGE_SIZE_LAST FUNC_QCFG_RESP_DB_PAGE_SIZE_4MB
1850 __le32 partition_min_bw;
1851 #define FUNC_QCFG_RESP_PARTITION_MIN_BW_BW_VALUE_MASK 0xfffffffUL
1852 #define FUNC_QCFG_RESP_PARTITION_MIN_BW_BW_VALUE_SFT 0
1853 #define FUNC_QCFG_RESP_PARTITION_MIN_BW_SCALE 0x10000000UL
1854 #define FUNC_QCFG_RESP_PARTITION_MIN_BW_SCALE_BITS (0x0UL << 28)
1855 #define FUNC_QCFG_RESP_PARTITION_MIN_BW_SCALE_BYTES (0x1UL << 28)
1856 #define FUNC_QCFG_RESP_PARTITION_MIN_BW_SCALE_LAST FUNC_QCFG_RESP_PARTITION_MIN_BW_SCALE_BYTES
1857 #define FUNC_QCFG_RESP_PARTITION_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
1858 #define FUNC_QCFG_RESP_PARTITION_MIN_BW_BW_VALUE_UNIT_SFT 29
1859 #define FUNC_QCFG_RESP_PARTITION_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
1860 #define FUNC_QCFG_RESP_PARTITION_MIN_BW_BW_VALUE_UNIT_LAST FUNC_QCFG_RESP_PARTITION_MIN_BW_BW_VALUE_UNIT_PERCENT1_100
1861 __le32 partition_max_bw;
1862 #define FUNC_QCFG_RESP_PARTITION_MAX_BW_BW_VALUE_MASK 0xfffffffUL
1863 #define FUNC_QCFG_RESP_PARTITION_MAX_BW_BW_VALUE_SFT 0
1864 #define FUNC_QCFG_RESP_PARTITION_MAX_BW_SCALE 0x10000000UL
1865 #define FUNC_QCFG_RESP_PARTITION_MAX_BW_SCALE_BITS (0x0UL << 28)
1866 #define FUNC_QCFG_RESP_PARTITION_MAX_BW_SCALE_BYTES (0x1UL << 28)
1867 #define FUNC_QCFG_RESP_PARTITION_MAX_BW_SCALE_LAST FUNC_QCFG_RESP_PARTITION_MAX_BW_SCALE_BYTES
1868 #define FUNC_QCFG_RESP_PARTITION_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
1869 #define FUNC_QCFG_RESP_PARTITION_MAX_BW_BW_VALUE_UNIT_SFT 29
1870 #define FUNC_QCFG_RESP_PARTITION_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
1871 #define FUNC_QCFG_RESP_PARTITION_MAX_BW_BW_VALUE_UNIT_LAST FUNC_QCFG_RESP_PARTITION_MAX_BW_BW_VALUE_UNIT_PERCENT1_100
1873 __le16 alloc_tx_key_ctxs;
1874 __le16 alloc_rx_key_ctxs;
1876 #define FUNC_QCFG_RESP_PORT_KDNET_MODE_DISABLED 0x0UL
1877 #define FUNC_QCFG_RESP_PORT_KDNET_MODE_ENABLED 0x1UL
1878 #define FUNC_QCFG_RESP_PORT_KDNET_MODE_LAST FUNC_QCFG_RESP_PORT_KDNET_MODE_ENABLED
1879 u8 kdnet_pcie_function;
1880 __le16 port_kdnet_fid;
1885 /* hwrm_func_cfg_input (size:960b/120B) */
1886 struct hwrm_func_cfg_input {
1895 #define FUNC_CFG_REQ_FLAGS_SRC_MAC_ADDR_CHECK_DISABLE 0x1UL
1896 #define FUNC_CFG_REQ_FLAGS_SRC_MAC_ADDR_CHECK_ENABLE 0x2UL
1897 #define FUNC_CFG_REQ_FLAGS_RSVD_MASK 0x1fcUL
1898 #define FUNC_CFG_REQ_FLAGS_RSVD_SFT 2
1899 #define FUNC_CFG_REQ_FLAGS_STD_TX_RING_MODE_ENABLE 0x200UL
1900 #define FUNC_CFG_REQ_FLAGS_STD_TX_RING_MODE_DISABLE 0x400UL
1901 #define FUNC_CFG_REQ_FLAGS_VIRT_MAC_PERSIST 0x800UL
1902 #define FUNC_CFG_REQ_FLAGS_NO_AUTOCLEAR_STATISTIC 0x1000UL
1903 #define FUNC_CFG_REQ_FLAGS_TX_ASSETS_TEST 0x2000UL
1904 #define FUNC_CFG_REQ_FLAGS_RX_ASSETS_TEST 0x4000UL
1905 #define FUNC_CFG_REQ_FLAGS_CMPL_ASSETS_TEST 0x8000UL
1906 #define FUNC_CFG_REQ_FLAGS_RSSCOS_CTX_ASSETS_TEST 0x10000UL
1907 #define FUNC_CFG_REQ_FLAGS_RING_GRP_ASSETS_TEST 0x20000UL
1908 #define FUNC_CFG_REQ_FLAGS_STAT_CTX_ASSETS_TEST 0x40000UL
1909 #define FUNC_CFG_REQ_FLAGS_VNIC_ASSETS_TEST 0x80000UL
1910 #define FUNC_CFG_REQ_FLAGS_L2_CTX_ASSETS_TEST 0x100000UL
1911 #define FUNC_CFG_REQ_FLAGS_TRUSTED_VF_ENABLE 0x200000UL
1912 #define FUNC_CFG_REQ_FLAGS_DYNAMIC_TX_RING_ALLOC 0x400000UL
1913 #define FUNC_CFG_REQ_FLAGS_NQ_ASSETS_TEST 0x800000UL
1914 #define FUNC_CFG_REQ_FLAGS_TRUSTED_VF_DISABLE 0x1000000UL
1915 #define FUNC_CFG_REQ_FLAGS_PREBOOT_LEGACY_L2_RINGS 0x2000000UL
1916 #define FUNC_CFG_REQ_FLAGS_HOT_RESET_IF_EN_DIS 0x4000000UL
1917 #define FUNC_CFG_REQ_FLAGS_PPP_PUSH_MODE_ENABLE 0x8000000UL
1918 #define FUNC_CFG_REQ_FLAGS_PPP_PUSH_MODE_DISABLE 0x10000000UL
1919 #define FUNC_CFG_REQ_FLAGS_BD_METADATA_ENABLE 0x20000000UL
1920 #define FUNC_CFG_REQ_FLAGS_BD_METADATA_DISABLE 0x40000000UL
1921 #define FUNC_CFG_REQ_FLAGS_KEY_CTX_ASSETS_TEST 0x80000000UL
1923 #define FUNC_CFG_REQ_ENABLES_ADMIN_MTU 0x1UL
1924 #define FUNC_CFG_REQ_ENABLES_MRU 0x2UL
1925 #define FUNC_CFG_REQ_ENABLES_NUM_RSSCOS_CTXS 0x4UL
1926 #define FUNC_CFG_REQ_ENABLES_NUM_CMPL_RINGS 0x8UL
1927 #define FUNC_CFG_REQ_ENABLES_NUM_TX_RINGS 0x10UL
1928 #define FUNC_CFG_REQ_ENABLES_NUM_RX_RINGS 0x20UL
1929 #define FUNC_CFG_REQ_ENABLES_NUM_L2_CTXS 0x40UL
1930 #define FUNC_CFG_REQ_ENABLES_NUM_VNICS 0x80UL
1931 #define FUNC_CFG_REQ_ENABLES_NUM_STAT_CTXS 0x100UL
1932 #define FUNC_CFG_REQ_ENABLES_DFLT_MAC_ADDR 0x200UL
1933 #define FUNC_CFG_REQ_ENABLES_DFLT_VLAN 0x400UL
1934 #define FUNC_CFG_REQ_ENABLES_DFLT_IP_ADDR 0x800UL
1935 #define FUNC_CFG_REQ_ENABLES_MIN_BW 0x1000UL
1936 #define FUNC_CFG_REQ_ENABLES_MAX_BW 0x2000UL
1937 #define FUNC_CFG_REQ_ENABLES_ASYNC_EVENT_CR 0x4000UL
1938 #define FUNC_CFG_REQ_ENABLES_VLAN_ANTISPOOF_MODE 0x8000UL
1939 #define FUNC_CFG_REQ_ENABLES_ALLOWED_VLAN_PRIS 0x10000UL
1940 #define FUNC_CFG_REQ_ENABLES_EVB_MODE 0x20000UL
1941 #define FUNC_CFG_REQ_ENABLES_NUM_MCAST_FILTERS 0x40000UL
1942 #define FUNC_CFG_REQ_ENABLES_NUM_HW_RING_GRPS 0x80000UL
1943 #define FUNC_CFG_REQ_ENABLES_CACHE_LINESIZE 0x100000UL
1944 #define FUNC_CFG_REQ_ENABLES_NUM_MSIX 0x200000UL
1945 #define FUNC_CFG_REQ_ENABLES_ADMIN_LINK_STATE 0x400000UL
1946 #define FUNC_CFG_REQ_ENABLES_HOT_RESET_IF_SUPPORT 0x800000UL
1947 #define FUNC_CFG_REQ_ENABLES_SCHQ_ID 0x1000000UL
1948 #define FUNC_CFG_REQ_ENABLES_MPC_CHNLS 0x2000000UL
1949 #define FUNC_CFG_REQ_ENABLES_PARTITION_MIN_BW 0x4000000UL
1950 #define FUNC_CFG_REQ_ENABLES_PARTITION_MAX_BW 0x8000000UL
1951 #define FUNC_CFG_REQ_ENABLES_TPID 0x10000000UL
1952 #define FUNC_CFG_REQ_ENABLES_HOST_MTU 0x20000000UL
1953 #define FUNC_CFG_REQ_ENABLES_TX_KEY_CTXS 0x40000000UL
1954 #define FUNC_CFG_REQ_ENABLES_RX_KEY_CTXS 0x80000000UL
1957 __le16 num_rsscos_ctxs;
1958 __le16 num_cmpl_rings;
1959 __le16 num_tx_rings;
1960 __le16 num_rx_rings;
1963 __le16 num_stat_ctxs;
1964 __le16 num_hw_ring_grps;
1965 u8 dflt_mac_addr[6];
1967 __be32 dflt_ip_addr[4];
1969 #define FUNC_CFG_REQ_MIN_BW_BW_VALUE_MASK 0xfffffffUL
1970 #define FUNC_CFG_REQ_MIN_BW_BW_VALUE_SFT 0
1971 #define FUNC_CFG_REQ_MIN_BW_SCALE 0x10000000UL
1972 #define FUNC_CFG_REQ_MIN_BW_SCALE_BITS (0x0UL << 28)
1973 #define FUNC_CFG_REQ_MIN_BW_SCALE_BYTES (0x1UL << 28)
1974 #define FUNC_CFG_REQ_MIN_BW_SCALE_LAST FUNC_CFG_REQ_MIN_BW_SCALE_BYTES
1975 #define FUNC_CFG_REQ_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
1976 #define FUNC_CFG_REQ_MIN_BW_BW_VALUE_UNIT_SFT 29
1977 #define FUNC_CFG_REQ_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
1978 #define FUNC_CFG_REQ_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
1979 #define FUNC_CFG_REQ_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
1980 #define FUNC_CFG_REQ_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
1981 #define FUNC_CFG_REQ_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
1982 #define FUNC_CFG_REQ_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
1983 #define FUNC_CFG_REQ_MIN_BW_BW_VALUE_UNIT_LAST FUNC_CFG_REQ_MIN_BW_BW_VALUE_UNIT_INVALID
1985 #define FUNC_CFG_REQ_MAX_BW_BW_VALUE_MASK 0xfffffffUL
1986 #define FUNC_CFG_REQ_MAX_BW_BW_VALUE_SFT 0
1987 #define FUNC_CFG_REQ_MAX_BW_SCALE 0x10000000UL
1988 #define FUNC_CFG_REQ_MAX_BW_SCALE_BITS (0x0UL << 28)
1989 #define FUNC_CFG_REQ_MAX_BW_SCALE_BYTES (0x1UL << 28)
1990 #define FUNC_CFG_REQ_MAX_BW_SCALE_LAST FUNC_CFG_REQ_MAX_BW_SCALE_BYTES
1991 #define FUNC_CFG_REQ_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
1992 #define FUNC_CFG_REQ_MAX_BW_BW_VALUE_UNIT_SFT 29
1993 #define FUNC_CFG_REQ_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
1994 #define FUNC_CFG_REQ_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
1995 #define FUNC_CFG_REQ_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
1996 #define FUNC_CFG_REQ_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
1997 #define FUNC_CFG_REQ_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
1998 #define FUNC_CFG_REQ_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
1999 #define FUNC_CFG_REQ_MAX_BW_BW_VALUE_UNIT_LAST FUNC_CFG_REQ_MAX_BW_BW_VALUE_UNIT_INVALID
2000 __le16 async_event_cr;
2001 u8 vlan_antispoof_mode;
2002 #define FUNC_CFG_REQ_VLAN_ANTISPOOF_MODE_NOCHECK 0x0UL
2003 #define FUNC_CFG_REQ_VLAN_ANTISPOOF_MODE_VALIDATE_VLAN 0x1UL
2004 #define FUNC_CFG_REQ_VLAN_ANTISPOOF_MODE_INSERT_IF_VLANDNE 0x2UL
2005 #define FUNC_CFG_REQ_VLAN_ANTISPOOF_MODE_INSERT_OR_OVERRIDE_VLAN 0x3UL
2006 #define FUNC_CFG_REQ_VLAN_ANTISPOOF_MODE_LAST FUNC_CFG_REQ_VLAN_ANTISPOOF_MODE_INSERT_OR_OVERRIDE_VLAN
2007 u8 allowed_vlan_pris;
2009 #define FUNC_CFG_REQ_EVB_MODE_NO_EVB 0x0UL
2010 #define FUNC_CFG_REQ_EVB_MODE_VEB 0x1UL
2011 #define FUNC_CFG_REQ_EVB_MODE_VEPA 0x2UL
2012 #define FUNC_CFG_REQ_EVB_MODE_LAST FUNC_CFG_REQ_EVB_MODE_VEPA
2014 #define FUNC_CFG_REQ_OPTIONS_CACHE_LINESIZE_MASK 0x3UL
2015 #define FUNC_CFG_REQ_OPTIONS_CACHE_LINESIZE_SFT 0
2016 #define FUNC_CFG_REQ_OPTIONS_CACHE_LINESIZE_SIZE_64 0x0UL
2017 #define FUNC_CFG_REQ_OPTIONS_CACHE_LINESIZE_SIZE_128 0x1UL
2018 #define FUNC_CFG_REQ_OPTIONS_CACHE_LINESIZE_LAST FUNC_CFG_REQ_OPTIONS_CACHE_LINESIZE_SIZE_128
2019 #define FUNC_CFG_REQ_OPTIONS_LINK_ADMIN_STATE_MASK 0xcUL
2020 #define FUNC_CFG_REQ_OPTIONS_LINK_ADMIN_STATE_SFT 2
2021 #define FUNC_CFG_REQ_OPTIONS_LINK_ADMIN_STATE_FORCED_DOWN (0x0UL << 2)
2022 #define FUNC_CFG_REQ_OPTIONS_LINK_ADMIN_STATE_FORCED_UP (0x1UL << 2)
2023 #define FUNC_CFG_REQ_OPTIONS_LINK_ADMIN_STATE_AUTO (0x2UL << 2)
2024 #define FUNC_CFG_REQ_OPTIONS_LINK_ADMIN_STATE_LAST FUNC_CFG_REQ_OPTIONS_LINK_ADMIN_STATE_AUTO
2025 #define FUNC_CFG_REQ_OPTIONS_RSVD_MASK 0xf0UL
2026 #define FUNC_CFG_REQ_OPTIONS_RSVD_SFT 4
2027 __le16 num_mcast_filters;
2030 #define FUNC_CFG_REQ_MPC_CHNLS_TCE_ENABLE 0x1UL
2031 #define FUNC_CFG_REQ_MPC_CHNLS_TCE_DISABLE 0x2UL
2032 #define FUNC_CFG_REQ_MPC_CHNLS_RCE_ENABLE 0x4UL
2033 #define FUNC_CFG_REQ_MPC_CHNLS_RCE_DISABLE 0x8UL
2034 #define FUNC_CFG_REQ_MPC_CHNLS_TE_CFA_ENABLE 0x10UL
2035 #define FUNC_CFG_REQ_MPC_CHNLS_TE_CFA_DISABLE 0x20UL
2036 #define FUNC_CFG_REQ_MPC_CHNLS_RE_CFA_ENABLE 0x40UL
2037 #define FUNC_CFG_REQ_MPC_CHNLS_RE_CFA_DISABLE 0x80UL
2038 #define FUNC_CFG_REQ_MPC_CHNLS_PRIMATE_ENABLE 0x100UL
2039 #define FUNC_CFG_REQ_MPC_CHNLS_PRIMATE_DISABLE 0x200UL
2040 __le32 partition_min_bw;
2041 #define FUNC_CFG_REQ_PARTITION_MIN_BW_BW_VALUE_MASK 0xfffffffUL
2042 #define FUNC_CFG_REQ_PARTITION_MIN_BW_BW_VALUE_SFT 0
2043 #define FUNC_CFG_REQ_PARTITION_MIN_BW_SCALE 0x10000000UL
2044 #define FUNC_CFG_REQ_PARTITION_MIN_BW_SCALE_BITS (0x0UL << 28)
2045 #define FUNC_CFG_REQ_PARTITION_MIN_BW_SCALE_BYTES (0x1UL << 28)
2046 #define FUNC_CFG_REQ_PARTITION_MIN_BW_SCALE_LAST FUNC_CFG_REQ_PARTITION_MIN_BW_SCALE_BYTES
2047 #define FUNC_CFG_REQ_PARTITION_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
2048 #define FUNC_CFG_REQ_PARTITION_MIN_BW_BW_VALUE_UNIT_SFT 29
2049 #define FUNC_CFG_REQ_PARTITION_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
2050 #define FUNC_CFG_REQ_PARTITION_MIN_BW_BW_VALUE_UNIT_LAST FUNC_CFG_REQ_PARTITION_MIN_BW_BW_VALUE_UNIT_PERCENT1_100
2051 __le32 partition_max_bw;
2052 #define FUNC_CFG_REQ_PARTITION_MAX_BW_BW_VALUE_MASK 0xfffffffUL
2053 #define FUNC_CFG_REQ_PARTITION_MAX_BW_BW_VALUE_SFT 0
2054 #define FUNC_CFG_REQ_PARTITION_MAX_BW_SCALE 0x10000000UL
2055 #define FUNC_CFG_REQ_PARTITION_MAX_BW_SCALE_BITS (0x0UL << 28)
2056 #define FUNC_CFG_REQ_PARTITION_MAX_BW_SCALE_BYTES (0x1UL << 28)
2057 #define FUNC_CFG_REQ_PARTITION_MAX_BW_SCALE_LAST FUNC_CFG_REQ_PARTITION_MAX_BW_SCALE_BYTES
2058 #define FUNC_CFG_REQ_PARTITION_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
2059 #define FUNC_CFG_REQ_PARTITION_MAX_BW_BW_VALUE_UNIT_SFT 29
2060 #define FUNC_CFG_REQ_PARTITION_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
2061 #define FUNC_CFG_REQ_PARTITION_MAX_BW_BW_VALUE_UNIT_LAST FUNC_CFG_REQ_PARTITION_MAX_BW_BW_VALUE_UNIT_PERCENT1_100
2064 __le16 num_tx_key_ctxs;
2065 __le16 num_rx_key_ctxs;
2067 #define FUNC_CFG_REQ_ENABLES2_KDNET 0x1UL
2068 #define FUNC_CFG_REQ_ENABLES2_DB_PAGE_SIZE 0x2UL
2070 #define FUNC_CFG_REQ_PORT_KDNET_MODE_DISABLED 0x0UL
2071 #define FUNC_CFG_REQ_PORT_KDNET_MODE_ENABLED 0x1UL
2072 #define FUNC_CFG_REQ_PORT_KDNET_MODE_LAST FUNC_CFG_REQ_PORT_KDNET_MODE_ENABLED
2074 #define FUNC_CFG_REQ_DB_PAGE_SIZE_4KB 0x0UL
2075 #define FUNC_CFG_REQ_DB_PAGE_SIZE_8KB 0x1UL
2076 #define FUNC_CFG_REQ_DB_PAGE_SIZE_16KB 0x2UL
2077 #define FUNC_CFG_REQ_DB_PAGE_SIZE_32KB 0x3UL
2078 #define FUNC_CFG_REQ_DB_PAGE_SIZE_64KB 0x4UL
2079 #define FUNC_CFG_REQ_DB_PAGE_SIZE_128KB 0x5UL
2080 #define FUNC_CFG_REQ_DB_PAGE_SIZE_256KB 0x6UL
2081 #define FUNC_CFG_REQ_DB_PAGE_SIZE_512KB 0x7UL
2082 #define FUNC_CFG_REQ_DB_PAGE_SIZE_1MB 0x8UL
2083 #define FUNC_CFG_REQ_DB_PAGE_SIZE_2MB 0x9UL
2084 #define FUNC_CFG_REQ_DB_PAGE_SIZE_4MB 0xaUL
2085 #define FUNC_CFG_REQ_DB_PAGE_SIZE_LAST FUNC_CFG_REQ_DB_PAGE_SIZE_4MB
2089 /* hwrm_func_cfg_output (size:128b/16B) */
2090 struct hwrm_func_cfg_output {
2099 /* hwrm_func_cfg_cmd_err (size:64b/8B) */
2100 struct hwrm_func_cfg_cmd_err {
2102 #define FUNC_CFG_CMD_ERR_CODE_UNKNOWN 0x0UL
2103 #define FUNC_CFG_CMD_ERR_CODE_PARTITION_MIN_BW_RANGE 0x1UL
2104 #define FUNC_CFG_CMD_ERR_CODE_PARTITION_MIN_MORE_THAN_MAX 0x2UL
2105 #define FUNC_CFG_CMD_ERR_CODE_PARTITION_MIN_BW_UNSUPPORTED 0x3UL
2106 #define FUNC_CFG_CMD_ERR_CODE_PARTITION_BW_PERCENT 0x4UL
2107 #define FUNC_CFG_CMD_ERR_CODE_LAST FUNC_CFG_CMD_ERR_CODE_PARTITION_BW_PERCENT
2111 /* hwrm_func_qstats_input (size:192b/24B) */
2112 struct hwrm_func_qstats_input {
2120 #define FUNC_QSTATS_REQ_FLAGS_ROCE_ONLY 0x1UL
2121 #define FUNC_QSTATS_REQ_FLAGS_COUNTER_MASK 0x2UL
2122 #define FUNC_QSTATS_REQ_FLAGS_L2_ONLY 0x4UL
2126 /* hwrm_func_qstats_output (size:1408b/176B) */
2127 struct hwrm_func_qstats_output {
2132 __le64 tx_ucast_pkts;
2133 __le64 tx_mcast_pkts;
2134 __le64 tx_bcast_pkts;
2135 __le64 tx_discard_pkts;
2136 __le64 tx_drop_pkts;
2137 __le64 tx_ucast_bytes;
2138 __le64 tx_mcast_bytes;
2139 __le64 tx_bcast_bytes;
2140 __le64 rx_ucast_pkts;
2141 __le64 rx_mcast_pkts;
2142 __le64 rx_bcast_pkts;
2143 __le64 rx_discard_pkts;
2144 __le64 rx_drop_pkts;
2145 __le64 rx_ucast_bytes;
2146 __le64 rx_mcast_bytes;
2147 __le64 rx_bcast_bytes;
2149 __le64 rx_agg_bytes;
2150 __le64 rx_agg_events;
2151 __le64 rx_agg_aborts;
2157 /* hwrm_func_qstats_ext_input (size:256b/32B) */
2158 struct hwrm_func_qstats_ext_input {
2166 #define FUNC_QSTATS_EXT_REQ_FLAGS_ROCE_ONLY 0x1UL
2167 #define FUNC_QSTATS_EXT_REQ_FLAGS_COUNTER_MASK 0x2UL
2170 #define FUNC_QSTATS_EXT_REQ_ENABLES_SCHQ_ID 0x1UL
2172 __le16 traffic_class;
2176 /* hwrm_func_qstats_ext_output (size:1536b/192B) */
2177 struct hwrm_func_qstats_ext_output {
2182 __le64 rx_ucast_pkts;
2183 __le64 rx_mcast_pkts;
2184 __le64 rx_bcast_pkts;
2185 __le64 rx_discard_pkts;
2186 __le64 rx_error_pkts;
2187 __le64 rx_ucast_bytes;
2188 __le64 rx_mcast_bytes;
2189 __le64 rx_bcast_bytes;
2190 __le64 tx_ucast_pkts;
2191 __le64 tx_mcast_pkts;
2192 __le64 tx_bcast_pkts;
2193 __le64 tx_error_pkts;
2194 __le64 tx_discard_pkts;
2195 __le64 tx_ucast_bytes;
2196 __le64 tx_mcast_bytes;
2197 __le64 tx_bcast_bytes;
2198 __le64 rx_tpa_eligible_pkt;
2199 __le64 rx_tpa_eligible_bytes;
2201 __le64 rx_tpa_bytes;
2202 __le64 rx_tpa_errors;
2203 __le64 rx_tpa_events;
2208 /* hwrm_func_clr_stats_input (size:192b/24B) */
2209 struct hwrm_func_clr_stats_input {
2219 /* hwrm_func_clr_stats_output (size:128b/16B) */
2220 struct hwrm_func_clr_stats_output {
2229 /* hwrm_func_vf_resc_free_input (size:192b/24B) */
2230 struct hwrm_func_vf_resc_free_input {
2240 /* hwrm_func_vf_resc_free_output (size:128b/16B) */
2241 struct hwrm_func_vf_resc_free_output {
2250 /* hwrm_func_drv_rgtr_input (size:896b/112B) */
2251 struct hwrm_func_drv_rgtr_input {
2258 #define FUNC_DRV_RGTR_REQ_FLAGS_FWD_ALL_MODE 0x1UL
2259 #define FUNC_DRV_RGTR_REQ_FLAGS_FWD_NONE_MODE 0x2UL
2260 #define FUNC_DRV_RGTR_REQ_FLAGS_16BIT_VER_MODE 0x4UL
2261 #define FUNC_DRV_RGTR_REQ_FLAGS_FLOW_HANDLE_64BIT_MODE 0x8UL
2262 #define FUNC_DRV_RGTR_REQ_FLAGS_HOT_RESET_SUPPORT 0x10UL
2263 #define FUNC_DRV_RGTR_REQ_FLAGS_ERROR_RECOVERY_SUPPORT 0x20UL
2264 #define FUNC_DRV_RGTR_REQ_FLAGS_MASTER_SUPPORT 0x40UL
2265 #define FUNC_DRV_RGTR_REQ_FLAGS_FAST_RESET_SUPPORT 0x80UL
2266 #define FUNC_DRV_RGTR_REQ_FLAGS_RSS_STRICT_HASH_TYPE_SUPPORT 0x100UL
2267 #define FUNC_DRV_RGTR_REQ_FLAGS_NPAR_1_2_SUPPORT 0x200UL
2268 #define FUNC_DRV_RGTR_REQ_FLAGS_ASYM_QUEUE_CFG_SUPPORT 0x400UL
2270 #define FUNC_DRV_RGTR_REQ_ENABLES_OS_TYPE 0x1UL
2271 #define FUNC_DRV_RGTR_REQ_ENABLES_VER 0x2UL
2272 #define FUNC_DRV_RGTR_REQ_ENABLES_TIMESTAMP 0x4UL
2273 #define FUNC_DRV_RGTR_REQ_ENABLES_VF_REQ_FWD 0x8UL
2274 #define FUNC_DRV_RGTR_REQ_ENABLES_ASYNC_EVENT_FWD 0x10UL
2276 #define FUNC_DRV_RGTR_REQ_OS_TYPE_UNKNOWN 0x0UL
2277 #define FUNC_DRV_RGTR_REQ_OS_TYPE_OTHER 0x1UL
2278 #define FUNC_DRV_RGTR_REQ_OS_TYPE_MSDOS 0xeUL
2279 #define FUNC_DRV_RGTR_REQ_OS_TYPE_WINDOWS 0x12UL
2280 #define FUNC_DRV_RGTR_REQ_OS_TYPE_SOLARIS 0x1dUL
2281 #define FUNC_DRV_RGTR_REQ_OS_TYPE_LINUX 0x24UL
2282 #define FUNC_DRV_RGTR_REQ_OS_TYPE_FREEBSD 0x2aUL
2283 #define FUNC_DRV_RGTR_REQ_OS_TYPE_ESXI 0x68UL
2284 #define FUNC_DRV_RGTR_REQ_OS_TYPE_WIN864 0x73UL
2285 #define FUNC_DRV_RGTR_REQ_OS_TYPE_WIN2012R2 0x74UL
2286 #define FUNC_DRV_RGTR_REQ_OS_TYPE_UEFI 0x8000UL
2287 #define FUNC_DRV_RGTR_REQ_OS_TYPE_LAST FUNC_DRV_RGTR_REQ_OS_TYPE_UEFI
2294 __le32 vf_req_fwd[8];
2295 __le32 async_event_fwd[8];
2302 /* hwrm_func_drv_rgtr_output (size:128b/16B) */
2303 struct hwrm_func_drv_rgtr_output {
2309 #define FUNC_DRV_RGTR_RESP_FLAGS_IF_CHANGE_SUPPORTED 0x1UL
2314 /* hwrm_func_drv_unrgtr_input (size:192b/24B) */
2315 struct hwrm_func_drv_unrgtr_input {
2322 #define FUNC_DRV_UNRGTR_REQ_FLAGS_PREPARE_FOR_SHUTDOWN 0x1UL
2326 /* hwrm_func_drv_unrgtr_output (size:128b/16B) */
2327 struct hwrm_func_drv_unrgtr_output {
2336 /* hwrm_func_buf_rgtr_input (size:1024b/128B) */
2337 struct hwrm_func_buf_rgtr_input {
2344 #define FUNC_BUF_RGTR_REQ_ENABLES_VF_ID 0x1UL
2345 #define FUNC_BUF_RGTR_REQ_ENABLES_ERR_BUF_ADDR 0x2UL
2347 __le16 req_buf_num_pages;
2348 __le16 req_buf_page_size;
2349 #define FUNC_BUF_RGTR_REQ_REQ_BUF_PAGE_SIZE_16B 0x4UL
2350 #define FUNC_BUF_RGTR_REQ_REQ_BUF_PAGE_SIZE_4K 0xcUL
2351 #define FUNC_BUF_RGTR_REQ_REQ_BUF_PAGE_SIZE_8K 0xdUL
2352 #define FUNC_BUF_RGTR_REQ_REQ_BUF_PAGE_SIZE_64K 0x10UL
2353 #define FUNC_BUF_RGTR_REQ_REQ_BUF_PAGE_SIZE_2M 0x15UL
2354 #define FUNC_BUF_RGTR_REQ_REQ_BUF_PAGE_SIZE_4M 0x16UL
2355 #define FUNC_BUF_RGTR_REQ_REQ_BUF_PAGE_SIZE_1G 0x1eUL
2356 #define FUNC_BUF_RGTR_REQ_REQ_BUF_PAGE_SIZE_LAST FUNC_BUF_RGTR_REQ_REQ_BUF_PAGE_SIZE_1G
2358 __le16 resp_buf_len;
2360 __le64 req_buf_page_addr0;
2361 __le64 req_buf_page_addr1;
2362 __le64 req_buf_page_addr2;
2363 __le64 req_buf_page_addr3;
2364 __le64 req_buf_page_addr4;
2365 __le64 req_buf_page_addr5;
2366 __le64 req_buf_page_addr6;
2367 __le64 req_buf_page_addr7;
2368 __le64 req_buf_page_addr8;
2369 __le64 req_buf_page_addr9;
2370 __le64 error_buf_addr;
2371 __le64 resp_buf_addr;
2374 /* hwrm_func_buf_rgtr_output (size:128b/16B) */
2375 struct hwrm_func_buf_rgtr_output {
2384 /* hwrm_func_drv_qver_input (size:192b/24B) */
2385 struct hwrm_func_drv_qver_input {
2396 /* hwrm_func_drv_qver_output (size:256b/32B) */
2397 struct hwrm_func_drv_qver_output {
2403 #define FUNC_DRV_QVER_RESP_OS_TYPE_UNKNOWN 0x0UL
2404 #define FUNC_DRV_QVER_RESP_OS_TYPE_OTHER 0x1UL
2405 #define FUNC_DRV_QVER_RESP_OS_TYPE_MSDOS 0xeUL
2406 #define FUNC_DRV_QVER_RESP_OS_TYPE_WINDOWS 0x12UL
2407 #define FUNC_DRV_QVER_RESP_OS_TYPE_SOLARIS 0x1dUL
2408 #define FUNC_DRV_QVER_RESP_OS_TYPE_LINUX 0x24UL
2409 #define FUNC_DRV_QVER_RESP_OS_TYPE_FREEBSD 0x2aUL
2410 #define FUNC_DRV_QVER_RESP_OS_TYPE_ESXI 0x68UL
2411 #define FUNC_DRV_QVER_RESP_OS_TYPE_WIN864 0x73UL
2412 #define FUNC_DRV_QVER_RESP_OS_TYPE_WIN2012R2 0x74UL
2413 #define FUNC_DRV_QVER_RESP_OS_TYPE_UEFI 0x8000UL
2414 #define FUNC_DRV_QVER_RESP_OS_TYPE_LAST FUNC_DRV_QVER_RESP_OS_TYPE_UEFI
2427 /* hwrm_func_resource_qcaps_input (size:192b/24B) */
2428 struct hwrm_func_resource_qcaps_input {
2438 /* hwrm_func_resource_qcaps_output (size:512b/64B) */
2439 struct hwrm_func_resource_qcaps_output {
2446 __le16 vf_reservation_strategy;
2447 #define FUNC_RESOURCE_QCAPS_RESP_VF_RESERVATION_STRATEGY_MAXIMAL 0x0UL
2448 #define FUNC_RESOURCE_QCAPS_RESP_VF_RESERVATION_STRATEGY_MINIMAL 0x1UL
2449 #define FUNC_RESOURCE_QCAPS_RESP_VF_RESERVATION_STRATEGY_MINIMAL_STATIC 0x2UL
2450 #define FUNC_RESOURCE_QCAPS_RESP_VF_RESERVATION_STRATEGY_LAST FUNC_RESOURCE_QCAPS_RESP_VF_RESERVATION_STRATEGY_MINIMAL_STATIC
2451 __le16 min_rsscos_ctx;
2452 __le16 max_rsscos_ctx;
2453 __le16 min_cmpl_rings;
2454 __le16 max_cmpl_rings;
2455 __le16 min_tx_rings;
2456 __le16 max_tx_rings;
2457 __le16 min_rx_rings;
2458 __le16 max_rx_rings;
2463 __le16 min_stat_ctx;
2464 __le16 max_stat_ctx;
2465 __le16 min_hw_ring_grps;
2466 __le16 max_hw_ring_grps;
2467 __le16 max_tx_scheduler_inputs;
2469 #define FUNC_RESOURCE_QCAPS_RESP_FLAGS_MIN_GUARANTEED 0x1UL
2470 __le16 min_tx_key_ctxs;
2471 __le16 max_tx_key_ctxs;
2472 __le16 min_rx_key_ctxs;
2473 __le16 max_rx_key_ctxs;
2478 /* hwrm_func_vf_resource_cfg_input (size:512b/64B) */
2479 struct hwrm_func_vf_resource_cfg_input {
2487 __le16 min_rsscos_ctx;
2488 __le16 max_rsscos_ctx;
2489 __le16 min_cmpl_rings;
2490 __le16 max_cmpl_rings;
2491 __le16 min_tx_rings;
2492 __le16 max_tx_rings;
2493 __le16 min_rx_rings;
2494 __le16 max_rx_rings;
2499 __le16 min_stat_ctx;
2500 __le16 max_stat_ctx;
2501 __le16 min_hw_ring_grps;
2502 __le16 max_hw_ring_grps;
2504 #define FUNC_VF_RESOURCE_CFG_REQ_FLAGS_MIN_GUARANTEED 0x1UL
2505 __le16 min_tx_key_ctxs;
2506 __le16 max_tx_key_ctxs;
2507 __le16 min_rx_key_ctxs;
2508 __le16 max_rx_key_ctxs;
2512 /* hwrm_func_vf_resource_cfg_output (size:256b/32B) */
2513 struct hwrm_func_vf_resource_cfg_output {
2518 __le16 reserved_rsscos_ctx;
2519 __le16 reserved_cmpl_rings;
2520 __le16 reserved_tx_rings;
2521 __le16 reserved_rx_rings;
2522 __le16 reserved_l2_ctxs;
2523 __le16 reserved_vnics;
2524 __le16 reserved_stat_ctx;
2525 __le16 reserved_hw_ring_grps;
2526 __le16 reserved_tx_key_ctxs;
2527 __le16 reserved_rx_key_ctxs;
2532 /* hwrm_func_backing_store_qcaps_input (size:128b/16B) */
2533 struct hwrm_func_backing_store_qcaps_input {
2541 /* hwrm_func_backing_store_qcaps_output (size:832b/104B) */
2542 struct hwrm_func_backing_store_qcaps_output {
2547 __le32 qp_max_entries;
2548 __le16 qp_min_qp1_entries;
2549 __le16 qp_max_l2_entries;
2550 __le16 qp_entry_size;
2551 __le16 srq_max_l2_entries;
2552 __le32 srq_max_entries;
2553 __le16 srq_entry_size;
2554 __le16 cq_max_l2_entries;
2555 __le32 cq_max_entries;
2556 __le16 cq_entry_size;
2557 __le16 vnic_max_vnic_entries;
2558 __le16 vnic_max_ring_table_entries;
2559 __le16 vnic_entry_size;
2560 __le32 stat_max_entries;
2561 __le16 stat_entry_size;
2562 __le16 tqm_entry_size;
2563 __le32 tqm_min_entries_per_ring;
2564 __le32 tqm_max_entries_per_ring;
2565 __le32 mrav_max_entries;
2566 __le16 mrav_entry_size;
2567 __le16 tim_entry_size;
2568 __le32 tim_max_entries;
2569 __le16 mrav_num_entries_units;
2570 u8 tqm_entries_multiple;
2571 u8 ctx_kind_initializer;
2572 __le16 ctx_init_mask;
2573 #define FUNC_BACKING_STORE_QCAPS_RESP_CTX_INIT_MASK_QP 0x1UL
2574 #define FUNC_BACKING_STORE_QCAPS_RESP_CTX_INIT_MASK_SRQ 0x2UL
2575 #define FUNC_BACKING_STORE_QCAPS_RESP_CTX_INIT_MASK_CQ 0x4UL
2576 #define FUNC_BACKING_STORE_QCAPS_RESP_CTX_INIT_MASK_VNIC 0x8UL
2577 #define FUNC_BACKING_STORE_QCAPS_RESP_CTX_INIT_MASK_STAT 0x10UL
2578 #define FUNC_BACKING_STORE_QCAPS_RESP_CTX_INIT_MASK_MRAV 0x20UL
2579 #define FUNC_BACKING_STORE_QCAPS_RESP_CTX_INIT_MASK_TKC 0x40UL
2580 #define FUNC_BACKING_STORE_QCAPS_RESP_CTX_INIT_MASK_RKC 0x80UL
2584 u8 vnic_init_offset;
2585 u8 tqm_fp_rings_count;
2586 u8 stat_init_offset;
2587 u8 mrav_init_offset;
2588 u8 tqm_fp_rings_count_ext;
2591 __le16 tkc_entry_size;
2592 __le16 rkc_entry_size;
2593 __le32 tkc_max_entries;
2594 __le32 rkc_max_entries;
2599 /* tqm_fp_ring_cfg (size:128b/16B) */
2600 struct tqm_fp_ring_cfg {
2601 u8 tqm_ring_pg_size_tqm_ring_lvl;
2602 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_LVL_MASK 0xfUL
2603 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_LVL_SFT 0
2604 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_LVL_LVL_0 0x0UL
2605 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_LVL_LVL_1 0x1UL
2606 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_LVL_LVL_2 0x2UL
2607 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_LVL_LAST TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_LVL_LVL_2
2608 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_PG_SIZE_MASK 0xf0UL
2609 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_PG_SIZE_SFT 4
2610 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_PG_SIZE_PG_4K (0x0UL << 4)
2611 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_PG_SIZE_PG_8K (0x1UL << 4)
2612 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_PG_SIZE_PG_64K (0x2UL << 4)
2613 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_PG_SIZE_PG_2M (0x3UL << 4)
2614 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_PG_SIZE_PG_8M (0x4UL << 4)
2615 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_PG_SIZE_PG_1G (0x5UL << 4)
2616 #define TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_PG_SIZE_LAST TQM_FP_RING_CFG_TQM_RING_CFG_TQM_RING_PG_SIZE_PG_1G
2618 __le32 tqm_ring_num_entries;
2619 __le64 tqm_ring_page_dir;
2622 /* hwrm_func_backing_store_cfg_input (size:2688b/336B) */
2623 struct hwrm_func_backing_store_cfg_input {
2630 #define FUNC_BACKING_STORE_CFG_REQ_FLAGS_PREBOOT_MODE 0x1UL
2631 #define FUNC_BACKING_STORE_CFG_REQ_FLAGS_MRAV_RESERVATION_SPLIT 0x2UL
2633 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_QP 0x1UL
2634 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_SRQ 0x2UL
2635 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_CQ 0x4UL
2636 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_VNIC 0x8UL
2637 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_STAT 0x10UL
2638 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TQM_SP 0x20UL
2639 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TQM_RING0 0x40UL
2640 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TQM_RING1 0x80UL
2641 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TQM_RING2 0x100UL
2642 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TQM_RING3 0x200UL
2643 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TQM_RING4 0x400UL
2644 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TQM_RING5 0x800UL
2645 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TQM_RING6 0x1000UL
2646 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TQM_RING7 0x2000UL
2647 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_MRAV 0x4000UL
2648 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TIM 0x8000UL
2649 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TQM_RING8 0x10000UL
2650 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TQM_RING9 0x20000UL
2651 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TQM_RING10 0x40000UL
2652 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_TKC 0x80000UL
2653 #define FUNC_BACKING_STORE_CFG_REQ_ENABLES_RKC 0x100000UL
2654 u8 qpc_pg_size_qpc_lvl;
2655 #define FUNC_BACKING_STORE_CFG_REQ_QPC_LVL_MASK 0xfUL
2656 #define FUNC_BACKING_STORE_CFG_REQ_QPC_LVL_SFT 0
2657 #define FUNC_BACKING_STORE_CFG_REQ_QPC_LVL_LVL_0 0x0UL
2658 #define FUNC_BACKING_STORE_CFG_REQ_QPC_LVL_LVL_1 0x1UL
2659 #define FUNC_BACKING_STORE_CFG_REQ_QPC_LVL_LVL_2 0x2UL
2660 #define FUNC_BACKING_STORE_CFG_REQ_QPC_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_QPC_LVL_LVL_2
2661 #define FUNC_BACKING_STORE_CFG_REQ_QPC_PG_SIZE_MASK 0xf0UL
2662 #define FUNC_BACKING_STORE_CFG_REQ_QPC_PG_SIZE_SFT 4
2663 #define FUNC_BACKING_STORE_CFG_REQ_QPC_PG_SIZE_PG_4K (0x0UL << 4)
2664 #define FUNC_BACKING_STORE_CFG_REQ_QPC_PG_SIZE_PG_8K (0x1UL << 4)
2665 #define FUNC_BACKING_STORE_CFG_REQ_QPC_PG_SIZE_PG_64K (0x2UL << 4)
2666 #define FUNC_BACKING_STORE_CFG_REQ_QPC_PG_SIZE_PG_2M (0x3UL << 4)
2667 #define FUNC_BACKING_STORE_CFG_REQ_QPC_PG_SIZE_PG_8M (0x4UL << 4)
2668 #define FUNC_BACKING_STORE_CFG_REQ_QPC_PG_SIZE_PG_1G (0x5UL << 4)
2669 #define FUNC_BACKING_STORE_CFG_REQ_QPC_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_QPC_PG_SIZE_PG_1G
2670 u8 srq_pg_size_srq_lvl;
2671 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_LVL_MASK 0xfUL
2672 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_LVL_SFT 0
2673 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_LVL_LVL_0 0x0UL
2674 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_LVL_LVL_1 0x1UL
2675 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_LVL_LVL_2 0x2UL
2676 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_SRQ_LVL_LVL_2
2677 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_PG_SIZE_MASK 0xf0UL
2678 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_PG_SIZE_SFT 4
2679 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_PG_SIZE_PG_4K (0x0UL << 4)
2680 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_PG_SIZE_PG_8K (0x1UL << 4)
2681 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_PG_SIZE_PG_64K (0x2UL << 4)
2682 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_PG_SIZE_PG_2M (0x3UL << 4)
2683 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_PG_SIZE_PG_8M (0x4UL << 4)
2684 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_PG_SIZE_PG_1G (0x5UL << 4)
2685 #define FUNC_BACKING_STORE_CFG_REQ_SRQ_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_SRQ_PG_SIZE_PG_1G
2686 u8 cq_pg_size_cq_lvl;
2687 #define FUNC_BACKING_STORE_CFG_REQ_CQ_LVL_MASK 0xfUL
2688 #define FUNC_BACKING_STORE_CFG_REQ_CQ_LVL_SFT 0
2689 #define FUNC_BACKING_STORE_CFG_REQ_CQ_LVL_LVL_0 0x0UL
2690 #define FUNC_BACKING_STORE_CFG_REQ_CQ_LVL_LVL_1 0x1UL
2691 #define FUNC_BACKING_STORE_CFG_REQ_CQ_LVL_LVL_2 0x2UL
2692 #define FUNC_BACKING_STORE_CFG_REQ_CQ_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_CQ_LVL_LVL_2
2693 #define FUNC_BACKING_STORE_CFG_REQ_CQ_PG_SIZE_MASK 0xf0UL
2694 #define FUNC_BACKING_STORE_CFG_REQ_CQ_PG_SIZE_SFT 4
2695 #define FUNC_BACKING_STORE_CFG_REQ_CQ_PG_SIZE_PG_4K (0x0UL << 4)
2696 #define FUNC_BACKING_STORE_CFG_REQ_CQ_PG_SIZE_PG_8K (0x1UL << 4)
2697 #define FUNC_BACKING_STORE_CFG_REQ_CQ_PG_SIZE_PG_64K (0x2UL << 4)
2698 #define FUNC_BACKING_STORE_CFG_REQ_CQ_PG_SIZE_PG_2M (0x3UL << 4)
2699 #define FUNC_BACKING_STORE_CFG_REQ_CQ_PG_SIZE_PG_8M (0x4UL << 4)
2700 #define FUNC_BACKING_STORE_CFG_REQ_CQ_PG_SIZE_PG_1G (0x5UL << 4)
2701 #define FUNC_BACKING_STORE_CFG_REQ_CQ_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_CQ_PG_SIZE_PG_1G
2702 u8 vnic_pg_size_vnic_lvl;
2703 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_LVL_MASK 0xfUL
2704 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_LVL_SFT 0
2705 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_LVL_LVL_0 0x0UL
2706 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_LVL_LVL_1 0x1UL
2707 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_LVL_LVL_2 0x2UL
2708 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_VNIC_LVL_LVL_2
2709 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_PG_SIZE_MASK 0xf0UL
2710 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_PG_SIZE_SFT 4
2711 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_PG_SIZE_PG_4K (0x0UL << 4)
2712 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_PG_SIZE_PG_8K (0x1UL << 4)
2713 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_PG_SIZE_PG_64K (0x2UL << 4)
2714 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_PG_SIZE_PG_2M (0x3UL << 4)
2715 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_PG_SIZE_PG_8M (0x4UL << 4)
2716 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_PG_SIZE_PG_1G (0x5UL << 4)
2717 #define FUNC_BACKING_STORE_CFG_REQ_VNIC_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_VNIC_PG_SIZE_PG_1G
2718 u8 stat_pg_size_stat_lvl;
2719 #define FUNC_BACKING_STORE_CFG_REQ_STAT_LVL_MASK 0xfUL
2720 #define FUNC_BACKING_STORE_CFG_REQ_STAT_LVL_SFT 0
2721 #define FUNC_BACKING_STORE_CFG_REQ_STAT_LVL_LVL_0 0x0UL
2722 #define FUNC_BACKING_STORE_CFG_REQ_STAT_LVL_LVL_1 0x1UL
2723 #define FUNC_BACKING_STORE_CFG_REQ_STAT_LVL_LVL_2 0x2UL
2724 #define FUNC_BACKING_STORE_CFG_REQ_STAT_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_STAT_LVL_LVL_2
2725 #define FUNC_BACKING_STORE_CFG_REQ_STAT_PG_SIZE_MASK 0xf0UL
2726 #define FUNC_BACKING_STORE_CFG_REQ_STAT_PG_SIZE_SFT 4
2727 #define FUNC_BACKING_STORE_CFG_REQ_STAT_PG_SIZE_PG_4K (0x0UL << 4)
2728 #define FUNC_BACKING_STORE_CFG_REQ_STAT_PG_SIZE_PG_8K (0x1UL << 4)
2729 #define FUNC_BACKING_STORE_CFG_REQ_STAT_PG_SIZE_PG_64K (0x2UL << 4)
2730 #define FUNC_BACKING_STORE_CFG_REQ_STAT_PG_SIZE_PG_2M (0x3UL << 4)
2731 #define FUNC_BACKING_STORE_CFG_REQ_STAT_PG_SIZE_PG_8M (0x4UL << 4)
2732 #define FUNC_BACKING_STORE_CFG_REQ_STAT_PG_SIZE_PG_1G (0x5UL << 4)
2733 #define FUNC_BACKING_STORE_CFG_REQ_STAT_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_STAT_PG_SIZE_PG_1G
2734 u8 tqm_sp_pg_size_tqm_sp_lvl;
2735 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_LVL_MASK 0xfUL
2736 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_LVL_SFT 0
2737 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_LVL_LVL_0 0x0UL
2738 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_LVL_LVL_1 0x1UL
2739 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_LVL_LVL_2 0x2UL
2740 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_SP_LVL_LVL_2
2741 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_PG_SIZE_MASK 0xf0UL
2742 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_PG_SIZE_SFT 4
2743 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_PG_SIZE_PG_4K (0x0UL << 4)
2744 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_PG_SIZE_PG_8K (0x1UL << 4)
2745 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_PG_SIZE_PG_64K (0x2UL << 4)
2746 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_PG_SIZE_PG_2M (0x3UL << 4)
2747 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_PG_SIZE_PG_8M (0x4UL << 4)
2748 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_PG_SIZE_PG_1G (0x5UL << 4)
2749 #define FUNC_BACKING_STORE_CFG_REQ_TQM_SP_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_SP_PG_SIZE_PG_1G
2750 u8 tqm_ring0_pg_size_tqm_ring0_lvl;
2751 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_LVL_MASK 0xfUL
2752 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_LVL_SFT 0
2753 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_LVL_LVL_0 0x0UL
2754 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_LVL_LVL_1 0x1UL
2755 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_LVL_LVL_2 0x2UL
2756 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_LVL_LVL_2
2757 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_PG_SIZE_MASK 0xf0UL
2758 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_PG_SIZE_SFT 4
2759 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_PG_SIZE_PG_4K (0x0UL << 4)
2760 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_PG_SIZE_PG_8K (0x1UL << 4)
2761 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_PG_SIZE_PG_64K (0x2UL << 4)
2762 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_PG_SIZE_PG_2M (0x3UL << 4)
2763 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_PG_SIZE_PG_8M (0x4UL << 4)
2764 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_PG_SIZE_PG_1G (0x5UL << 4)
2765 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING0_PG_SIZE_PG_1G
2766 u8 tqm_ring1_pg_size_tqm_ring1_lvl;
2767 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_LVL_MASK 0xfUL
2768 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_LVL_SFT 0
2769 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_LVL_LVL_0 0x0UL
2770 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_LVL_LVL_1 0x1UL
2771 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_LVL_LVL_2 0x2UL
2772 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_LVL_LVL_2
2773 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_PG_SIZE_MASK 0xf0UL
2774 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_PG_SIZE_SFT 4
2775 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_PG_SIZE_PG_4K (0x0UL << 4)
2776 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_PG_SIZE_PG_8K (0x1UL << 4)
2777 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_PG_SIZE_PG_64K (0x2UL << 4)
2778 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_PG_SIZE_PG_2M (0x3UL << 4)
2779 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_PG_SIZE_PG_8M (0x4UL << 4)
2780 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_PG_SIZE_PG_1G (0x5UL << 4)
2781 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING1_PG_SIZE_PG_1G
2782 u8 tqm_ring2_pg_size_tqm_ring2_lvl;
2783 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_LVL_MASK 0xfUL
2784 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_LVL_SFT 0
2785 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_LVL_LVL_0 0x0UL
2786 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_LVL_LVL_1 0x1UL
2787 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_LVL_LVL_2 0x2UL
2788 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_LVL_LVL_2
2789 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_PG_SIZE_MASK 0xf0UL
2790 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_PG_SIZE_SFT 4
2791 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_PG_SIZE_PG_4K (0x0UL << 4)
2792 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_PG_SIZE_PG_8K (0x1UL << 4)
2793 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_PG_SIZE_PG_64K (0x2UL << 4)
2794 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_PG_SIZE_PG_2M (0x3UL << 4)
2795 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_PG_SIZE_PG_8M (0x4UL << 4)
2796 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_PG_SIZE_PG_1G (0x5UL << 4)
2797 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING2_PG_SIZE_PG_1G
2798 u8 tqm_ring3_pg_size_tqm_ring3_lvl;
2799 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_LVL_MASK 0xfUL
2800 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_LVL_SFT 0
2801 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_LVL_LVL_0 0x0UL
2802 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_LVL_LVL_1 0x1UL
2803 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_LVL_LVL_2 0x2UL
2804 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_LVL_LVL_2
2805 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_PG_SIZE_MASK 0xf0UL
2806 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_PG_SIZE_SFT 4
2807 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_PG_SIZE_PG_4K (0x0UL << 4)
2808 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_PG_SIZE_PG_8K (0x1UL << 4)
2809 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_PG_SIZE_PG_64K (0x2UL << 4)
2810 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_PG_SIZE_PG_2M (0x3UL << 4)
2811 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_PG_SIZE_PG_8M (0x4UL << 4)
2812 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_PG_SIZE_PG_1G (0x5UL << 4)
2813 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING3_PG_SIZE_PG_1G
2814 u8 tqm_ring4_pg_size_tqm_ring4_lvl;
2815 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_LVL_MASK 0xfUL
2816 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_LVL_SFT 0
2817 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_LVL_LVL_0 0x0UL
2818 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_LVL_LVL_1 0x1UL
2819 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_LVL_LVL_2 0x2UL
2820 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_LVL_LVL_2
2821 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_PG_SIZE_MASK 0xf0UL
2822 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_PG_SIZE_SFT 4
2823 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_PG_SIZE_PG_4K (0x0UL << 4)
2824 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_PG_SIZE_PG_8K (0x1UL << 4)
2825 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_PG_SIZE_PG_64K (0x2UL << 4)
2826 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_PG_SIZE_PG_2M (0x3UL << 4)
2827 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_PG_SIZE_PG_8M (0x4UL << 4)
2828 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_PG_SIZE_PG_1G (0x5UL << 4)
2829 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING4_PG_SIZE_PG_1G
2830 u8 tqm_ring5_pg_size_tqm_ring5_lvl;
2831 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_LVL_MASK 0xfUL
2832 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_LVL_SFT 0
2833 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_LVL_LVL_0 0x0UL
2834 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_LVL_LVL_1 0x1UL
2835 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_LVL_LVL_2 0x2UL
2836 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_LVL_LVL_2
2837 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_PG_SIZE_MASK 0xf0UL
2838 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_PG_SIZE_SFT 4
2839 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_PG_SIZE_PG_4K (0x0UL << 4)
2840 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_PG_SIZE_PG_8K (0x1UL << 4)
2841 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_PG_SIZE_PG_64K (0x2UL << 4)
2842 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_PG_SIZE_PG_2M (0x3UL << 4)
2843 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_PG_SIZE_PG_8M (0x4UL << 4)
2844 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_PG_SIZE_PG_1G (0x5UL << 4)
2845 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING5_PG_SIZE_PG_1G
2846 u8 tqm_ring6_pg_size_tqm_ring6_lvl;
2847 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_LVL_MASK 0xfUL
2848 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_LVL_SFT 0
2849 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_LVL_LVL_0 0x0UL
2850 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_LVL_LVL_1 0x1UL
2851 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_LVL_LVL_2 0x2UL
2852 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_LVL_LVL_2
2853 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_PG_SIZE_MASK 0xf0UL
2854 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_PG_SIZE_SFT 4
2855 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_PG_SIZE_PG_4K (0x0UL << 4)
2856 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_PG_SIZE_PG_8K (0x1UL << 4)
2857 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_PG_SIZE_PG_64K (0x2UL << 4)
2858 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_PG_SIZE_PG_2M (0x3UL << 4)
2859 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_PG_SIZE_PG_8M (0x4UL << 4)
2860 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_PG_SIZE_PG_1G (0x5UL << 4)
2861 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING6_PG_SIZE_PG_1G
2862 u8 tqm_ring7_pg_size_tqm_ring7_lvl;
2863 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_LVL_MASK 0xfUL
2864 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_LVL_SFT 0
2865 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_LVL_LVL_0 0x0UL
2866 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_LVL_LVL_1 0x1UL
2867 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_LVL_LVL_2 0x2UL
2868 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_LVL_LVL_2
2869 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_PG_SIZE_MASK 0xf0UL
2870 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_PG_SIZE_SFT 4
2871 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_PG_SIZE_PG_4K (0x0UL << 4)
2872 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_PG_SIZE_PG_8K (0x1UL << 4)
2873 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_PG_SIZE_PG_64K (0x2UL << 4)
2874 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_PG_SIZE_PG_2M (0x3UL << 4)
2875 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_PG_SIZE_PG_8M (0x4UL << 4)
2876 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_PG_SIZE_PG_1G (0x5UL << 4)
2877 #define FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_TQM_RING7_PG_SIZE_PG_1G
2878 u8 mrav_pg_size_mrav_lvl;
2879 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_LVL_MASK 0xfUL
2880 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_LVL_SFT 0
2881 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_LVL_LVL_0 0x0UL
2882 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_LVL_LVL_1 0x1UL
2883 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_LVL_LVL_2 0x2UL
2884 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_MRAV_LVL_LVL_2
2885 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_PG_SIZE_MASK 0xf0UL
2886 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_PG_SIZE_SFT 4
2887 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_PG_SIZE_PG_4K (0x0UL << 4)
2888 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_PG_SIZE_PG_8K (0x1UL << 4)
2889 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_PG_SIZE_PG_64K (0x2UL << 4)
2890 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_PG_SIZE_PG_2M (0x3UL << 4)
2891 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_PG_SIZE_PG_8M (0x4UL << 4)
2892 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_PG_SIZE_PG_1G (0x5UL << 4)
2893 #define FUNC_BACKING_STORE_CFG_REQ_MRAV_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_MRAV_PG_SIZE_PG_1G
2894 u8 tim_pg_size_tim_lvl;
2895 #define FUNC_BACKING_STORE_CFG_REQ_TIM_LVL_MASK 0xfUL
2896 #define FUNC_BACKING_STORE_CFG_REQ_TIM_LVL_SFT 0
2897 #define FUNC_BACKING_STORE_CFG_REQ_TIM_LVL_LVL_0 0x0UL
2898 #define FUNC_BACKING_STORE_CFG_REQ_TIM_LVL_LVL_1 0x1UL
2899 #define FUNC_BACKING_STORE_CFG_REQ_TIM_LVL_LVL_2 0x2UL
2900 #define FUNC_BACKING_STORE_CFG_REQ_TIM_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_TIM_LVL_LVL_2
2901 #define FUNC_BACKING_STORE_CFG_REQ_TIM_PG_SIZE_MASK 0xf0UL
2902 #define FUNC_BACKING_STORE_CFG_REQ_TIM_PG_SIZE_SFT 4
2903 #define FUNC_BACKING_STORE_CFG_REQ_TIM_PG_SIZE_PG_4K (0x0UL << 4)
2904 #define FUNC_BACKING_STORE_CFG_REQ_TIM_PG_SIZE_PG_8K (0x1UL << 4)
2905 #define FUNC_BACKING_STORE_CFG_REQ_TIM_PG_SIZE_PG_64K (0x2UL << 4)
2906 #define FUNC_BACKING_STORE_CFG_REQ_TIM_PG_SIZE_PG_2M (0x3UL << 4)
2907 #define FUNC_BACKING_STORE_CFG_REQ_TIM_PG_SIZE_PG_8M (0x4UL << 4)
2908 #define FUNC_BACKING_STORE_CFG_REQ_TIM_PG_SIZE_PG_1G (0x5UL << 4)
2909 #define FUNC_BACKING_STORE_CFG_REQ_TIM_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_TIM_PG_SIZE_PG_1G
2910 __le64 qpc_page_dir;
2911 __le64 srq_page_dir;
2913 __le64 vnic_page_dir;
2914 __le64 stat_page_dir;
2915 __le64 tqm_sp_page_dir;
2916 __le64 tqm_ring0_page_dir;
2917 __le64 tqm_ring1_page_dir;
2918 __le64 tqm_ring2_page_dir;
2919 __le64 tqm_ring3_page_dir;
2920 __le64 tqm_ring4_page_dir;
2921 __le64 tqm_ring5_page_dir;
2922 __le64 tqm_ring6_page_dir;
2923 __le64 tqm_ring7_page_dir;
2924 __le64 mrav_page_dir;
2925 __le64 tim_page_dir;
2926 __le32 qp_num_entries;
2927 __le32 srq_num_entries;
2928 __le32 cq_num_entries;
2929 __le32 stat_num_entries;
2930 __le32 tqm_sp_num_entries;
2931 __le32 tqm_ring0_num_entries;
2932 __le32 tqm_ring1_num_entries;
2933 __le32 tqm_ring2_num_entries;
2934 __le32 tqm_ring3_num_entries;
2935 __le32 tqm_ring4_num_entries;
2936 __le32 tqm_ring5_num_entries;
2937 __le32 tqm_ring6_num_entries;
2938 __le32 tqm_ring7_num_entries;
2939 __le32 mrav_num_entries;
2940 __le32 tim_num_entries;
2941 __le16 qp_num_qp1_entries;
2942 __le16 qp_num_l2_entries;
2943 __le16 qp_entry_size;
2944 __le16 srq_num_l2_entries;
2945 __le16 srq_entry_size;
2946 __le16 cq_num_l2_entries;
2947 __le16 cq_entry_size;
2948 __le16 vnic_num_vnic_entries;
2949 __le16 vnic_num_ring_table_entries;
2950 __le16 vnic_entry_size;
2951 __le16 stat_entry_size;
2952 __le16 tqm_entry_size;
2953 __le16 mrav_entry_size;
2954 __le16 tim_entry_size;
2955 u8 tqm_ring8_pg_size_tqm_ring_lvl;
2956 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_LVL_MASK 0xfUL
2957 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_LVL_SFT 0
2958 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_LVL_LVL_0 0x0UL
2959 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_LVL_LVL_1 0x1UL
2960 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_LVL_LVL_2 0x2UL
2961 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_LVL_LVL_2
2962 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_PG_SIZE_MASK 0xf0UL
2963 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_PG_SIZE_SFT 4
2964 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_PG_SIZE_PG_4K (0x0UL << 4)
2965 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_PG_SIZE_PG_8K (0x1UL << 4)
2966 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_PG_SIZE_PG_64K (0x2UL << 4)
2967 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_PG_SIZE_PG_2M (0x3UL << 4)
2968 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_PG_SIZE_PG_8M (0x4UL << 4)
2969 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_PG_SIZE_PG_1G (0x5UL << 4)
2970 #define FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_RING8_TQM_RING_PG_SIZE_PG_1G
2972 __le32 tqm_ring8_num_entries;
2973 __le64 tqm_ring8_page_dir;
2974 u8 tqm_ring9_pg_size_tqm_ring_lvl;
2975 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_LVL_MASK 0xfUL
2976 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_LVL_SFT 0
2977 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_LVL_LVL_0 0x0UL
2978 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_LVL_LVL_1 0x1UL
2979 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_LVL_LVL_2 0x2UL
2980 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_LVL_LVL_2
2981 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_PG_SIZE_MASK 0xf0UL
2982 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_PG_SIZE_SFT 4
2983 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_PG_SIZE_PG_4K (0x0UL << 4)
2984 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_PG_SIZE_PG_8K (0x1UL << 4)
2985 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_PG_SIZE_PG_64K (0x2UL << 4)
2986 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_PG_SIZE_PG_2M (0x3UL << 4)
2987 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_PG_SIZE_PG_8M (0x4UL << 4)
2988 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_PG_SIZE_PG_1G (0x5UL << 4)
2989 #define FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_RING9_TQM_RING_PG_SIZE_PG_1G
2991 __le32 tqm_ring9_num_entries;
2992 __le64 tqm_ring9_page_dir;
2993 u8 tqm_ring10_pg_size_tqm_ring_lvl;
2994 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_LVL_MASK 0xfUL
2995 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_LVL_SFT 0
2996 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_LVL_LVL_0 0x0UL
2997 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_LVL_LVL_1 0x1UL
2998 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_LVL_LVL_2 0x2UL
2999 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_LVL_LVL_2
3000 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_PG_SIZE_MASK 0xf0UL
3001 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_PG_SIZE_SFT 4
3002 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_PG_SIZE_PG_4K (0x0UL << 4)
3003 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_PG_SIZE_PG_8K (0x1UL << 4)
3004 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_PG_SIZE_PG_64K (0x2UL << 4)
3005 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_PG_SIZE_PG_2M (0x3UL << 4)
3006 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_PG_SIZE_PG_8M (0x4UL << 4)
3007 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_PG_SIZE_PG_1G (0x5UL << 4)
3008 #define FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_RING10_TQM_RING_PG_SIZE_PG_1G
3009 u8 ring10_unused[3];
3010 __le32 tqm_ring10_num_entries;
3011 __le64 tqm_ring10_page_dir;
3012 __le32 tkc_num_entries;
3013 __le32 rkc_num_entries;
3014 __le64 tkc_page_dir;
3015 __le64 rkc_page_dir;
3016 __le16 tkc_entry_size;
3017 __le16 rkc_entry_size;
3018 u8 tkc_pg_size_tkc_lvl;
3019 #define FUNC_BACKING_STORE_CFG_REQ_TKC_LVL_MASK 0xfUL
3020 #define FUNC_BACKING_STORE_CFG_REQ_TKC_LVL_SFT 0
3021 #define FUNC_BACKING_STORE_CFG_REQ_TKC_LVL_LVL_0 0x0UL
3022 #define FUNC_BACKING_STORE_CFG_REQ_TKC_LVL_LVL_1 0x1UL
3023 #define FUNC_BACKING_STORE_CFG_REQ_TKC_LVL_LVL_2 0x2UL
3024 #define FUNC_BACKING_STORE_CFG_REQ_TKC_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_TKC_LVL_LVL_2
3025 #define FUNC_BACKING_STORE_CFG_REQ_TKC_PG_SIZE_MASK 0xf0UL
3026 #define FUNC_BACKING_STORE_CFG_REQ_TKC_PG_SIZE_SFT 4
3027 #define FUNC_BACKING_STORE_CFG_REQ_TKC_PG_SIZE_PG_4K (0x0UL << 4)
3028 #define FUNC_BACKING_STORE_CFG_REQ_TKC_PG_SIZE_PG_8K (0x1UL << 4)
3029 #define FUNC_BACKING_STORE_CFG_REQ_TKC_PG_SIZE_PG_64K (0x2UL << 4)
3030 #define FUNC_BACKING_STORE_CFG_REQ_TKC_PG_SIZE_PG_2M (0x3UL << 4)
3031 #define FUNC_BACKING_STORE_CFG_REQ_TKC_PG_SIZE_PG_8M (0x4UL << 4)
3032 #define FUNC_BACKING_STORE_CFG_REQ_TKC_PG_SIZE_PG_1G (0x5UL << 4)
3033 #define FUNC_BACKING_STORE_CFG_REQ_TKC_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_TKC_PG_SIZE_PG_1G
3034 u8 rkc_pg_size_rkc_lvl;
3035 #define FUNC_BACKING_STORE_CFG_REQ_RKC_LVL_MASK 0xfUL
3036 #define FUNC_BACKING_STORE_CFG_REQ_RKC_LVL_SFT 0
3037 #define FUNC_BACKING_STORE_CFG_REQ_RKC_LVL_LVL_0 0x0UL
3038 #define FUNC_BACKING_STORE_CFG_REQ_RKC_LVL_LVL_1 0x1UL
3039 #define FUNC_BACKING_STORE_CFG_REQ_RKC_LVL_LVL_2 0x2UL
3040 #define FUNC_BACKING_STORE_CFG_REQ_RKC_LVL_LAST FUNC_BACKING_STORE_CFG_REQ_RKC_LVL_LVL_2
3041 #define FUNC_BACKING_STORE_CFG_REQ_RKC_PG_SIZE_MASK 0xf0UL
3042 #define FUNC_BACKING_STORE_CFG_REQ_RKC_PG_SIZE_SFT 4
3043 #define FUNC_BACKING_STORE_CFG_REQ_RKC_PG_SIZE_PG_4K (0x0UL << 4)
3044 #define FUNC_BACKING_STORE_CFG_REQ_RKC_PG_SIZE_PG_8K (0x1UL << 4)
3045 #define FUNC_BACKING_STORE_CFG_REQ_RKC_PG_SIZE_PG_64K (0x2UL << 4)
3046 #define FUNC_BACKING_STORE_CFG_REQ_RKC_PG_SIZE_PG_2M (0x3UL << 4)
3047 #define FUNC_BACKING_STORE_CFG_REQ_RKC_PG_SIZE_PG_8M (0x4UL << 4)
3048 #define FUNC_BACKING_STORE_CFG_REQ_RKC_PG_SIZE_PG_1G (0x5UL << 4)
3049 #define FUNC_BACKING_STORE_CFG_REQ_RKC_PG_SIZE_LAST FUNC_BACKING_STORE_CFG_REQ_RKC_PG_SIZE_PG_1G
3053 /* hwrm_func_backing_store_cfg_output (size:128b/16B) */
3054 struct hwrm_func_backing_store_cfg_output {
3063 /* hwrm_error_recovery_qcfg_input (size:192b/24B) */
3064 struct hwrm_error_recovery_qcfg_input {
3073 /* hwrm_error_recovery_qcfg_output (size:1664b/208B) */
3074 struct hwrm_error_recovery_qcfg_output {
3080 #define ERROR_RECOVERY_QCFG_RESP_FLAGS_HOST 0x1UL
3081 #define ERROR_RECOVERY_QCFG_RESP_FLAGS_CO_CPU 0x2UL
3082 __le32 driver_polling_freq;
3083 __le32 master_func_wait_period;
3084 __le32 normal_func_wait_period;
3085 __le32 master_func_wait_period_after_reset;
3086 __le32 max_bailout_time_after_reset;
3087 __le32 fw_health_status_reg;
3088 #define ERROR_RECOVERY_QCFG_RESP_FW_HEALTH_STATUS_REG_ADDR_SPACE_MASK 0x3UL
3089 #define ERROR_RECOVERY_QCFG_RESP_FW_HEALTH_STATUS_REG_ADDR_SPACE_SFT 0
3090 #define ERROR_RECOVERY_QCFG_RESP_FW_HEALTH_STATUS_REG_ADDR_SPACE_PCIE_CFG 0x0UL
3091 #define ERROR_RECOVERY_QCFG_RESP_FW_HEALTH_STATUS_REG_ADDR_SPACE_GRC 0x1UL
3092 #define ERROR_RECOVERY_QCFG_RESP_FW_HEALTH_STATUS_REG_ADDR_SPACE_BAR0 0x2UL
3093 #define ERROR_RECOVERY_QCFG_RESP_FW_HEALTH_STATUS_REG_ADDR_SPACE_BAR1 0x3UL
3094 #define ERROR_RECOVERY_QCFG_RESP_FW_HEALTH_STATUS_REG_ADDR_SPACE_LAST ERROR_RECOVERY_QCFG_RESP_FW_HEALTH_STATUS_REG_ADDR_SPACE_BAR1
3095 #define ERROR_RECOVERY_QCFG_RESP_FW_HEALTH_STATUS_REG_ADDR_MASK 0xfffffffcUL
3096 #define ERROR_RECOVERY_QCFG_RESP_FW_HEALTH_STATUS_REG_ADDR_SFT 2
3097 __le32 fw_heartbeat_reg;
3098 #define ERROR_RECOVERY_QCFG_RESP_FW_HEARTBEAT_REG_ADDR_SPACE_MASK 0x3UL
3099 #define ERROR_RECOVERY_QCFG_RESP_FW_HEARTBEAT_REG_ADDR_SPACE_SFT 0
3100 #define ERROR_RECOVERY_QCFG_RESP_FW_HEARTBEAT_REG_ADDR_SPACE_PCIE_CFG 0x0UL
3101 #define ERROR_RECOVERY_QCFG_RESP_FW_HEARTBEAT_REG_ADDR_SPACE_GRC 0x1UL
3102 #define ERROR_RECOVERY_QCFG_RESP_FW_HEARTBEAT_REG_ADDR_SPACE_BAR0 0x2UL
3103 #define ERROR_RECOVERY_QCFG_RESP_FW_HEARTBEAT_REG_ADDR_SPACE_BAR1 0x3UL
3104 #define ERROR_RECOVERY_QCFG_RESP_FW_HEARTBEAT_REG_ADDR_SPACE_LAST ERROR_RECOVERY_QCFG_RESP_FW_HEARTBEAT_REG_ADDR_SPACE_BAR1
3105 #define ERROR_RECOVERY_QCFG_RESP_FW_HEARTBEAT_REG_ADDR_MASK 0xfffffffcUL
3106 #define ERROR_RECOVERY_QCFG_RESP_FW_HEARTBEAT_REG_ADDR_SFT 2
3107 __le32 fw_reset_cnt_reg;
3108 #define ERROR_RECOVERY_QCFG_RESP_FW_RESET_CNT_REG_ADDR_SPACE_MASK 0x3UL
3109 #define ERROR_RECOVERY_QCFG_RESP_FW_RESET_CNT_REG_ADDR_SPACE_SFT 0
3110 #define ERROR_RECOVERY_QCFG_RESP_FW_RESET_CNT_REG_ADDR_SPACE_PCIE_CFG 0x0UL
3111 #define ERROR_RECOVERY_QCFG_RESP_FW_RESET_CNT_REG_ADDR_SPACE_GRC 0x1UL
3112 #define ERROR_RECOVERY_QCFG_RESP_FW_RESET_CNT_REG_ADDR_SPACE_BAR0 0x2UL
3113 #define ERROR_RECOVERY_QCFG_RESP_FW_RESET_CNT_REG_ADDR_SPACE_BAR1 0x3UL
3114 #define ERROR_RECOVERY_QCFG_RESP_FW_RESET_CNT_REG_ADDR_SPACE_LAST ERROR_RECOVERY_QCFG_RESP_FW_RESET_CNT_REG_ADDR_SPACE_BAR1
3115 #define ERROR_RECOVERY_QCFG_RESP_FW_RESET_CNT_REG_ADDR_MASK 0xfffffffcUL
3116 #define ERROR_RECOVERY_QCFG_RESP_FW_RESET_CNT_REG_ADDR_SFT 2
3117 __le32 reset_inprogress_reg;
3118 #define ERROR_RECOVERY_QCFG_RESP_RESET_INPROGRESS_REG_ADDR_SPACE_MASK 0x3UL
3119 #define ERROR_RECOVERY_QCFG_RESP_RESET_INPROGRESS_REG_ADDR_SPACE_SFT 0
3120 #define ERROR_RECOVERY_QCFG_RESP_RESET_INPROGRESS_REG_ADDR_SPACE_PCIE_CFG 0x0UL
3121 #define ERROR_RECOVERY_QCFG_RESP_RESET_INPROGRESS_REG_ADDR_SPACE_GRC 0x1UL
3122 #define ERROR_RECOVERY_QCFG_RESP_RESET_INPROGRESS_REG_ADDR_SPACE_BAR0 0x2UL
3123 #define ERROR_RECOVERY_QCFG_RESP_RESET_INPROGRESS_REG_ADDR_SPACE_BAR1 0x3UL
3124 #define ERROR_RECOVERY_QCFG_RESP_RESET_INPROGRESS_REG_ADDR_SPACE_LAST ERROR_RECOVERY_QCFG_RESP_RESET_INPROGRESS_REG_ADDR_SPACE_BAR1
3125 #define ERROR_RECOVERY_QCFG_RESP_RESET_INPROGRESS_REG_ADDR_MASK 0xfffffffcUL
3126 #define ERROR_RECOVERY_QCFG_RESP_RESET_INPROGRESS_REG_ADDR_SFT 2
3127 __le32 reset_inprogress_reg_mask;
3130 __le32 reset_reg[16];
3131 #define ERROR_RECOVERY_QCFG_RESP_RESET_REG_ADDR_SPACE_MASK 0x3UL
3132 #define ERROR_RECOVERY_QCFG_RESP_RESET_REG_ADDR_SPACE_SFT 0
3133 #define ERROR_RECOVERY_QCFG_RESP_RESET_REG_ADDR_SPACE_PCIE_CFG 0x0UL
3134 #define ERROR_RECOVERY_QCFG_RESP_RESET_REG_ADDR_SPACE_GRC 0x1UL
3135 #define ERROR_RECOVERY_QCFG_RESP_RESET_REG_ADDR_SPACE_BAR0 0x2UL
3136 #define ERROR_RECOVERY_QCFG_RESP_RESET_REG_ADDR_SPACE_BAR1 0x3UL
3137 #define ERROR_RECOVERY_QCFG_RESP_RESET_REG_ADDR_SPACE_LAST ERROR_RECOVERY_QCFG_RESP_RESET_REG_ADDR_SPACE_BAR1
3138 #define ERROR_RECOVERY_QCFG_RESP_RESET_REG_ADDR_MASK 0xfffffffcUL
3139 #define ERROR_RECOVERY_QCFG_RESP_RESET_REG_ADDR_SFT 2
3140 __le32 reset_reg_val[16];
3141 u8 delay_after_reset[16];
3142 __le32 err_recovery_cnt_reg;
3143 #define ERROR_RECOVERY_QCFG_RESP_ERR_RECOVERY_CNT_REG_ADDR_SPACE_MASK 0x3UL
3144 #define ERROR_RECOVERY_QCFG_RESP_ERR_RECOVERY_CNT_REG_ADDR_SPACE_SFT 0
3145 #define ERROR_RECOVERY_QCFG_RESP_ERR_RECOVERY_CNT_REG_ADDR_SPACE_PCIE_CFG 0x0UL
3146 #define ERROR_RECOVERY_QCFG_RESP_ERR_RECOVERY_CNT_REG_ADDR_SPACE_GRC 0x1UL
3147 #define ERROR_RECOVERY_QCFG_RESP_ERR_RECOVERY_CNT_REG_ADDR_SPACE_BAR0 0x2UL
3148 #define ERROR_RECOVERY_QCFG_RESP_ERR_RECOVERY_CNT_REG_ADDR_SPACE_BAR1 0x3UL
3149 #define ERROR_RECOVERY_QCFG_RESP_ERR_RECOVERY_CNT_REG_ADDR_SPACE_LAST ERROR_RECOVERY_QCFG_RESP_ERR_RECOVERY_CNT_REG_ADDR_SPACE_BAR1
3150 #define ERROR_RECOVERY_QCFG_RESP_ERR_RECOVERY_CNT_REG_ADDR_MASK 0xfffffffcUL
3151 #define ERROR_RECOVERY_QCFG_RESP_ERR_RECOVERY_CNT_REG_ADDR_SFT 2
3156 /* hwrm_func_echo_response_input (size:192b/24B) */
3157 struct hwrm_func_echo_response_input {
3167 /* hwrm_func_echo_response_output (size:128b/16B) */
3168 struct hwrm_func_echo_response_output {
3177 /* hwrm_func_ptp_pin_qcfg_input (size:192b/24B) */
3178 struct hwrm_func_ptp_pin_qcfg_input {
3187 /* hwrm_func_ptp_pin_qcfg_output (size:128b/16B) */
3188 struct hwrm_func_ptp_pin_qcfg_output {
3195 #define FUNC_PTP_PIN_QCFG_RESP_STATE_PIN0_ENABLED 0x1UL
3196 #define FUNC_PTP_PIN_QCFG_RESP_STATE_PIN1_ENABLED 0x2UL
3197 #define FUNC_PTP_PIN_QCFG_RESP_STATE_PIN2_ENABLED 0x4UL
3198 #define FUNC_PTP_PIN_QCFG_RESP_STATE_PIN3_ENABLED 0x8UL
3200 #define FUNC_PTP_PIN_QCFG_RESP_PIN0_USAGE_NONE 0x0UL
3201 #define FUNC_PTP_PIN_QCFG_RESP_PIN0_USAGE_PPS_IN 0x1UL
3202 #define FUNC_PTP_PIN_QCFG_RESP_PIN0_USAGE_PPS_OUT 0x2UL
3203 #define FUNC_PTP_PIN_QCFG_RESP_PIN0_USAGE_SYNC_IN 0x3UL
3204 #define FUNC_PTP_PIN_QCFG_RESP_PIN0_USAGE_SYNC_OUT 0x4UL
3205 #define FUNC_PTP_PIN_QCFG_RESP_PIN0_USAGE_LAST FUNC_PTP_PIN_QCFG_RESP_PIN0_USAGE_SYNC_OUT
3207 #define FUNC_PTP_PIN_QCFG_RESP_PIN1_USAGE_NONE 0x0UL
3208 #define FUNC_PTP_PIN_QCFG_RESP_PIN1_USAGE_PPS_IN 0x1UL
3209 #define FUNC_PTP_PIN_QCFG_RESP_PIN1_USAGE_PPS_OUT 0x2UL
3210 #define FUNC_PTP_PIN_QCFG_RESP_PIN1_USAGE_SYNC_IN 0x3UL
3211 #define FUNC_PTP_PIN_QCFG_RESP_PIN1_USAGE_SYNC_OUT 0x4UL
3212 #define FUNC_PTP_PIN_QCFG_RESP_PIN1_USAGE_LAST FUNC_PTP_PIN_QCFG_RESP_PIN1_USAGE_SYNC_OUT
3214 #define FUNC_PTP_PIN_QCFG_RESP_PIN2_USAGE_NONE 0x0UL
3215 #define FUNC_PTP_PIN_QCFG_RESP_PIN2_USAGE_PPS_IN 0x1UL
3216 #define FUNC_PTP_PIN_QCFG_RESP_PIN2_USAGE_PPS_OUT 0x2UL
3217 #define FUNC_PTP_PIN_QCFG_RESP_PIN2_USAGE_SYNC_IN 0x3UL
3218 #define FUNC_PTP_PIN_QCFG_RESP_PIN2_USAGE_SYNC_OUT 0x4UL
3219 #define FUNC_PTP_PIN_QCFG_RESP_PIN2_USAGE_SYNCE_PRIMARY_CLOCK_OUT 0x5UL
3220 #define FUNC_PTP_PIN_QCFG_RESP_PIN2_USAGE_SYNCE_SECONDARY_CLOCK_OUT 0x6UL
3221 #define FUNC_PTP_PIN_QCFG_RESP_PIN2_USAGE_LAST FUNC_PTP_PIN_QCFG_RESP_PIN2_USAGE_SYNCE_SECONDARY_CLOCK_OUT
3223 #define FUNC_PTP_PIN_QCFG_RESP_PIN3_USAGE_NONE 0x0UL
3224 #define FUNC_PTP_PIN_QCFG_RESP_PIN3_USAGE_PPS_IN 0x1UL
3225 #define FUNC_PTP_PIN_QCFG_RESP_PIN3_USAGE_PPS_OUT 0x2UL
3226 #define FUNC_PTP_PIN_QCFG_RESP_PIN3_USAGE_SYNC_IN 0x3UL
3227 #define FUNC_PTP_PIN_QCFG_RESP_PIN3_USAGE_SYNC_OUT 0x4UL
3228 #define FUNC_PTP_PIN_QCFG_RESP_PIN3_USAGE_SYNCE_PRIMARY_CLOCK_OUT 0x5UL
3229 #define FUNC_PTP_PIN_QCFG_RESP_PIN3_USAGE_SYNCE_SECONDARY_CLOCK_OUT 0x6UL
3230 #define FUNC_PTP_PIN_QCFG_RESP_PIN3_USAGE_LAST FUNC_PTP_PIN_QCFG_RESP_PIN3_USAGE_SYNCE_SECONDARY_CLOCK_OUT
3235 /* hwrm_func_ptp_pin_cfg_input (size:256b/32B) */
3236 struct hwrm_func_ptp_pin_cfg_input {
3243 #define FUNC_PTP_PIN_CFG_REQ_ENABLES_PIN0_STATE 0x1UL
3244 #define FUNC_PTP_PIN_CFG_REQ_ENABLES_PIN0_USAGE 0x2UL
3245 #define FUNC_PTP_PIN_CFG_REQ_ENABLES_PIN1_STATE 0x4UL
3246 #define FUNC_PTP_PIN_CFG_REQ_ENABLES_PIN1_USAGE 0x8UL
3247 #define FUNC_PTP_PIN_CFG_REQ_ENABLES_PIN2_STATE 0x10UL
3248 #define FUNC_PTP_PIN_CFG_REQ_ENABLES_PIN2_USAGE 0x20UL
3249 #define FUNC_PTP_PIN_CFG_REQ_ENABLES_PIN3_STATE 0x40UL
3250 #define FUNC_PTP_PIN_CFG_REQ_ENABLES_PIN3_USAGE 0x80UL
3252 #define FUNC_PTP_PIN_CFG_REQ_PIN0_STATE_DISABLED 0x0UL
3253 #define FUNC_PTP_PIN_CFG_REQ_PIN0_STATE_ENABLED 0x1UL
3254 #define FUNC_PTP_PIN_CFG_REQ_PIN0_STATE_LAST FUNC_PTP_PIN_CFG_REQ_PIN0_STATE_ENABLED
3256 #define FUNC_PTP_PIN_CFG_REQ_PIN0_USAGE_NONE 0x0UL
3257 #define FUNC_PTP_PIN_CFG_REQ_PIN0_USAGE_PPS_IN 0x1UL
3258 #define FUNC_PTP_PIN_CFG_REQ_PIN0_USAGE_PPS_OUT 0x2UL
3259 #define FUNC_PTP_PIN_CFG_REQ_PIN0_USAGE_SYNC_IN 0x3UL
3260 #define FUNC_PTP_PIN_CFG_REQ_PIN0_USAGE_SYNC_OUT 0x4UL
3261 #define FUNC_PTP_PIN_CFG_REQ_PIN0_USAGE_LAST FUNC_PTP_PIN_CFG_REQ_PIN0_USAGE_SYNC_OUT
3263 #define FUNC_PTP_PIN_CFG_REQ_PIN1_STATE_DISABLED 0x0UL
3264 #define FUNC_PTP_PIN_CFG_REQ_PIN1_STATE_ENABLED 0x1UL
3265 #define FUNC_PTP_PIN_CFG_REQ_PIN1_STATE_LAST FUNC_PTP_PIN_CFG_REQ_PIN1_STATE_ENABLED
3267 #define FUNC_PTP_PIN_CFG_REQ_PIN1_USAGE_NONE 0x0UL
3268 #define FUNC_PTP_PIN_CFG_REQ_PIN1_USAGE_PPS_IN 0x1UL
3269 #define FUNC_PTP_PIN_CFG_REQ_PIN1_USAGE_PPS_OUT 0x2UL
3270 #define FUNC_PTP_PIN_CFG_REQ_PIN1_USAGE_SYNC_IN 0x3UL
3271 #define FUNC_PTP_PIN_CFG_REQ_PIN1_USAGE_SYNC_OUT 0x4UL
3272 #define FUNC_PTP_PIN_CFG_REQ_PIN1_USAGE_LAST FUNC_PTP_PIN_CFG_REQ_PIN1_USAGE_SYNC_OUT
3274 #define FUNC_PTP_PIN_CFG_REQ_PIN2_STATE_DISABLED 0x0UL
3275 #define FUNC_PTP_PIN_CFG_REQ_PIN2_STATE_ENABLED 0x1UL
3276 #define FUNC_PTP_PIN_CFG_REQ_PIN2_STATE_LAST FUNC_PTP_PIN_CFG_REQ_PIN2_STATE_ENABLED
3278 #define FUNC_PTP_PIN_CFG_REQ_PIN2_USAGE_NONE 0x0UL
3279 #define FUNC_PTP_PIN_CFG_REQ_PIN2_USAGE_PPS_IN 0x1UL
3280 #define FUNC_PTP_PIN_CFG_REQ_PIN2_USAGE_PPS_OUT 0x2UL
3281 #define FUNC_PTP_PIN_CFG_REQ_PIN2_USAGE_SYNC_IN 0x3UL
3282 #define FUNC_PTP_PIN_CFG_REQ_PIN2_USAGE_SYNC_OUT 0x4UL
3283 #define FUNC_PTP_PIN_CFG_REQ_PIN2_USAGE_SYNCE_PRIMARY_CLOCK_OUT 0x5UL
3284 #define FUNC_PTP_PIN_CFG_REQ_PIN2_USAGE_SYNCE_SECONDARY_CLOCK_OUT 0x6UL
3285 #define FUNC_PTP_PIN_CFG_REQ_PIN2_USAGE_LAST FUNC_PTP_PIN_CFG_REQ_PIN2_USAGE_SYNCE_SECONDARY_CLOCK_OUT
3287 #define FUNC_PTP_PIN_CFG_REQ_PIN3_STATE_DISABLED 0x0UL
3288 #define FUNC_PTP_PIN_CFG_REQ_PIN3_STATE_ENABLED 0x1UL
3289 #define FUNC_PTP_PIN_CFG_REQ_PIN3_STATE_LAST FUNC_PTP_PIN_CFG_REQ_PIN3_STATE_ENABLED
3291 #define FUNC_PTP_PIN_CFG_REQ_PIN3_USAGE_NONE 0x0UL
3292 #define FUNC_PTP_PIN_CFG_REQ_PIN3_USAGE_PPS_IN 0x1UL
3293 #define FUNC_PTP_PIN_CFG_REQ_PIN3_USAGE_PPS_OUT 0x2UL
3294 #define FUNC_PTP_PIN_CFG_REQ_PIN3_USAGE_SYNC_IN 0x3UL
3295 #define FUNC_PTP_PIN_CFG_REQ_PIN3_USAGE_SYNC_OUT 0x4UL
3296 #define FUNC_PTP_PIN_CFG_REQ_PIN3_USAGE_SYNCE_PRIMARY_CLOCK_OUT 0x5UL
3297 #define FUNC_PTP_PIN_CFG_REQ_PIN3_USAGE_SYNCE_SECONDARY_CLOCK_OUT 0x6UL
3298 #define FUNC_PTP_PIN_CFG_REQ_PIN3_USAGE_LAST FUNC_PTP_PIN_CFG_REQ_PIN3_USAGE_SYNCE_SECONDARY_CLOCK_OUT
3302 /* hwrm_func_ptp_pin_cfg_output (size:128b/16B) */
3303 struct hwrm_func_ptp_pin_cfg_output {
3312 /* hwrm_func_ptp_cfg_input (size:384b/48B) */
3313 struct hwrm_func_ptp_cfg_input {
3320 #define FUNC_PTP_CFG_REQ_ENABLES_PTP_PPS_EVENT 0x1UL
3321 #define FUNC_PTP_CFG_REQ_ENABLES_PTP_FREQ_ADJ_DLL_SOURCE 0x2UL
3322 #define FUNC_PTP_CFG_REQ_ENABLES_PTP_FREQ_ADJ_DLL_PHASE 0x4UL
3323 #define FUNC_PTP_CFG_REQ_ENABLES_PTP_FREQ_ADJ_EXT_PERIOD 0x8UL
3324 #define FUNC_PTP_CFG_REQ_ENABLES_PTP_FREQ_ADJ_EXT_UP 0x10UL
3325 #define FUNC_PTP_CFG_REQ_ENABLES_PTP_FREQ_ADJ_EXT_PHASE 0x20UL
3326 #define FUNC_PTP_CFG_REQ_ENABLES_PTP_SET_TIME 0x40UL
3328 #define FUNC_PTP_CFG_REQ_PTP_PPS_EVENT_INTERNAL 0x1UL
3329 #define FUNC_PTP_CFG_REQ_PTP_PPS_EVENT_EXTERNAL 0x2UL
3330 u8 ptp_freq_adj_dll_source;
3331 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_SOURCE_NONE 0x0UL
3332 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_SOURCE_TSIO_0 0x1UL
3333 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_SOURCE_TSIO_1 0x2UL
3334 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_SOURCE_TSIO_2 0x3UL
3335 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_SOURCE_TSIO_3 0x4UL
3336 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_SOURCE_PORT_0 0x5UL
3337 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_SOURCE_PORT_1 0x6UL
3338 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_SOURCE_PORT_2 0x7UL
3339 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_SOURCE_PORT_3 0x8UL
3340 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_SOURCE_INVALID 0xffUL
3341 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_SOURCE_LAST FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_SOURCE_INVALID
3342 u8 ptp_freq_adj_dll_phase;
3343 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_PHASE_NONE 0x0UL
3344 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_PHASE_4K 0x1UL
3345 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_PHASE_8K 0x2UL
3346 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_PHASE_10M 0x3UL
3347 #define FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_PHASE_LAST FUNC_PTP_CFG_REQ_PTP_FREQ_ADJ_DLL_PHASE_10M
3349 __le32 ptp_freq_adj_ext_period;
3350 __le32 ptp_freq_adj_ext_up;
3351 __le32 ptp_freq_adj_ext_phase_lower;
3352 __le32 ptp_freq_adj_ext_phase_upper;
3353 __le64 ptp_set_time;
3356 /* hwrm_func_ptp_cfg_output (size:128b/16B) */
3357 struct hwrm_func_ptp_cfg_output {
3366 /* hwrm_func_ptp_ts_query_input (size:192b/24B) */
3367 struct hwrm_func_ptp_ts_query_input {
3374 #define FUNC_PTP_TS_QUERY_REQ_FLAGS_PPS_TIME 0x1UL
3375 #define FUNC_PTP_TS_QUERY_REQ_FLAGS_PTM_TIME 0x2UL
3379 /* hwrm_func_ptp_ts_query_output (size:320b/40B) */
3380 struct hwrm_func_ptp_ts_query_output {
3385 __le64 pps_event_ts;
3386 __le64 ptm_local_ts;
3387 __le64 ptm_system_ts;
3388 __le32 ptm_link_delay;
3393 /* hwrm_func_ptp_ext_cfg_input (size:256b/32B) */
3394 struct hwrm_func_ptp_ext_cfg_input {
3401 #define FUNC_PTP_EXT_CFG_REQ_ENABLES_PHC_MASTER_FID 0x1UL
3402 #define FUNC_PTP_EXT_CFG_REQ_ENABLES_PHC_SEC_FID 0x2UL
3403 #define FUNC_PTP_EXT_CFG_REQ_ENABLES_PHC_SEC_MODE 0x4UL
3404 #define FUNC_PTP_EXT_CFG_REQ_ENABLES_FAILOVER_TIMER 0x8UL
3405 __le16 phc_master_fid;
3408 #define FUNC_PTP_EXT_CFG_REQ_PHC_SEC_MODE_SWITCH 0x0UL
3409 #define FUNC_PTP_EXT_CFG_REQ_PHC_SEC_MODE_ALL 0x1UL
3410 #define FUNC_PTP_EXT_CFG_REQ_PHC_SEC_MODE_PF_ONLY 0x2UL
3411 #define FUNC_PTP_EXT_CFG_REQ_PHC_SEC_MODE_LAST FUNC_PTP_EXT_CFG_REQ_PHC_SEC_MODE_PF_ONLY
3413 __le32 failover_timer;
3417 /* hwrm_func_ptp_ext_cfg_output (size:128b/16B) */
3418 struct hwrm_func_ptp_ext_cfg_output {
3427 /* hwrm_func_ptp_ext_qcfg_input (size:192b/24B) */
3428 struct hwrm_func_ptp_ext_qcfg_input {
3437 /* hwrm_func_ptp_ext_qcfg_output (size:256b/32B) */
3438 struct hwrm_func_ptp_ext_qcfg_output {
3443 __le16 phc_master_fid;
3445 __le16 phc_active_fid0;
3446 __le16 phc_active_fid1;
3447 __le32 last_failover_event;
3454 /* hwrm_func_backing_store_cfg_v2_input (size:448b/56B) */
3455 struct hwrm_func_backing_store_cfg_v2_input {
3462 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_QP 0x0UL
3463 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_SRQ 0x1UL
3464 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_CQ 0x2UL
3465 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_VNIC 0x3UL
3466 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_STAT 0x4UL
3467 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_SP_TQM_RING 0x5UL
3468 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_FP_TQM_RING 0x6UL
3469 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_MRAV 0xeUL
3470 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_TIM 0xfUL
3471 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_TKC 0x13UL
3472 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_RKC 0x14UL
3473 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_MP_TQM_RING 0x15UL
3474 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_SQ_DB_SHADOW 0x16UL
3475 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_RQ_DB_SHADOW 0x17UL
3476 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_SRQ_DB_SHADOW 0x18UL
3477 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_CQ_DB_SHADOW 0x19UL
3478 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_QUIC_TKC 0x1aUL
3479 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_QUIC_RKC 0x1bUL
3480 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_INVALID 0xffffUL
3481 #define FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_LAST FUNC_BACKING_STORE_CFG_V2_REQ_TYPE_INVALID
3484 #define FUNC_BACKING_STORE_CFG_V2_REQ_FLAGS_PREBOOT_MODE 0x1UL
3485 #define FUNC_BACKING_STORE_CFG_V2_REQ_FLAGS_BS_CFG_ALL_DONE 0x2UL
3486 #define FUNC_BACKING_STORE_CFG_V2_REQ_FLAGS_BS_EXTEND 0x4UL
3490 u8 page_size_pbl_level;
3491 #define FUNC_BACKING_STORE_CFG_V2_REQ_PBL_LEVEL_MASK 0xfUL
3492 #define FUNC_BACKING_STORE_CFG_V2_REQ_PBL_LEVEL_SFT 0
3493 #define FUNC_BACKING_STORE_CFG_V2_REQ_PBL_LEVEL_LVL_0 0x0UL
3494 #define FUNC_BACKING_STORE_CFG_V2_REQ_PBL_LEVEL_LVL_1 0x1UL
3495 #define FUNC_BACKING_STORE_CFG_V2_REQ_PBL_LEVEL_LVL_2 0x2UL
3496 #define FUNC_BACKING_STORE_CFG_V2_REQ_PBL_LEVEL_LAST FUNC_BACKING_STORE_CFG_V2_REQ_PBL_LEVEL_LVL_2
3497 #define FUNC_BACKING_STORE_CFG_V2_REQ_PAGE_SIZE_MASK 0xf0UL
3498 #define FUNC_BACKING_STORE_CFG_V2_REQ_PAGE_SIZE_SFT 4
3499 #define FUNC_BACKING_STORE_CFG_V2_REQ_PAGE_SIZE_PG_4K (0x0UL << 4)
3500 #define FUNC_BACKING_STORE_CFG_V2_REQ_PAGE_SIZE_PG_8K (0x1UL << 4)
3501 #define FUNC_BACKING_STORE_CFG_V2_REQ_PAGE_SIZE_PG_64K (0x2UL << 4)
3502 #define FUNC_BACKING_STORE_CFG_V2_REQ_PAGE_SIZE_PG_2M (0x3UL << 4)
3503 #define FUNC_BACKING_STORE_CFG_V2_REQ_PAGE_SIZE_PG_8M (0x4UL << 4)
3504 #define FUNC_BACKING_STORE_CFG_V2_REQ_PAGE_SIZE_PG_1G (0x5UL << 4)
3505 #define FUNC_BACKING_STORE_CFG_V2_REQ_PAGE_SIZE_LAST FUNC_BACKING_STORE_CFG_V2_REQ_PAGE_SIZE_PG_1G
3506 u8 subtype_valid_cnt;
3507 __le32 split_entry_0;
3508 __le32 split_entry_1;
3509 __le32 split_entry_2;
3510 __le32 split_entry_3;
3513 /* hwrm_func_backing_store_cfg_v2_output (size:128b/16B) */
3514 struct hwrm_func_backing_store_cfg_v2_output {
3523 /* hwrm_func_backing_store_qcfg_v2_input (size:192b/24B) */
3524 struct hwrm_func_backing_store_qcfg_v2_input {
3531 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_QP 0x0UL
3532 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_SRQ 0x1UL
3533 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_CQ 0x2UL
3534 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_VNIC 0x3UL
3535 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_STAT 0x4UL
3536 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_SP_TQM_RING 0x5UL
3537 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_FP_TQM_RING 0x6UL
3538 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_MRAV 0xeUL
3539 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_TIM 0xfUL
3540 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_TKC 0x13UL
3541 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_RKC 0x14UL
3542 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_MP_TQM_RING 0x15UL
3543 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_SQ_DB_SHADOW 0x16UL
3544 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_RQ_DB_SHADOW 0x17UL
3545 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_SRQ_DB_SHADOW 0x18UL
3546 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_CQ_DB_SHADOW 0x19UL
3547 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_QUIC_TKC 0x1aUL
3548 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_QUIC_RKC 0x1bUL
3549 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_INVALID 0xffffUL
3550 #define FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_LAST FUNC_BACKING_STORE_QCFG_V2_REQ_TYPE_INVALID
3555 /* hwrm_func_backing_store_qcfg_v2_output (size:448b/56B) */
3556 struct hwrm_func_backing_store_qcfg_v2_output {
3562 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_QP 0x0UL
3563 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_SRQ 0x1UL
3564 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_CQ 0x2UL
3565 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_VNIC 0x3UL
3566 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_STAT 0x4UL
3567 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_SP_TQM_RING 0x5UL
3568 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_FP_TQM_RING 0x6UL
3569 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_MRAV 0xeUL
3570 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_TIM 0xfUL
3571 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_TKC 0x13UL
3572 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_RKC 0x14UL
3573 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_MP_TQM_RING 0x15UL
3574 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_QUIC_TKC 0x1aUL
3575 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_QUIC_RKC 0x1bUL
3576 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_INVALID 0xffffUL
3577 #define FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_LAST FUNC_BACKING_STORE_QCFG_V2_RESP_TYPE_INVALID
3582 u8 page_size_pbl_level;
3583 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PBL_LEVEL_MASK 0xfUL
3584 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PBL_LEVEL_SFT 0
3585 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PBL_LEVEL_LVL_0 0x0UL
3586 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PBL_LEVEL_LVL_1 0x1UL
3587 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PBL_LEVEL_LVL_2 0x2UL
3588 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PBL_LEVEL_LAST FUNC_BACKING_STORE_QCFG_V2_RESP_PBL_LEVEL_LVL_2
3589 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PAGE_SIZE_MASK 0xf0UL
3590 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PAGE_SIZE_SFT 4
3591 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PAGE_SIZE_PG_4K (0x0UL << 4)
3592 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PAGE_SIZE_PG_8K (0x1UL << 4)
3593 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PAGE_SIZE_PG_64K (0x2UL << 4)
3594 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PAGE_SIZE_PG_2M (0x3UL << 4)
3595 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PAGE_SIZE_PG_8M (0x4UL << 4)
3596 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PAGE_SIZE_PG_1G (0x5UL << 4)
3597 #define FUNC_BACKING_STORE_QCFG_V2_RESP_PAGE_SIZE_LAST FUNC_BACKING_STORE_QCFG_V2_RESP_PAGE_SIZE_PG_1G
3598 u8 subtype_valid_cnt;
3600 __le32 split_entry_0;
3601 __le32 split_entry_1;
3602 __le32 split_entry_2;
3603 __le32 split_entry_3;
3608 /* qpc_split_entries (size:128b/16B) */
3609 struct qpc_split_entries {
3610 __le32 qp_num_l2_entries;
3611 __le32 qp_num_qp1_entries;
3615 /* srq_split_entries (size:128b/16B) */
3616 struct srq_split_entries {
3617 __le32 srq_num_l2_entries;
3622 /* cq_split_entries (size:128b/16B) */
3623 struct cq_split_entries {
3624 __le32 cq_num_l2_entries;
3629 /* vnic_split_entries (size:128b/16B) */
3630 struct vnic_split_entries {
3631 __le32 vnic_num_vnic_entries;
3636 /* mrav_split_entries (size:128b/16B) */
3637 struct mrav_split_entries {
3638 __le32 mrav_num_av_entries;
3643 /* hwrm_func_backing_store_qcaps_v2_input (size:192b/24B) */
3644 struct hwrm_func_backing_store_qcaps_v2_input {
3651 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_QP 0x0UL
3652 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_SRQ 0x1UL
3653 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_CQ 0x2UL
3654 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_VNIC 0x3UL
3655 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_STAT 0x4UL
3656 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_SP_TQM_RING 0x5UL
3657 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_FP_TQM_RING 0x6UL
3658 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_MRAV 0xeUL
3659 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_TIM 0xfUL
3660 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_TKC 0x13UL
3661 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_RKC 0x14UL
3662 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_MP_TQM_RING 0x15UL
3663 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_SQ_DB_SHADOW 0x16UL
3664 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_RQ_DB_SHADOW 0x17UL
3665 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_SRQ_DB_SHADOW 0x18UL
3666 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_CQ_DB_SHADOW 0x19UL
3667 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_QUIC_TKC 0x1aUL
3668 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_QUIC_RKC 0x1bUL
3669 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_INVALID 0xffffUL
3670 #define FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_LAST FUNC_BACKING_STORE_QCAPS_V2_REQ_TYPE_INVALID
3674 /* hwrm_func_backing_store_qcaps_v2_output (size:448b/56B) */
3675 struct hwrm_func_backing_store_qcaps_v2_output {
3681 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_QP 0x0UL
3682 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_SRQ 0x1UL
3683 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_CQ 0x2UL
3684 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_VNIC 0x3UL
3685 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_STAT 0x4UL
3686 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_SP_TQM_RING 0x5UL
3687 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_FP_TQM_RING 0x6UL
3688 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_MRAV 0xeUL
3689 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_TIM 0xfUL
3690 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_TKC 0x13UL
3691 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_RKC 0x14UL
3692 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_MP_TQM_RING 0x15UL
3693 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_SQ_DB_SHADOW 0x16UL
3694 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_RQ_DB_SHADOW 0x17UL
3695 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_SRQ_DB_SHADOW 0x18UL
3696 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_CQ_DB_SHADOW 0x19UL
3697 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_QUIC_TKC 0x1aUL
3698 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_QUIC_RKC 0x1bUL
3699 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_INVALID 0xffffUL
3700 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_LAST FUNC_BACKING_STORE_QCAPS_V2_RESP_TYPE_INVALID
3703 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_FLAGS_ENABLE_CTX_KIND_INIT 0x1UL
3704 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_FLAGS_TYPE_VALID 0x2UL
3705 #define FUNC_BACKING_STORE_QCAPS_V2_RESP_FLAGS_DRIVER_MANAGED_MEMORY 0x4UL
3706 __le32 instance_bit_map;
3711 __le32 max_num_entries;
3712 __le32 min_num_entries;
3713 __le16 next_valid_type;
3714 u8 subtype_valid_cnt;
3716 __le32 split_entry_0;
3717 __le32 split_entry_1;
3718 __le32 split_entry_2;
3719 __le32 split_entry_3;
3724 /* hwrm_func_drv_if_change_input (size:192b/24B) */
3725 struct hwrm_func_drv_if_change_input {
3732 #define FUNC_DRV_IF_CHANGE_REQ_FLAGS_UP 0x1UL
3736 /* hwrm_func_drv_if_change_output (size:128b/16B) */
3737 struct hwrm_func_drv_if_change_output {
3743 #define FUNC_DRV_IF_CHANGE_RESP_FLAGS_RESC_CHANGE 0x1UL
3744 #define FUNC_DRV_IF_CHANGE_RESP_FLAGS_HOT_FW_RESET_DONE 0x2UL
3749 /* hwrm_port_phy_cfg_input (size:448b/56B) */
3750 struct hwrm_port_phy_cfg_input {
3757 #define PORT_PHY_CFG_REQ_FLAGS_RESET_PHY 0x1UL
3758 #define PORT_PHY_CFG_REQ_FLAGS_DEPRECATED 0x2UL
3759 #define PORT_PHY_CFG_REQ_FLAGS_FORCE 0x4UL
3760 #define PORT_PHY_CFG_REQ_FLAGS_RESTART_AUTONEG 0x8UL
3761 #define PORT_PHY_CFG_REQ_FLAGS_EEE_ENABLE 0x10UL
3762 #define PORT_PHY_CFG_REQ_FLAGS_EEE_DISABLE 0x20UL
3763 #define PORT_PHY_CFG_REQ_FLAGS_EEE_TX_LPI_ENABLE 0x40UL
3764 #define PORT_PHY_CFG_REQ_FLAGS_EEE_TX_LPI_DISABLE 0x80UL
3765 #define PORT_PHY_CFG_REQ_FLAGS_FEC_AUTONEG_ENABLE 0x100UL
3766 #define PORT_PHY_CFG_REQ_FLAGS_FEC_AUTONEG_DISABLE 0x200UL
3767 #define PORT_PHY_CFG_REQ_FLAGS_FEC_CLAUSE74_ENABLE 0x400UL
3768 #define PORT_PHY_CFG_REQ_FLAGS_FEC_CLAUSE74_DISABLE 0x800UL
3769 #define PORT_PHY_CFG_REQ_FLAGS_FEC_CLAUSE91_ENABLE 0x1000UL
3770 #define PORT_PHY_CFG_REQ_FLAGS_FEC_CLAUSE91_DISABLE 0x2000UL
3771 #define PORT_PHY_CFG_REQ_FLAGS_FORCE_LINK_DWN 0x4000UL
3772 #define PORT_PHY_CFG_REQ_FLAGS_FEC_RS544_1XN_ENABLE 0x8000UL
3773 #define PORT_PHY_CFG_REQ_FLAGS_FEC_RS544_1XN_DISABLE 0x10000UL
3774 #define PORT_PHY_CFG_REQ_FLAGS_FEC_RS544_IEEE_ENABLE 0x20000UL
3775 #define PORT_PHY_CFG_REQ_FLAGS_FEC_RS544_IEEE_DISABLE 0x40000UL
3776 #define PORT_PHY_CFG_REQ_FLAGS_FEC_RS272_1XN_ENABLE 0x80000UL
3777 #define PORT_PHY_CFG_REQ_FLAGS_FEC_RS272_1XN_DISABLE 0x100000UL
3778 #define PORT_PHY_CFG_REQ_FLAGS_FEC_RS272_IEEE_ENABLE 0x200000UL
3779 #define PORT_PHY_CFG_REQ_FLAGS_FEC_RS272_IEEE_DISABLE 0x400000UL
3781 #define PORT_PHY_CFG_REQ_ENABLES_AUTO_MODE 0x1UL
3782 #define PORT_PHY_CFG_REQ_ENABLES_AUTO_DUPLEX 0x2UL
3783 #define PORT_PHY_CFG_REQ_ENABLES_AUTO_PAUSE 0x4UL
3784 #define PORT_PHY_CFG_REQ_ENABLES_AUTO_LINK_SPEED 0x8UL
3785 #define PORT_PHY_CFG_REQ_ENABLES_AUTO_LINK_SPEED_MASK 0x10UL
3786 #define PORT_PHY_CFG_REQ_ENABLES_WIRESPEED 0x20UL
3787 #define PORT_PHY_CFG_REQ_ENABLES_LPBK 0x40UL
3788 #define PORT_PHY_CFG_REQ_ENABLES_PREEMPHASIS 0x80UL
3789 #define PORT_PHY_CFG_REQ_ENABLES_FORCE_PAUSE 0x100UL
3790 #define PORT_PHY_CFG_REQ_ENABLES_EEE_LINK_SPEED_MASK 0x200UL
3791 #define PORT_PHY_CFG_REQ_ENABLES_TX_LPI_TIMER 0x400UL
3792 #define PORT_PHY_CFG_REQ_ENABLES_FORCE_PAM4_LINK_SPEED 0x800UL
3793 #define PORT_PHY_CFG_REQ_ENABLES_AUTO_PAM4_LINK_SPEED_MASK 0x1000UL
3795 __le16 force_link_speed;
3796 #define PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_100MB 0x1UL
3797 #define PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_1GB 0xaUL
3798 #define PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_2GB 0x14UL
3799 #define PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_2_5GB 0x19UL
3800 #define PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_10GB 0x64UL
3801 #define PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_20GB 0xc8UL
3802 #define PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_25GB 0xfaUL
3803 #define PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_40GB 0x190UL
3804 #define PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_50GB 0x1f4UL
3805 #define PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_100GB 0x3e8UL
3806 #define PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_10MB 0xffffUL
3807 #define PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_LAST PORT_PHY_CFG_REQ_FORCE_LINK_SPEED_10MB
3809 #define PORT_PHY_CFG_REQ_AUTO_MODE_NONE 0x0UL
3810 #define PORT_PHY_CFG_REQ_AUTO_MODE_ALL_SPEEDS 0x1UL
3811 #define PORT_PHY_CFG_REQ_AUTO_MODE_ONE_SPEED 0x2UL
3812 #define PORT_PHY_CFG_REQ_AUTO_MODE_ONE_OR_BELOW 0x3UL
3813 #define PORT_PHY_CFG_REQ_AUTO_MODE_SPEED_MASK 0x4UL
3814 #define PORT_PHY_CFG_REQ_AUTO_MODE_LAST PORT_PHY_CFG_REQ_AUTO_MODE_SPEED_MASK
3816 #define PORT_PHY_CFG_REQ_AUTO_DUPLEX_HALF 0x0UL
3817 #define PORT_PHY_CFG_REQ_AUTO_DUPLEX_FULL 0x1UL
3818 #define PORT_PHY_CFG_REQ_AUTO_DUPLEX_BOTH 0x2UL
3819 #define PORT_PHY_CFG_REQ_AUTO_DUPLEX_LAST PORT_PHY_CFG_REQ_AUTO_DUPLEX_BOTH
3821 #define PORT_PHY_CFG_REQ_AUTO_PAUSE_TX 0x1UL
3822 #define PORT_PHY_CFG_REQ_AUTO_PAUSE_RX 0x2UL
3823 #define PORT_PHY_CFG_REQ_AUTO_PAUSE_AUTONEG_PAUSE 0x4UL
3825 __le16 auto_link_speed;
3826 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_100MB 0x1UL
3827 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_1GB 0xaUL
3828 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_2GB 0x14UL
3829 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_2_5GB 0x19UL
3830 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_10GB 0x64UL
3831 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_20GB 0xc8UL
3832 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_25GB 0xfaUL
3833 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_40GB 0x190UL
3834 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_50GB 0x1f4UL
3835 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_100GB 0x3e8UL
3836 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_10MB 0xffffUL
3837 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_LAST PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_10MB
3838 __le16 auto_link_speed_mask;
3839 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_100MBHD 0x1UL
3840 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_100MB 0x2UL
3841 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_1GBHD 0x4UL
3842 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_1GB 0x8UL
3843 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_2GB 0x10UL
3844 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_2_5GB 0x20UL
3845 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_10GB 0x40UL
3846 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_20GB 0x80UL
3847 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_25GB 0x100UL
3848 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_40GB 0x200UL
3849 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_50GB 0x400UL
3850 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_100GB 0x800UL
3851 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_10MBHD 0x1000UL
3852 #define PORT_PHY_CFG_REQ_AUTO_LINK_SPEED_MASK_10MB 0x2000UL
3854 #define PORT_PHY_CFG_REQ_WIRESPEED_OFF 0x0UL
3855 #define PORT_PHY_CFG_REQ_WIRESPEED_ON 0x1UL
3856 #define PORT_PHY_CFG_REQ_WIRESPEED_LAST PORT_PHY_CFG_REQ_WIRESPEED_ON
3858 #define PORT_PHY_CFG_REQ_LPBK_NONE 0x0UL
3859 #define PORT_PHY_CFG_REQ_LPBK_LOCAL 0x1UL
3860 #define PORT_PHY_CFG_REQ_LPBK_REMOTE 0x2UL
3861 #define PORT_PHY_CFG_REQ_LPBK_EXTERNAL 0x3UL
3862 #define PORT_PHY_CFG_REQ_LPBK_LAST PORT_PHY_CFG_REQ_LPBK_EXTERNAL
3864 #define PORT_PHY_CFG_REQ_FORCE_PAUSE_TX 0x1UL
3865 #define PORT_PHY_CFG_REQ_FORCE_PAUSE_RX 0x2UL
3868 __le16 eee_link_speed_mask;
3869 #define PORT_PHY_CFG_REQ_EEE_LINK_SPEED_MASK_RSVD1 0x1UL
3870 #define PORT_PHY_CFG_REQ_EEE_LINK_SPEED_MASK_100MB 0x2UL
3871 #define PORT_PHY_CFG_REQ_EEE_LINK_SPEED_MASK_RSVD2 0x4UL
3872 #define PORT_PHY_CFG_REQ_EEE_LINK_SPEED_MASK_1GB 0x8UL
3873 #define PORT_PHY_CFG_REQ_EEE_LINK_SPEED_MASK_RSVD3 0x10UL
3874 #define PORT_PHY_CFG_REQ_EEE_LINK_SPEED_MASK_RSVD4 0x20UL
3875 #define PORT_PHY_CFG_REQ_EEE_LINK_SPEED_MASK_10GB 0x40UL
3876 __le16 force_pam4_link_speed;
3877 #define PORT_PHY_CFG_REQ_FORCE_PAM4_LINK_SPEED_50GB 0x1f4UL
3878 #define PORT_PHY_CFG_REQ_FORCE_PAM4_LINK_SPEED_100GB 0x3e8UL
3879 #define PORT_PHY_CFG_REQ_FORCE_PAM4_LINK_SPEED_200GB 0x7d0UL
3880 #define PORT_PHY_CFG_REQ_FORCE_PAM4_LINK_SPEED_LAST PORT_PHY_CFG_REQ_FORCE_PAM4_LINK_SPEED_200GB
3881 __le32 tx_lpi_timer;
3882 #define PORT_PHY_CFG_REQ_TX_LPI_TIMER_MASK 0xffffffUL
3883 #define PORT_PHY_CFG_REQ_TX_LPI_TIMER_SFT 0
3884 __le16 auto_link_pam4_speed_mask;
3885 #define PORT_PHY_CFG_REQ_AUTO_LINK_PAM4_SPEED_MASK_50G 0x1UL
3886 #define PORT_PHY_CFG_REQ_AUTO_LINK_PAM4_SPEED_MASK_100G 0x2UL
3887 #define PORT_PHY_CFG_REQ_AUTO_LINK_PAM4_SPEED_MASK_200G 0x4UL
3891 /* hwrm_port_phy_cfg_output (size:128b/16B) */
3892 struct hwrm_port_phy_cfg_output {
3901 /* hwrm_port_phy_cfg_cmd_err (size:64b/8B) */
3902 struct hwrm_port_phy_cfg_cmd_err {
3904 #define PORT_PHY_CFG_CMD_ERR_CODE_UNKNOWN 0x0UL
3905 #define PORT_PHY_CFG_CMD_ERR_CODE_ILLEGAL_SPEED 0x1UL
3906 #define PORT_PHY_CFG_CMD_ERR_CODE_RETRY 0x2UL
3907 #define PORT_PHY_CFG_CMD_ERR_CODE_LAST PORT_PHY_CFG_CMD_ERR_CODE_RETRY
3911 /* hwrm_port_phy_qcfg_input (size:192b/24B) */
3912 struct hwrm_port_phy_qcfg_input {
3922 /* hwrm_port_phy_qcfg_output (size:832b/104B) */
3923 struct hwrm_port_phy_qcfg_output {
3929 #define PORT_PHY_QCFG_RESP_LINK_NO_LINK 0x0UL
3930 #define PORT_PHY_QCFG_RESP_LINK_SIGNAL 0x1UL
3931 #define PORT_PHY_QCFG_RESP_LINK_LINK 0x2UL
3932 #define PORT_PHY_QCFG_RESP_LINK_LAST PORT_PHY_QCFG_RESP_LINK_LINK
3933 u8 active_fec_signal_mode;
3934 #define PORT_PHY_QCFG_RESP_SIGNAL_MODE_MASK 0xfUL
3935 #define PORT_PHY_QCFG_RESP_SIGNAL_MODE_SFT 0
3936 #define PORT_PHY_QCFG_RESP_SIGNAL_MODE_NRZ 0x0UL
3937 #define PORT_PHY_QCFG_RESP_SIGNAL_MODE_PAM4 0x1UL
3938 #define PORT_PHY_QCFG_RESP_SIGNAL_MODE_LAST PORT_PHY_QCFG_RESP_SIGNAL_MODE_PAM4
3939 #define PORT_PHY_QCFG_RESP_ACTIVE_FEC_MASK 0xf0UL
3940 #define PORT_PHY_QCFG_RESP_ACTIVE_FEC_SFT 4
3941 #define PORT_PHY_QCFG_RESP_ACTIVE_FEC_FEC_NONE_ACTIVE (0x0UL << 4)
3942 #define PORT_PHY_QCFG_RESP_ACTIVE_FEC_FEC_CLAUSE74_ACTIVE (0x1UL << 4)
3943 #define PORT_PHY_QCFG_RESP_ACTIVE_FEC_FEC_CLAUSE91_ACTIVE (0x2UL << 4)
3944 #define PORT_PHY_QCFG_RESP_ACTIVE_FEC_FEC_RS544_1XN_ACTIVE (0x3UL << 4)
3945 #define PORT_PHY_QCFG_RESP_ACTIVE_FEC_FEC_RS544_IEEE_ACTIVE (0x4UL << 4)
3946 #define PORT_PHY_QCFG_RESP_ACTIVE_FEC_FEC_RS272_1XN_ACTIVE (0x5UL << 4)
3947 #define PORT_PHY_QCFG_RESP_ACTIVE_FEC_FEC_RS272_IEEE_ACTIVE (0x6UL << 4)
3948 #define PORT_PHY_QCFG_RESP_ACTIVE_FEC_LAST PORT_PHY_QCFG_RESP_ACTIVE_FEC_FEC_RS272_IEEE_ACTIVE
3950 #define PORT_PHY_QCFG_RESP_LINK_SPEED_100MB 0x1UL
3951 #define PORT_PHY_QCFG_RESP_LINK_SPEED_1GB 0xaUL
3952 #define PORT_PHY_QCFG_RESP_LINK_SPEED_2GB 0x14UL
3953 #define PORT_PHY_QCFG_RESP_LINK_SPEED_2_5GB 0x19UL
3954 #define PORT_PHY_QCFG_RESP_LINK_SPEED_10GB 0x64UL
3955 #define PORT_PHY_QCFG_RESP_LINK_SPEED_20GB 0xc8UL
3956 #define PORT_PHY_QCFG_RESP_LINK_SPEED_25GB 0xfaUL
3957 #define PORT_PHY_QCFG_RESP_LINK_SPEED_40GB 0x190UL
3958 #define PORT_PHY_QCFG_RESP_LINK_SPEED_50GB 0x1f4UL
3959 #define PORT_PHY_QCFG_RESP_LINK_SPEED_100GB 0x3e8UL
3960 #define PORT_PHY_QCFG_RESP_LINK_SPEED_200GB 0x7d0UL
3961 #define PORT_PHY_QCFG_RESP_LINK_SPEED_10MB 0xffffUL
3962 #define PORT_PHY_QCFG_RESP_LINK_SPEED_LAST PORT_PHY_QCFG_RESP_LINK_SPEED_10MB
3964 #define PORT_PHY_QCFG_RESP_DUPLEX_CFG_HALF 0x0UL
3965 #define PORT_PHY_QCFG_RESP_DUPLEX_CFG_FULL 0x1UL
3966 #define PORT_PHY_QCFG_RESP_DUPLEX_CFG_LAST PORT_PHY_QCFG_RESP_DUPLEX_CFG_FULL
3968 #define PORT_PHY_QCFG_RESP_PAUSE_TX 0x1UL
3969 #define PORT_PHY_QCFG_RESP_PAUSE_RX 0x2UL
3970 __le16 support_speeds;
3971 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_100MBHD 0x1UL
3972 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_100MB 0x2UL
3973 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_1GBHD 0x4UL
3974 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_1GB 0x8UL
3975 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_2GB 0x10UL
3976 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_2_5GB 0x20UL
3977 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_10GB 0x40UL
3978 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_20GB 0x80UL
3979 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_25GB 0x100UL
3980 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_40GB 0x200UL
3981 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_50GB 0x400UL
3982 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_100GB 0x800UL
3983 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_10MBHD 0x1000UL
3984 #define PORT_PHY_QCFG_RESP_SUPPORT_SPEEDS_10MB 0x2000UL
3985 __le16 force_link_speed;
3986 #define PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_100MB 0x1UL
3987 #define PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_1GB 0xaUL
3988 #define PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_2GB 0x14UL
3989 #define PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_2_5GB 0x19UL
3990 #define PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_10GB 0x64UL
3991 #define PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_20GB 0xc8UL
3992 #define PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_25GB 0xfaUL
3993 #define PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_40GB 0x190UL
3994 #define PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_50GB 0x1f4UL
3995 #define PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_100GB 0x3e8UL
3996 #define PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_10MB 0xffffUL
3997 #define PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_LAST PORT_PHY_QCFG_RESP_FORCE_LINK_SPEED_10MB
3999 #define PORT_PHY_QCFG_RESP_AUTO_MODE_NONE 0x0UL
4000 #define PORT_PHY_QCFG_RESP_AUTO_MODE_ALL_SPEEDS 0x1UL
4001 #define PORT_PHY_QCFG_RESP_AUTO_MODE_ONE_SPEED 0x2UL
4002 #define PORT_PHY_QCFG_RESP_AUTO_MODE_ONE_OR_BELOW 0x3UL
4003 #define PORT_PHY_QCFG_RESP_AUTO_MODE_SPEED_MASK 0x4UL
4004 #define PORT_PHY_QCFG_RESP_AUTO_MODE_LAST PORT_PHY_QCFG_RESP_AUTO_MODE_SPEED_MASK
4006 #define PORT_PHY_QCFG_RESP_AUTO_PAUSE_TX 0x1UL
4007 #define PORT_PHY_QCFG_RESP_AUTO_PAUSE_RX 0x2UL
4008 #define PORT_PHY_QCFG_RESP_AUTO_PAUSE_AUTONEG_PAUSE 0x4UL
4009 __le16 auto_link_speed;
4010 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_100MB 0x1UL
4011 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_1GB 0xaUL
4012 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_2GB 0x14UL
4013 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_2_5GB 0x19UL
4014 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_10GB 0x64UL
4015 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_20GB 0xc8UL
4016 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_25GB 0xfaUL
4017 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_40GB 0x190UL
4018 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_50GB 0x1f4UL
4019 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_100GB 0x3e8UL
4020 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_10MB 0xffffUL
4021 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_LAST PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_10MB
4022 __le16 auto_link_speed_mask;
4023 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_100MBHD 0x1UL
4024 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_100MB 0x2UL
4025 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_1GBHD 0x4UL
4026 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_1GB 0x8UL
4027 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_2GB 0x10UL
4028 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_2_5GB 0x20UL
4029 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_10GB 0x40UL
4030 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_20GB 0x80UL
4031 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_25GB 0x100UL
4032 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_40GB 0x200UL
4033 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_50GB 0x400UL
4034 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_100GB 0x800UL
4035 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_10MBHD 0x1000UL
4036 #define PORT_PHY_QCFG_RESP_AUTO_LINK_SPEED_MASK_10MB 0x2000UL
4038 #define PORT_PHY_QCFG_RESP_WIRESPEED_OFF 0x0UL
4039 #define PORT_PHY_QCFG_RESP_WIRESPEED_ON 0x1UL
4040 #define PORT_PHY_QCFG_RESP_WIRESPEED_LAST PORT_PHY_QCFG_RESP_WIRESPEED_ON
4042 #define PORT_PHY_QCFG_RESP_LPBK_NONE 0x0UL
4043 #define PORT_PHY_QCFG_RESP_LPBK_LOCAL 0x1UL
4044 #define PORT_PHY_QCFG_RESP_LPBK_REMOTE 0x2UL
4045 #define PORT_PHY_QCFG_RESP_LPBK_EXTERNAL 0x3UL
4046 #define PORT_PHY_QCFG_RESP_LPBK_LAST PORT_PHY_QCFG_RESP_LPBK_EXTERNAL
4048 #define PORT_PHY_QCFG_RESP_FORCE_PAUSE_TX 0x1UL
4049 #define PORT_PHY_QCFG_RESP_FORCE_PAUSE_RX 0x2UL
4051 #define PORT_PHY_QCFG_RESP_MODULE_STATUS_NONE 0x0UL
4052 #define PORT_PHY_QCFG_RESP_MODULE_STATUS_DISABLETX 0x1UL
4053 #define PORT_PHY_QCFG_RESP_MODULE_STATUS_WARNINGMSG 0x2UL
4054 #define PORT_PHY_QCFG_RESP_MODULE_STATUS_PWRDOWN 0x3UL
4055 #define PORT_PHY_QCFG_RESP_MODULE_STATUS_NOTINSERTED 0x4UL
4056 #define PORT_PHY_QCFG_RESP_MODULE_STATUS_CURRENTFAULT 0x5UL
4057 #define PORT_PHY_QCFG_RESP_MODULE_STATUS_NOTAPPLICABLE 0xffUL
4058 #define PORT_PHY_QCFG_RESP_MODULE_STATUS_LAST PORT_PHY_QCFG_RESP_MODULE_STATUS_NOTAPPLICABLE
4064 #define PORT_PHY_QCFG_RESP_PHY_TYPE_UNKNOWN 0x0UL
4065 #define PORT_PHY_QCFG_RESP_PHY_TYPE_BASECR 0x1UL
4066 #define PORT_PHY_QCFG_RESP_PHY_TYPE_BASEKR4 0x2UL
4067 #define PORT_PHY_QCFG_RESP_PHY_TYPE_BASELR 0x3UL
4068 #define PORT_PHY_QCFG_RESP_PHY_TYPE_BASESR 0x4UL
4069 #define PORT_PHY_QCFG_RESP_PHY_TYPE_BASEKR2 0x5UL
4070 #define PORT_PHY_QCFG_RESP_PHY_TYPE_BASEKX 0x6UL
4071 #define PORT_PHY_QCFG_RESP_PHY_TYPE_BASEKR 0x7UL
4072 #define PORT_PHY_QCFG_RESP_PHY_TYPE_BASET 0x8UL
4073 #define PORT_PHY_QCFG_RESP_PHY_TYPE_BASETE 0x9UL
4074 #define PORT_PHY_QCFG_RESP_PHY_TYPE_SGMIIEXTPHY 0xaUL
4075 #define PORT_PHY_QCFG_RESP_PHY_TYPE_25G_BASECR_CA_L 0xbUL
4076 #define PORT_PHY_QCFG_RESP_PHY_TYPE_25G_BASECR_CA_S 0xcUL
4077 #define PORT_PHY_QCFG_RESP_PHY_TYPE_25G_BASECR_CA_N 0xdUL
4078 #define PORT_PHY_QCFG_RESP_PHY_TYPE_25G_BASESR 0xeUL
4079 #define PORT_PHY_QCFG_RESP_PHY_TYPE_100G_BASECR4 0xfUL
4080 #define PORT_PHY_QCFG_RESP_PHY_TYPE_100G_BASESR4 0x10UL
4081 #define PORT_PHY_QCFG_RESP_PHY_TYPE_100G_BASELR4 0x11UL
4082 #define PORT_PHY_QCFG_RESP_PHY_TYPE_100G_BASEER4 0x12UL
4083 #define PORT_PHY_QCFG_RESP_PHY_TYPE_100G_BASESR10 0x13UL
4084 #define PORT_PHY_QCFG_RESP_PHY_TYPE_40G_BASECR4 0x14UL
4085 #define PORT_PHY_QCFG_RESP_PHY_TYPE_40G_BASESR4 0x15UL
4086 #define PORT_PHY_QCFG_RESP_PHY_TYPE_40G_BASELR4 0x16UL
4087 #define PORT_PHY_QCFG_RESP_PHY_TYPE_40G_BASEER4 0x17UL
4088 #define PORT_PHY_QCFG_RESP_PHY_TYPE_40G_ACTIVE_CABLE 0x18UL
4089 #define PORT_PHY_QCFG_RESP_PHY_TYPE_1G_BASET 0x19UL
4090 #define PORT_PHY_QCFG_RESP_PHY_TYPE_1G_BASESX 0x1aUL
4091 #define PORT_PHY_QCFG_RESP_PHY_TYPE_1G_BASECX 0x1bUL
4092 #define PORT_PHY_QCFG_RESP_PHY_TYPE_200G_BASECR4 0x1cUL
4093 #define PORT_PHY_QCFG_RESP_PHY_TYPE_200G_BASESR4 0x1dUL
4094 #define PORT_PHY_QCFG_RESP_PHY_TYPE_200G_BASELR4 0x1eUL
4095 #define PORT_PHY_QCFG_RESP_PHY_TYPE_200G_BASEER4 0x1fUL
4096 #define PORT_PHY_QCFG_RESP_PHY_TYPE_50G_BASECR 0x20UL
4097 #define PORT_PHY_QCFG_RESP_PHY_TYPE_50G_BASESR 0x21UL
4098 #define PORT_PHY_QCFG_RESP_PHY_TYPE_50G_BASELR 0x22UL
4099 #define PORT_PHY_QCFG_RESP_PHY_TYPE_50G_BASEER 0x23UL
4100 #define PORT_PHY_QCFG_RESP_PHY_TYPE_100G_BASECR2 0x24UL
4101 #define PORT_PHY_QCFG_RESP_PHY_TYPE_100G_BASESR2 0x25UL
4102 #define PORT_PHY_QCFG_RESP_PHY_TYPE_100G_BASELR2 0x26UL
4103 #define PORT_PHY_QCFG_RESP_PHY_TYPE_100G_BASEER2 0x27UL
4104 #define PORT_PHY_QCFG_RESP_PHY_TYPE_LAST PORT_PHY_QCFG_RESP_PHY_TYPE_100G_BASEER2
4106 #define PORT_PHY_QCFG_RESP_MEDIA_TYPE_UNKNOWN 0x0UL
4107 #define PORT_PHY_QCFG_RESP_MEDIA_TYPE_TP 0x1UL
4108 #define PORT_PHY_QCFG_RESP_MEDIA_TYPE_DAC 0x2UL
4109 #define PORT_PHY_QCFG_RESP_MEDIA_TYPE_FIBRE 0x3UL
4110 #define PORT_PHY_QCFG_RESP_MEDIA_TYPE_LAST PORT_PHY_QCFG_RESP_MEDIA_TYPE_FIBRE
4112 #define PORT_PHY_QCFG_RESP_XCVR_PKG_TYPE_XCVR_INTERNAL 0x1UL
4113 #define PORT_PHY_QCFG_RESP_XCVR_PKG_TYPE_XCVR_EXTERNAL 0x2UL
4114 #define PORT_PHY_QCFG_RESP_XCVR_PKG_TYPE_LAST PORT_PHY_QCFG_RESP_XCVR_PKG_TYPE_XCVR_EXTERNAL
4115 u8 eee_config_phy_addr;
4116 #define PORT_PHY_QCFG_RESP_PHY_ADDR_MASK 0x1fUL
4117 #define PORT_PHY_QCFG_RESP_PHY_ADDR_SFT 0
4118 #define PORT_PHY_QCFG_RESP_EEE_CONFIG_MASK 0xe0UL
4119 #define PORT_PHY_QCFG_RESP_EEE_CONFIG_SFT 5
4120 #define PORT_PHY_QCFG_RESP_EEE_CONFIG_EEE_ENABLED 0x20UL
4121 #define PORT_PHY_QCFG_RESP_EEE_CONFIG_EEE_ACTIVE 0x40UL
4122 #define PORT_PHY_QCFG_RESP_EEE_CONFIG_EEE_TX_LPI 0x80UL
4124 #define PORT_PHY_QCFG_RESP_PARALLEL_DETECT 0x1UL
4125 __le16 link_partner_adv_speeds;
4126 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_100MBHD 0x1UL
4127 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_100MB 0x2UL
4128 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_1GBHD 0x4UL
4129 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_1GB 0x8UL
4130 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_2GB 0x10UL
4131 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_2_5GB 0x20UL
4132 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_10GB 0x40UL
4133 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_20GB 0x80UL
4134 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_25GB 0x100UL
4135 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_40GB 0x200UL
4136 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_50GB 0x400UL
4137 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_100GB 0x800UL
4138 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_10MBHD 0x1000UL
4139 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_SPEEDS_10MB 0x2000UL
4140 u8 link_partner_adv_auto_mode;
4141 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_AUTO_MODE_NONE 0x0UL
4142 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_AUTO_MODE_ALL_SPEEDS 0x1UL
4143 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_AUTO_MODE_ONE_SPEED 0x2UL
4144 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_AUTO_MODE_ONE_OR_BELOW 0x3UL
4145 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_AUTO_MODE_SPEED_MASK 0x4UL
4146 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_AUTO_MODE_LAST PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_AUTO_MODE_SPEED_MASK
4147 u8 link_partner_adv_pause;
4148 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_PAUSE_TX 0x1UL
4149 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_PAUSE_RX 0x2UL
4150 __le16 adv_eee_link_speed_mask;
4151 #define PORT_PHY_QCFG_RESP_ADV_EEE_LINK_SPEED_MASK_RSVD1 0x1UL
4152 #define PORT_PHY_QCFG_RESP_ADV_EEE_LINK_SPEED_MASK_100MB 0x2UL
4153 #define PORT_PHY_QCFG_RESP_ADV_EEE_LINK_SPEED_MASK_RSVD2 0x4UL
4154 #define PORT_PHY_QCFG_RESP_ADV_EEE_LINK_SPEED_MASK_1GB 0x8UL
4155 #define PORT_PHY_QCFG_RESP_ADV_EEE_LINK_SPEED_MASK_RSVD3 0x10UL
4156 #define PORT_PHY_QCFG_RESP_ADV_EEE_LINK_SPEED_MASK_RSVD4 0x20UL
4157 #define PORT_PHY_QCFG_RESP_ADV_EEE_LINK_SPEED_MASK_10GB 0x40UL
4158 __le16 link_partner_adv_eee_link_speed_mask;
4159 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_EEE_LINK_SPEED_MASK_RSVD1 0x1UL
4160 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_EEE_LINK_SPEED_MASK_100MB 0x2UL
4161 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_EEE_LINK_SPEED_MASK_RSVD2 0x4UL
4162 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_EEE_LINK_SPEED_MASK_1GB 0x8UL
4163 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_EEE_LINK_SPEED_MASK_RSVD3 0x10UL
4164 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_EEE_LINK_SPEED_MASK_RSVD4 0x20UL
4165 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_ADV_EEE_LINK_SPEED_MASK_10GB 0x40UL
4166 __le32 xcvr_identifier_type_tx_lpi_timer;
4167 #define PORT_PHY_QCFG_RESP_TX_LPI_TIMER_MASK 0xffffffUL
4168 #define PORT_PHY_QCFG_RESP_TX_LPI_TIMER_SFT 0
4169 #define PORT_PHY_QCFG_RESP_XCVR_IDENTIFIER_TYPE_MASK 0xff000000UL
4170 #define PORT_PHY_QCFG_RESP_XCVR_IDENTIFIER_TYPE_SFT 24
4171 #define PORT_PHY_QCFG_RESP_XCVR_IDENTIFIER_TYPE_UNKNOWN (0x0UL << 24)
4172 #define PORT_PHY_QCFG_RESP_XCVR_IDENTIFIER_TYPE_SFP (0x3UL << 24)
4173 #define PORT_PHY_QCFG_RESP_XCVR_IDENTIFIER_TYPE_QSFP (0xcUL << 24)
4174 #define PORT_PHY_QCFG_RESP_XCVR_IDENTIFIER_TYPE_QSFPPLUS (0xdUL << 24)
4175 #define PORT_PHY_QCFG_RESP_XCVR_IDENTIFIER_TYPE_QSFP28 (0x11UL << 24)
4176 #define PORT_PHY_QCFG_RESP_XCVR_IDENTIFIER_TYPE_LAST PORT_PHY_QCFG_RESP_XCVR_IDENTIFIER_TYPE_QSFP28
4178 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_NONE_SUPPORTED 0x1UL
4179 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_AUTONEG_SUPPORTED 0x2UL
4180 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_AUTONEG_ENABLED 0x4UL
4181 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_CLAUSE74_SUPPORTED 0x8UL
4182 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_CLAUSE74_ENABLED 0x10UL
4183 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_CLAUSE91_SUPPORTED 0x20UL
4184 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_CLAUSE91_ENABLED 0x40UL
4185 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_RS544_1XN_SUPPORTED 0x80UL
4186 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_RS544_1XN_ENABLED 0x100UL
4187 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_RS544_IEEE_SUPPORTED 0x200UL
4188 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_RS544_IEEE_ENABLED 0x400UL
4189 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_RS272_1XN_SUPPORTED 0x800UL
4190 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_RS272_1XN_ENABLED 0x1000UL
4191 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_RS272_IEEE_SUPPORTED 0x2000UL
4192 #define PORT_PHY_QCFG_RESP_FEC_CFG_FEC_RS272_IEEE_ENABLED 0x4000UL
4194 #define PORT_PHY_QCFG_RESP_DUPLEX_STATE_HALF 0x0UL
4195 #define PORT_PHY_QCFG_RESP_DUPLEX_STATE_FULL 0x1UL
4196 #define PORT_PHY_QCFG_RESP_DUPLEX_STATE_LAST PORT_PHY_QCFG_RESP_DUPLEX_STATE_FULL
4198 #define PORT_PHY_QCFG_RESP_OPTION_FLAGS_MEDIA_AUTO_DETECT 0x1UL
4199 #define PORT_PHY_QCFG_RESP_OPTION_FLAGS_SIGNAL_MODE_KNOWN 0x2UL
4200 char phy_vendor_name[16];
4201 char phy_vendor_partnumber[16];
4202 __le16 support_pam4_speeds;
4203 #define PORT_PHY_QCFG_RESP_SUPPORT_PAM4_SPEEDS_50G 0x1UL
4204 #define PORT_PHY_QCFG_RESP_SUPPORT_PAM4_SPEEDS_100G 0x2UL
4205 #define PORT_PHY_QCFG_RESP_SUPPORT_PAM4_SPEEDS_200G 0x4UL
4206 __le16 force_pam4_link_speed;
4207 #define PORT_PHY_QCFG_RESP_FORCE_PAM4_LINK_SPEED_50GB 0x1f4UL
4208 #define PORT_PHY_QCFG_RESP_FORCE_PAM4_LINK_SPEED_100GB 0x3e8UL
4209 #define PORT_PHY_QCFG_RESP_FORCE_PAM4_LINK_SPEED_200GB 0x7d0UL
4210 #define PORT_PHY_QCFG_RESP_FORCE_PAM4_LINK_SPEED_LAST PORT_PHY_QCFG_RESP_FORCE_PAM4_LINK_SPEED_200GB
4211 __le16 auto_pam4_link_speed_mask;
4212 #define PORT_PHY_QCFG_RESP_AUTO_PAM4_LINK_SPEED_MASK_50G 0x1UL
4213 #define PORT_PHY_QCFG_RESP_AUTO_PAM4_LINK_SPEED_MASK_100G 0x2UL
4214 #define PORT_PHY_QCFG_RESP_AUTO_PAM4_LINK_SPEED_MASK_200G 0x4UL
4215 u8 link_partner_pam4_adv_speeds;
4216 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_PAM4_ADV_SPEEDS_50GB 0x1UL
4217 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_PAM4_ADV_SPEEDS_100GB 0x2UL
4218 #define PORT_PHY_QCFG_RESP_LINK_PARTNER_PAM4_ADV_SPEEDS_200GB 0x4UL
4219 u8 link_down_reason;
4220 #define PORT_PHY_QCFG_RESP_LINK_DOWN_REASON_RF 0x1UL
4225 /* hwrm_port_mac_cfg_input (size:448b/56B) */
4226 struct hwrm_port_mac_cfg_input {
4233 #define PORT_MAC_CFG_REQ_FLAGS_MATCH_LINK 0x1UL
4234 #define PORT_MAC_CFG_REQ_FLAGS_VLAN_PRI2COS_ENABLE 0x2UL
4235 #define PORT_MAC_CFG_REQ_FLAGS_TUNNEL_PRI2COS_ENABLE 0x4UL
4236 #define PORT_MAC_CFG_REQ_FLAGS_IP_DSCP2COS_ENABLE 0x8UL
4237 #define PORT_MAC_CFG_REQ_FLAGS_PTP_RX_TS_CAPTURE_ENABLE 0x10UL
4238 #define PORT_MAC_CFG_REQ_FLAGS_PTP_RX_TS_CAPTURE_DISABLE 0x20UL
4239 #define PORT_MAC_CFG_REQ_FLAGS_PTP_TX_TS_CAPTURE_ENABLE 0x40UL
4240 #define PORT_MAC_CFG_REQ_FLAGS_PTP_TX_TS_CAPTURE_DISABLE 0x80UL
4241 #define PORT_MAC_CFG_REQ_FLAGS_OOB_WOL_ENABLE 0x100UL
4242 #define PORT_MAC_CFG_REQ_FLAGS_OOB_WOL_DISABLE 0x200UL
4243 #define PORT_MAC_CFG_REQ_FLAGS_VLAN_PRI2COS_DISABLE 0x400UL
4244 #define PORT_MAC_CFG_REQ_FLAGS_TUNNEL_PRI2COS_DISABLE 0x800UL
4245 #define PORT_MAC_CFG_REQ_FLAGS_IP_DSCP2COS_DISABLE 0x1000UL
4246 #define PORT_MAC_CFG_REQ_FLAGS_PTP_ONE_STEP_TX_TS 0x2000UL
4247 #define PORT_MAC_CFG_REQ_FLAGS_ALL_RX_TS_CAPTURE_ENABLE 0x4000UL
4248 #define PORT_MAC_CFG_REQ_FLAGS_ALL_RX_TS_CAPTURE_DISABLE 0x8000UL
4250 #define PORT_MAC_CFG_REQ_ENABLES_IPG 0x1UL
4251 #define PORT_MAC_CFG_REQ_ENABLES_LPBK 0x2UL
4252 #define PORT_MAC_CFG_REQ_ENABLES_VLAN_PRI2COS_MAP_PRI 0x4UL
4253 #define PORT_MAC_CFG_REQ_ENABLES_TUNNEL_PRI2COS_MAP_PRI 0x10UL
4254 #define PORT_MAC_CFG_REQ_ENABLES_DSCP2COS_MAP_PRI 0x20UL
4255 #define PORT_MAC_CFG_REQ_ENABLES_RX_TS_CAPTURE_PTP_MSG_TYPE 0x40UL
4256 #define PORT_MAC_CFG_REQ_ENABLES_TX_TS_CAPTURE_PTP_MSG_TYPE 0x80UL
4257 #define PORT_MAC_CFG_REQ_ENABLES_COS_FIELD_CFG 0x100UL
4258 #define PORT_MAC_CFG_REQ_ENABLES_PTP_FREQ_ADJ_PPB 0x200UL
4259 #define PORT_MAC_CFG_REQ_ENABLES_PTP_ADJ_PHASE 0x400UL
4263 #define PORT_MAC_CFG_REQ_LPBK_NONE 0x0UL
4264 #define PORT_MAC_CFG_REQ_LPBK_LOCAL 0x1UL
4265 #define PORT_MAC_CFG_REQ_LPBK_REMOTE 0x2UL
4266 #define PORT_MAC_CFG_REQ_LPBK_LAST PORT_MAC_CFG_REQ_LPBK_REMOTE
4267 u8 vlan_pri2cos_map_pri;
4269 u8 tunnel_pri2cos_map_pri;
4270 u8 dscp2pri_map_pri;
4271 __le16 rx_ts_capture_ptp_msg_type;
4272 __le16 tx_ts_capture_ptp_msg_type;
4274 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_RSVD1 0x1UL
4275 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_VLAN_PRI_SEL_MASK 0x6UL
4276 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_VLAN_PRI_SEL_SFT 1
4277 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_VLAN_PRI_SEL_INNERMOST (0x0UL << 1)
4278 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_VLAN_PRI_SEL_OUTER (0x1UL << 1)
4279 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_VLAN_PRI_SEL_OUTERMOST (0x2UL << 1)
4280 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_VLAN_PRI_SEL_UNSPECIFIED (0x3UL << 1)
4281 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_VLAN_PRI_SEL_LAST PORT_MAC_CFG_REQ_COS_FIELD_CFG_VLAN_PRI_SEL_UNSPECIFIED
4282 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_T_VLAN_PRI_SEL_MASK 0x18UL
4283 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_T_VLAN_PRI_SEL_SFT 3
4284 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_T_VLAN_PRI_SEL_INNERMOST (0x0UL << 3)
4285 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_T_VLAN_PRI_SEL_OUTER (0x1UL << 3)
4286 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_T_VLAN_PRI_SEL_OUTERMOST (0x2UL << 3)
4287 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_T_VLAN_PRI_SEL_UNSPECIFIED (0x3UL << 3)
4288 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_T_VLAN_PRI_SEL_LAST PORT_MAC_CFG_REQ_COS_FIELD_CFG_T_VLAN_PRI_SEL_UNSPECIFIED
4289 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_DEFAULT_COS_MASK 0xe0UL
4290 #define PORT_MAC_CFG_REQ_COS_FIELD_CFG_DEFAULT_COS_SFT 5
4292 __le32 ptp_freq_adj_ppb;
4294 __le64 ptp_adj_phase;
4297 /* hwrm_port_mac_cfg_output (size:128b/16B) */
4298 struct hwrm_port_mac_cfg_output {
4307 #define PORT_MAC_CFG_RESP_LPBK_NONE 0x0UL
4308 #define PORT_MAC_CFG_RESP_LPBK_LOCAL 0x1UL
4309 #define PORT_MAC_CFG_RESP_LPBK_REMOTE 0x2UL
4310 #define PORT_MAC_CFG_RESP_LPBK_LAST PORT_MAC_CFG_RESP_LPBK_REMOTE
4315 /* hwrm_port_mac_ptp_qcfg_input (size:192b/24B) */
4316 struct hwrm_port_mac_ptp_qcfg_input {
4326 /* hwrm_port_mac_ptp_qcfg_output (size:704b/88B) */
4327 struct hwrm_port_mac_ptp_qcfg_output {
4333 #define PORT_MAC_PTP_QCFG_RESP_FLAGS_DIRECT_ACCESS 0x1UL
4334 #define PORT_MAC_PTP_QCFG_RESP_FLAGS_ONE_STEP_TX_TS 0x4UL
4335 #define PORT_MAC_PTP_QCFG_RESP_FLAGS_HWRM_ACCESS 0x8UL
4336 #define PORT_MAC_PTP_QCFG_RESP_FLAGS_PARTIAL_DIRECT_ACCESS_REF_CLOCK 0x10UL
4337 #define PORT_MAC_PTP_QCFG_RESP_FLAGS_RTC_CONFIGURED 0x20UL
4339 __le32 rx_ts_reg_off_lower;
4340 __le32 rx_ts_reg_off_upper;
4341 __le32 rx_ts_reg_off_seq_id;
4342 __le32 rx_ts_reg_off_src_id_0;
4343 __le32 rx_ts_reg_off_src_id_1;
4344 __le32 rx_ts_reg_off_src_id_2;
4345 __le32 rx_ts_reg_off_domain_id;
4346 __le32 rx_ts_reg_off_fifo;
4347 __le32 rx_ts_reg_off_fifo_adv;
4348 __le32 rx_ts_reg_off_granularity;
4349 __le32 tx_ts_reg_off_lower;
4350 __le32 tx_ts_reg_off_upper;
4351 __le32 tx_ts_reg_off_seq_id;
4352 __le32 tx_ts_reg_off_fifo;
4353 __le32 tx_ts_reg_off_granularity;
4354 __le32 ts_ref_clock_reg_lower;
4355 __le32 ts_ref_clock_reg_upper;
4360 /* tx_port_stats (size:3264b/408B) */
4361 struct tx_port_stats {
4362 __le64 tx_64b_frames;
4363 __le64 tx_65b_127b_frames;
4364 __le64 tx_128b_255b_frames;
4365 __le64 tx_256b_511b_frames;
4366 __le64 tx_512b_1023b_frames;
4367 __le64 tx_1024b_1518b_frames;
4368 __le64 tx_good_vlan_frames;
4369 __le64 tx_1519b_2047b_frames;
4370 __le64 tx_2048b_4095b_frames;
4371 __le64 tx_4096b_9216b_frames;
4372 __le64 tx_9217b_16383b_frames;
4373 __le64 tx_good_frames;
4374 __le64 tx_total_frames;
4375 __le64 tx_ucast_frames;
4376 __le64 tx_mcast_frames;
4377 __le64 tx_bcast_frames;
4378 __le64 tx_pause_frames;
4379 __le64 tx_pfc_frames;
4380 __le64 tx_jabber_frames;
4381 __le64 tx_fcs_err_frames;
4382 __le64 tx_control_frames;
4383 __le64 tx_oversz_frames;
4384 __le64 tx_single_dfrl_frames;
4385 __le64 tx_multi_dfrl_frames;
4386 __le64 tx_single_coll_frames;
4387 __le64 tx_multi_coll_frames;
4388 __le64 tx_late_coll_frames;
4389 __le64 tx_excessive_coll_frames;
4390 __le64 tx_frag_frames;
4392 __le64 tx_tagged_frames;
4393 __le64 tx_dbl_tagged_frames;
4394 __le64 tx_runt_frames;
4395 __le64 tx_fifo_underruns;
4396 __le64 tx_pfc_ena_frames_pri0;
4397 __le64 tx_pfc_ena_frames_pri1;
4398 __le64 tx_pfc_ena_frames_pri2;
4399 __le64 tx_pfc_ena_frames_pri3;
4400 __le64 tx_pfc_ena_frames_pri4;
4401 __le64 tx_pfc_ena_frames_pri5;
4402 __le64 tx_pfc_ena_frames_pri6;
4403 __le64 tx_pfc_ena_frames_pri7;
4404 __le64 tx_eee_lpi_events;
4405 __le64 tx_eee_lpi_duration;
4406 __le64 tx_llfc_logical_msgs;
4407 __le64 tx_hcfc_msgs;
4408 __le64 tx_total_collisions;
4410 __le64 tx_xthol_frames;
4411 __le64 tx_stat_discard;
4412 __le64 tx_stat_error;
4415 /* rx_port_stats (size:4224b/528B) */
4416 struct rx_port_stats {
4417 __le64 rx_64b_frames;
4418 __le64 rx_65b_127b_frames;
4419 __le64 rx_128b_255b_frames;
4420 __le64 rx_256b_511b_frames;
4421 __le64 rx_512b_1023b_frames;
4422 __le64 rx_1024b_1518b_frames;
4423 __le64 rx_good_vlan_frames;
4424 __le64 rx_1519b_2047b_frames;
4425 __le64 rx_2048b_4095b_frames;
4426 __le64 rx_4096b_9216b_frames;
4427 __le64 rx_9217b_16383b_frames;
4428 __le64 rx_total_frames;
4429 __le64 rx_ucast_frames;
4430 __le64 rx_mcast_frames;
4431 __le64 rx_bcast_frames;
4432 __le64 rx_fcs_err_frames;
4433 __le64 rx_ctrl_frames;
4434 __le64 rx_pause_frames;
4435 __le64 rx_pfc_frames;
4436 __le64 rx_unsupported_opcode_frames;
4437 __le64 rx_unsupported_da_pausepfc_frames;
4438 __le64 rx_wrong_sa_frames;
4439 __le64 rx_align_err_frames;
4440 __le64 rx_oor_len_frames;
4441 __le64 rx_code_err_frames;
4442 __le64 rx_false_carrier_frames;
4443 __le64 rx_ovrsz_frames;
4444 __le64 rx_jbr_frames;
4445 __le64 rx_mtu_err_frames;
4446 __le64 rx_match_crc_frames;
4447 __le64 rx_promiscuous_frames;
4448 __le64 rx_tagged_frames;
4449 __le64 rx_double_tagged_frames;
4450 __le64 rx_trunc_frames;
4451 __le64 rx_good_frames;
4452 __le64 rx_pfc_xon2xoff_frames_pri0;
4453 __le64 rx_pfc_xon2xoff_frames_pri1;
4454 __le64 rx_pfc_xon2xoff_frames_pri2;
4455 __le64 rx_pfc_xon2xoff_frames_pri3;
4456 __le64 rx_pfc_xon2xoff_frames_pri4;
4457 __le64 rx_pfc_xon2xoff_frames_pri5;
4458 __le64 rx_pfc_xon2xoff_frames_pri6;
4459 __le64 rx_pfc_xon2xoff_frames_pri7;
4460 __le64 rx_pfc_ena_frames_pri0;
4461 __le64 rx_pfc_ena_frames_pri1;
4462 __le64 rx_pfc_ena_frames_pri2;
4463 __le64 rx_pfc_ena_frames_pri3;
4464 __le64 rx_pfc_ena_frames_pri4;
4465 __le64 rx_pfc_ena_frames_pri5;
4466 __le64 rx_pfc_ena_frames_pri6;
4467 __le64 rx_pfc_ena_frames_pri7;
4468 __le64 rx_sch_crc_err_frames;
4469 __le64 rx_undrsz_frames;
4470 __le64 rx_frag_frames;
4471 __le64 rx_eee_lpi_events;
4472 __le64 rx_eee_lpi_duration;
4473 __le64 rx_llfc_physical_msgs;
4474 __le64 rx_llfc_logical_msgs;
4475 __le64 rx_llfc_msgs_with_crc_err;
4476 __le64 rx_hcfc_msgs;
4477 __le64 rx_hcfc_msgs_with_crc_err;
4479 __le64 rx_runt_bytes;
4480 __le64 rx_runt_frames;
4481 __le64 rx_stat_discard;
4485 /* hwrm_port_qstats_input (size:320b/40B) */
4486 struct hwrm_port_qstats_input {
4494 #define PORT_QSTATS_REQ_FLAGS_COUNTER_MASK 0x1UL
4496 __le64 tx_stat_host_addr;
4497 __le64 rx_stat_host_addr;
4500 /* hwrm_port_qstats_output (size:128b/16B) */
4501 struct hwrm_port_qstats_output {
4506 __le16 tx_stat_size;
4507 __le16 rx_stat_size;
4512 /* tx_port_stats_ext (size:2048b/256B) */
4513 struct tx_port_stats_ext {
4514 __le64 tx_bytes_cos0;
4515 __le64 tx_bytes_cos1;
4516 __le64 tx_bytes_cos2;
4517 __le64 tx_bytes_cos3;
4518 __le64 tx_bytes_cos4;
4519 __le64 tx_bytes_cos5;
4520 __le64 tx_bytes_cos6;
4521 __le64 tx_bytes_cos7;
4522 __le64 tx_packets_cos0;
4523 __le64 tx_packets_cos1;
4524 __le64 tx_packets_cos2;
4525 __le64 tx_packets_cos3;
4526 __le64 tx_packets_cos4;
4527 __le64 tx_packets_cos5;
4528 __le64 tx_packets_cos6;
4529 __le64 tx_packets_cos7;
4530 __le64 pfc_pri0_tx_duration_us;
4531 __le64 pfc_pri0_tx_transitions;
4532 __le64 pfc_pri1_tx_duration_us;
4533 __le64 pfc_pri1_tx_transitions;
4534 __le64 pfc_pri2_tx_duration_us;
4535 __le64 pfc_pri2_tx_transitions;
4536 __le64 pfc_pri3_tx_duration_us;
4537 __le64 pfc_pri3_tx_transitions;
4538 __le64 pfc_pri4_tx_duration_us;
4539 __le64 pfc_pri4_tx_transitions;
4540 __le64 pfc_pri5_tx_duration_us;
4541 __le64 pfc_pri5_tx_transitions;
4542 __le64 pfc_pri6_tx_duration_us;
4543 __le64 pfc_pri6_tx_transitions;
4544 __le64 pfc_pri7_tx_duration_us;
4545 __le64 pfc_pri7_tx_transitions;
4548 /* rx_port_stats_ext (size:3776b/472B) */
4549 struct rx_port_stats_ext {
4550 __le64 link_down_events;
4551 __le64 continuous_pause_events;
4552 __le64 resume_pause_events;
4553 __le64 continuous_roce_pause_events;
4554 __le64 resume_roce_pause_events;
4555 __le64 rx_bytes_cos0;
4556 __le64 rx_bytes_cos1;
4557 __le64 rx_bytes_cos2;
4558 __le64 rx_bytes_cos3;
4559 __le64 rx_bytes_cos4;
4560 __le64 rx_bytes_cos5;
4561 __le64 rx_bytes_cos6;
4562 __le64 rx_bytes_cos7;
4563 __le64 rx_packets_cos0;
4564 __le64 rx_packets_cos1;
4565 __le64 rx_packets_cos2;
4566 __le64 rx_packets_cos3;
4567 __le64 rx_packets_cos4;
4568 __le64 rx_packets_cos5;
4569 __le64 rx_packets_cos6;
4570 __le64 rx_packets_cos7;
4571 __le64 pfc_pri0_rx_duration_us;
4572 __le64 pfc_pri0_rx_transitions;
4573 __le64 pfc_pri1_rx_duration_us;
4574 __le64 pfc_pri1_rx_transitions;
4575 __le64 pfc_pri2_rx_duration_us;
4576 __le64 pfc_pri2_rx_transitions;
4577 __le64 pfc_pri3_rx_duration_us;
4578 __le64 pfc_pri3_rx_transitions;
4579 __le64 pfc_pri4_rx_duration_us;
4580 __le64 pfc_pri4_rx_transitions;
4581 __le64 pfc_pri5_rx_duration_us;
4582 __le64 pfc_pri5_rx_transitions;
4583 __le64 pfc_pri6_rx_duration_us;
4584 __le64 pfc_pri6_rx_transitions;
4585 __le64 pfc_pri7_rx_duration_us;
4586 __le64 pfc_pri7_rx_transitions;
4588 __le64 rx_buffer_passed_threshold;
4589 __le64 rx_pcs_symbol_err;
4590 __le64 rx_corrected_bits;
4591 __le64 rx_discard_bytes_cos0;
4592 __le64 rx_discard_bytes_cos1;
4593 __le64 rx_discard_bytes_cos2;
4594 __le64 rx_discard_bytes_cos3;
4595 __le64 rx_discard_bytes_cos4;
4596 __le64 rx_discard_bytes_cos5;
4597 __le64 rx_discard_bytes_cos6;
4598 __le64 rx_discard_bytes_cos7;
4599 __le64 rx_discard_packets_cos0;
4600 __le64 rx_discard_packets_cos1;
4601 __le64 rx_discard_packets_cos2;
4602 __le64 rx_discard_packets_cos3;
4603 __le64 rx_discard_packets_cos4;
4604 __le64 rx_discard_packets_cos5;
4605 __le64 rx_discard_packets_cos6;
4606 __le64 rx_discard_packets_cos7;
4607 __le64 rx_fec_corrected_blocks;
4608 __le64 rx_fec_uncorrectable_blocks;
4611 /* hwrm_port_qstats_ext_input (size:320b/40B) */
4612 struct hwrm_port_qstats_ext_input {
4619 __le16 tx_stat_size;
4620 __le16 rx_stat_size;
4622 #define PORT_QSTATS_EXT_REQ_FLAGS_COUNTER_MASK 0x1UL
4624 __le64 tx_stat_host_addr;
4625 __le64 rx_stat_host_addr;
4628 /* hwrm_port_qstats_ext_output (size:128b/16B) */
4629 struct hwrm_port_qstats_ext_output {
4634 __le16 tx_stat_size;
4635 __le16 rx_stat_size;
4636 __le16 total_active_cos_queues;
4638 #define PORT_QSTATS_EXT_RESP_FLAGS_CLEAR_ROCE_COUNTERS_SUPPORTED 0x1UL
4642 /* hwrm_port_lpbk_qstats_input (size:128b/16B) */
4643 struct hwrm_port_lpbk_qstats_input {
4651 /* hwrm_port_lpbk_qstats_output (size:768b/96B) */
4652 struct hwrm_port_lpbk_qstats_output {
4657 __le64 lpbk_ucast_frames;
4658 __le64 lpbk_mcast_frames;
4659 __le64 lpbk_bcast_frames;
4660 __le64 lpbk_ucast_bytes;
4661 __le64 lpbk_mcast_bytes;
4662 __le64 lpbk_bcast_bytes;
4663 __le64 tx_stat_discard;
4664 __le64 tx_stat_error;
4665 __le64 rx_stat_discard;
4666 __le64 rx_stat_error;
4671 /* hwrm_port_ecn_qstats_input (size:256b/32B) */
4672 struct hwrm_port_ecn_qstats_input {
4679 __le16 ecn_stat_buf_size;
4681 #define PORT_ECN_QSTATS_REQ_FLAGS_COUNTER_MASK 0x1UL
4683 __le64 ecn_stat_host_addr;
4686 /* hwrm_port_ecn_qstats_output (size:128b/16B) */
4687 struct hwrm_port_ecn_qstats_output {
4692 __le16 ecn_stat_buf_size;
4698 /* port_stats_ecn (size:512b/64B) */
4699 struct port_stats_ecn {
4700 __le64 mark_cnt_cos0;
4701 __le64 mark_cnt_cos1;
4702 __le64 mark_cnt_cos2;
4703 __le64 mark_cnt_cos3;
4704 __le64 mark_cnt_cos4;
4705 __le64 mark_cnt_cos5;
4706 __le64 mark_cnt_cos6;
4707 __le64 mark_cnt_cos7;
4710 /* hwrm_port_clr_stats_input (size:192b/24B) */
4711 struct hwrm_port_clr_stats_input {
4719 #define PORT_CLR_STATS_REQ_FLAGS_ROCE_COUNTERS 0x1UL
4723 /* hwrm_port_clr_stats_output (size:128b/16B) */
4724 struct hwrm_port_clr_stats_output {
4733 /* hwrm_port_lpbk_clr_stats_input (size:128b/16B) */
4734 struct hwrm_port_lpbk_clr_stats_input {
4742 /* hwrm_port_lpbk_clr_stats_output (size:128b/16B) */
4743 struct hwrm_port_lpbk_clr_stats_output {
4752 /* hwrm_port_ts_query_input (size:320b/40B) */
4753 struct hwrm_port_ts_query_input {
4760 #define PORT_TS_QUERY_REQ_FLAGS_PATH 0x1UL
4761 #define PORT_TS_QUERY_REQ_FLAGS_PATH_TX 0x0UL
4762 #define PORT_TS_QUERY_REQ_FLAGS_PATH_RX 0x1UL
4763 #define PORT_TS_QUERY_REQ_FLAGS_PATH_LAST PORT_TS_QUERY_REQ_FLAGS_PATH_RX
4764 #define PORT_TS_QUERY_REQ_FLAGS_CURRENT_TIME 0x2UL
4768 #define PORT_TS_QUERY_REQ_ENABLES_TS_REQ_TIMEOUT 0x1UL
4769 #define PORT_TS_QUERY_REQ_ENABLES_PTP_SEQ_ID 0x2UL
4770 #define PORT_TS_QUERY_REQ_ENABLES_PTP_HDR_OFFSET 0x4UL
4771 __le16 ts_req_timeout;
4773 __le16 ptp_hdr_offset;
4777 /* hwrm_port_ts_query_output (size:192b/24B) */
4778 struct hwrm_port_ts_query_output {
4784 __le16 ptp_msg_seqid;
4789 /* hwrm_port_phy_qcaps_input (size:192b/24B) */
4790 struct hwrm_port_phy_qcaps_input {
4800 /* hwrm_port_phy_qcaps_output (size:256b/32B) */
4801 struct hwrm_port_phy_qcaps_output {
4807 #define PORT_PHY_QCAPS_RESP_FLAGS_EEE_SUPPORTED 0x1UL
4808 #define PORT_PHY_QCAPS_RESP_FLAGS_EXTERNAL_LPBK_SUPPORTED 0x2UL
4809 #define PORT_PHY_QCAPS_RESP_FLAGS_AUTONEG_LPBK_SUPPORTED 0x4UL
4810 #define PORT_PHY_QCAPS_RESP_FLAGS_SHARED_PHY_CFG_SUPPORTED 0x8UL
4811 #define PORT_PHY_QCAPS_RESP_FLAGS_CUMULATIVE_COUNTERS_ON_RESET 0x10UL
4812 #define PORT_PHY_QCAPS_RESP_FLAGS_LOCAL_LPBK_NOT_SUPPORTED 0x20UL
4813 #define PORT_PHY_QCAPS_RESP_FLAGS_FW_MANAGED_LINK_DOWN 0x40UL
4814 #define PORT_PHY_QCAPS_RESP_FLAGS_NO_FCS 0x80UL
4816 #define PORT_PHY_QCAPS_RESP_PORT_CNT_UNKNOWN 0x0UL
4817 #define PORT_PHY_QCAPS_RESP_PORT_CNT_1 0x1UL
4818 #define PORT_PHY_QCAPS_RESP_PORT_CNT_2 0x2UL
4819 #define PORT_PHY_QCAPS_RESP_PORT_CNT_3 0x3UL
4820 #define PORT_PHY_QCAPS_RESP_PORT_CNT_4 0x4UL
4821 #define PORT_PHY_QCAPS_RESP_PORT_CNT_12 0xcUL
4822 #define PORT_PHY_QCAPS_RESP_PORT_CNT_LAST PORT_PHY_QCAPS_RESP_PORT_CNT_12
4823 __le16 supported_speeds_force_mode;
4824 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_100MBHD 0x1UL
4825 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_100MB 0x2UL
4826 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_1GBHD 0x4UL
4827 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_1GB 0x8UL
4828 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_2GB 0x10UL
4829 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_2_5GB 0x20UL
4830 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_10GB 0x40UL
4831 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_20GB 0x80UL
4832 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_25GB 0x100UL
4833 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_40GB 0x200UL
4834 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_50GB 0x400UL
4835 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_100GB 0x800UL
4836 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_10MBHD 0x1000UL
4837 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_FORCE_MODE_10MB 0x2000UL
4838 __le16 supported_speeds_auto_mode;
4839 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_100MBHD 0x1UL
4840 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_100MB 0x2UL
4841 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_1GBHD 0x4UL
4842 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_1GB 0x8UL
4843 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_2GB 0x10UL
4844 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_2_5GB 0x20UL
4845 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_10GB 0x40UL
4846 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_20GB 0x80UL
4847 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_25GB 0x100UL
4848 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_40GB 0x200UL
4849 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_50GB 0x400UL
4850 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_100GB 0x800UL
4851 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_10MBHD 0x1000UL
4852 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_AUTO_MODE_10MB 0x2000UL
4853 __le16 supported_speeds_eee_mode;
4854 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_EEE_MODE_RSVD1 0x1UL
4855 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_EEE_MODE_100MB 0x2UL
4856 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_EEE_MODE_RSVD2 0x4UL
4857 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_EEE_MODE_1GB 0x8UL
4858 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_EEE_MODE_RSVD3 0x10UL
4859 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_EEE_MODE_RSVD4 0x20UL
4860 #define PORT_PHY_QCAPS_RESP_SUPPORTED_SPEEDS_EEE_MODE_10GB 0x40UL
4861 __le32 tx_lpi_timer_low;
4862 #define PORT_PHY_QCAPS_RESP_TX_LPI_TIMER_LOW_MASK 0xffffffUL
4863 #define PORT_PHY_QCAPS_RESP_TX_LPI_TIMER_LOW_SFT 0
4864 #define PORT_PHY_QCAPS_RESP_RSVD2_MASK 0xff000000UL
4865 #define PORT_PHY_QCAPS_RESP_RSVD2_SFT 24
4866 __le32 valid_tx_lpi_timer_high;
4867 #define PORT_PHY_QCAPS_RESP_TX_LPI_TIMER_HIGH_MASK 0xffffffUL
4868 #define PORT_PHY_QCAPS_RESP_TX_LPI_TIMER_HIGH_SFT 0
4869 #define PORT_PHY_QCAPS_RESP_RSVD_MASK 0xff000000UL
4870 #define PORT_PHY_QCAPS_RESP_RSVD_SFT 24
4871 __le16 supported_pam4_speeds_auto_mode;
4872 #define PORT_PHY_QCAPS_RESP_SUPPORTED_PAM4_SPEEDS_AUTO_MODE_50G 0x1UL
4873 #define PORT_PHY_QCAPS_RESP_SUPPORTED_PAM4_SPEEDS_AUTO_MODE_100G 0x2UL
4874 #define PORT_PHY_QCAPS_RESP_SUPPORTED_PAM4_SPEEDS_AUTO_MODE_200G 0x4UL
4875 __le16 supported_pam4_speeds_force_mode;
4876 #define PORT_PHY_QCAPS_RESP_SUPPORTED_PAM4_SPEEDS_FORCE_MODE_50G 0x1UL
4877 #define PORT_PHY_QCAPS_RESP_SUPPORTED_PAM4_SPEEDS_FORCE_MODE_100G 0x2UL
4878 #define PORT_PHY_QCAPS_RESP_SUPPORTED_PAM4_SPEEDS_FORCE_MODE_200G 0x4UL
4880 #define PORT_PHY_QCAPS_RESP_FLAGS2_PAUSE_UNSUPPORTED 0x1UL
4881 #define PORT_PHY_QCAPS_RESP_FLAGS2_PFC_UNSUPPORTED 0x2UL
4882 #define PORT_PHY_QCAPS_RESP_FLAGS2_BANK_ADDR_SUPPORTED 0x4UL
4883 u8 internal_port_cnt;
4887 /* hwrm_port_phy_i2c_read_input (size:320b/40B) */
4888 struct hwrm_port_phy_i2c_read_input {
4896 #define PORT_PHY_I2C_READ_REQ_ENABLES_PAGE_OFFSET 0x1UL
4897 #define PORT_PHY_I2C_READ_REQ_ENABLES_BANK_NUMBER 0x2UL
4907 /* hwrm_port_phy_i2c_read_output (size:640b/80B) */
4908 struct hwrm_port_phy_i2c_read_output {
4918 /* hwrm_port_phy_mdio_write_input (size:320b/40B) */
4919 struct hwrm_port_phy_mdio_write_input {
4935 /* hwrm_port_phy_mdio_write_output (size:128b/16B) */
4936 struct hwrm_port_phy_mdio_write_output {
4945 /* hwrm_port_phy_mdio_read_input (size:256b/32B) */
4946 struct hwrm_port_phy_mdio_read_input {
4961 /* hwrm_port_phy_mdio_read_output (size:128b/16B) */
4962 struct hwrm_port_phy_mdio_read_output {
4972 /* hwrm_port_led_cfg_input (size:512b/64B) */
4973 struct hwrm_port_led_cfg_input {
4980 #define PORT_LED_CFG_REQ_ENABLES_LED0_ID 0x1UL
4981 #define PORT_LED_CFG_REQ_ENABLES_LED0_STATE 0x2UL
4982 #define PORT_LED_CFG_REQ_ENABLES_LED0_COLOR 0x4UL
4983 #define PORT_LED_CFG_REQ_ENABLES_LED0_BLINK_ON 0x8UL
4984 #define PORT_LED_CFG_REQ_ENABLES_LED0_BLINK_OFF 0x10UL
4985 #define PORT_LED_CFG_REQ_ENABLES_LED0_GROUP_ID 0x20UL
4986 #define PORT_LED_CFG_REQ_ENABLES_LED1_ID 0x40UL
4987 #define PORT_LED_CFG_REQ_ENABLES_LED1_STATE 0x80UL
4988 #define PORT_LED_CFG_REQ_ENABLES_LED1_COLOR 0x100UL
4989 #define PORT_LED_CFG_REQ_ENABLES_LED1_BLINK_ON 0x200UL
4990 #define PORT_LED_CFG_REQ_ENABLES_LED1_BLINK_OFF 0x400UL
4991 #define PORT_LED_CFG_REQ_ENABLES_LED1_GROUP_ID 0x800UL
4992 #define PORT_LED_CFG_REQ_ENABLES_LED2_ID 0x1000UL
4993 #define PORT_LED_CFG_REQ_ENABLES_LED2_STATE 0x2000UL
4994 #define PORT_LED_CFG_REQ_ENABLES_LED2_COLOR 0x4000UL
4995 #define PORT_LED_CFG_REQ_ENABLES_LED2_BLINK_ON 0x8000UL
4996 #define PORT_LED_CFG_REQ_ENABLES_LED2_BLINK_OFF 0x10000UL
4997 #define PORT_LED_CFG_REQ_ENABLES_LED2_GROUP_ID 0x20000UL
4998 #define PORT_LED_CFG_REQ_ENABLES_LED3_ID 0x40000UL
4999 #define PORT_LED_CFG_REQ_ENABLES_LED3_STATE 0x80000UL
5000 #define PORT_LED_CFG_REQ_ENABLES_LED3_COLOR 0x100000UL
5001 #define PORT_LED_CFG_REQ_ENABLES_LED3_BLINK_ON 0x200000UL
5002 #define PORT_LED_CFG_REQ_ENABLES_LED3_BLINK_OFF 0x400000UL
5003 #define PORT_LED_CFG_REQ_ENABLES_LED3_GROUP_ID 0x800000UL
5009 #define PORT_LED_CFG_REQ_LED0_STATE_DEFAULT 0x0UL
5010 #define PORT_LED_CFG_REQ_LED0_STATE_OFF 0x1UL
5011 #define PORT_LED_CFG_REQ_LED0_STATE_ON 0x2UL
5012 #define PORT_LED_CFG_REQ_LED0_STATE_BLINK 0x3UL
5013 #define PORT_LED_CFG_REQ_LED0_STATE_BLINKALT 0x4UL
5014 #define PORT_LED_CFG_REQ_LED0_STATE_LAST PORT_LED_CFG_REQ_LED0_STATE_BLINKALT
5016 #define PORT_LED_CFG_REQ_LED0_COLOR_DEFAULT 0x0UL
5017 #define PORT_LED_CFG_REQ_LED0_COLOR_AMBER 0x1UL
5018 #define PORT_LED_CFG_REQ_LED0_COLOR_GREEN 0x2UL
5019 #define PORT_LED_CFG_REQ_LED0_COLOR_GREENAMBER 0x3UL
5020 #define PORT_LED_CFG_REQ_LED0_COLOR_LAST PORT_LED_CFG_REQ_LED0_COLOR_GREENAMBER
5022 __le16 led0_blink_on;
5023 __le16 led0_blink_off;
5028 #define PORT_LED_CFG_REQ_LED1_STATE_DEFAULT 0x0UL
5029 #define PORT_LED_CFG_REQ_LED1_STATE_OFF 0x1UL
5030 #define PORT_LED_CFG_REQ_LED1_STATE_ON 0x2UL
5031 #define PORT_LED_CFG_REQ_LED1_STATE_BLINK 0x3UL
5032 #define PORT_LED_CFG_REQ_LED1_STATE_BLINKALT 0x4UL
5033 #define PORT_LED_CFG_REQ_LED1_STATE_LAST PORT_LED_CFG_REQ_LED1_STATE_BLINKALT
5035 #define PORT_LED_CFG_REQ_LED1_COLOR_DEFAULT 0x0UL
5036 #define PORT_LED_CFG_REQ_LED1_COLOR_AMBER 0x1UL
5037 #define PORT_LED_CFG_REQ_LED1_COLOR_GREEN 0x2UL
5038 #define PORT_LED_CFG_REQ_LED1_COLOR_GREENAMBER 0x3UL
5039 #define PORT_LED_CFG_REQ_LED1_COLOR_LAST PORT_LED_CFG_REQ_LED1_COLOR_GREENAMBER
5041 __le16 led1_blink_on;
5042 __le16 led1_blink_off;
5047 #define PORT_LED_CFG_REQ_LED2_STATE_DEFAULT 0x0UL
5048 #define PORT_LED_CFG_REQ_LED2_STATE_OFF 0x1UL
5049 #define PORT_LED_CFG_REQ_LED2_STATE_ON 0x2UL
5050 #define PORT_LED_CFG_REQ_LED2_STATE_BLINK 0x3UL
5051 #define PORT_LED_CFG_REQ_LED2_STATE_BLINKALT 0x4UL
5052 #define PORT_LED_CFG_REQ_LED2_STATE_LAST PORT_LED_CFG_REQ_LED2_STATE_BLINKALT
5054 #define PORT_LED_CFG_REQ_LED2_COLOR_DEFAULT 0x0UL
5055 #define PORT_LED_CFG_REQ_LED2_COLOR_AMBER 0x1UL
5056 #define PORT_LED_CFG_REQ_LED2_COLOR_GREEN 0x2UL
5057 #define PORT_LED_CFG_REQ_LED2_COLOR_GREENAMBER 0x3UL
5058 #define PORT_LED_CFG_REQ_LED2_COLOR_LAST PORT_LED_CFG_REQ_LED2_COLOR_GREENAMBER
5060 __le16 led2_blink_on;
5061 __le16 led2_blink_off;
5066 #define PORT_LED_CFG_REQ_LED3_STATE_DEFAULT 0x0UL
5067 #define PORT_LED_CFG_REQ_LED3_STATE_OFF 0x1UL
5068 #define PORT_LED_CFG_REQ_LED3_STATE_ON 0x2UL
5069 #define PORT_LED_CFG_REQ_LED3_STATE_BLINK 0x3UL
5070 #define PORT_LED_CFG_REQ_LED3_STATE_BLINKALT 0x4UL
5071 #define PORT_LED_CFG_REQ_LED3_STATE_LAST PORT_LED_CFG_REQ_LED3_STATE_BLINKALT
5073 #define PORT_LED_CFG_REQ_LED3_COLOR_DEFAULT 0x0UL
5074 #define PORT_LED_CFG_REQ_LED3_COLOR_AMBER 0x1UL
5075 #define PORT_LED_CFG_REQ_LED3_COLOR_GREEN 0x2UL
5076 #define PORT_LED_CFG_REQ_LED3_COLOR_GREENAMBER 0x3UL
5077 #define PORT_LED_CFG_REQ_LED3_COLOR_LAST PORT_LED_CFG_REQ_LED3_COLOR_GREENAMBER
5079 __le16 led3_blink_on;
5080 __le16 led3_blink_off;
5085 /* hwrm_port_led_cfg_output (size:128b/16B) */
5086 struct hwrm_port_led_cfg_output {
5095 /* hwrm_port_led_qcfg_input (size:192b/24B) */
5096 struct hwrm_port_led_qcfg_input {
5106 /* hwrm_port_led_qcfg_output (size:448b/56B) */
5107 struct hwrm_port_led_qcfg_output {
5115 #define PORT_LED_QCFG_RESP_LED0_TYPE_SPEED 0x0UL
5116 #define PORT_LED_QCFG_RESP_LED0_TYPE_ACTIVITY 0x1UL
5117 #define PORT_LED_QCFG_RESP_LED0_TYPE_INVALID 0xffUL
5118 #define PORT_LED_QCFG_RESP_LED0_TYPE_LAST PORT_LED_QCFG_RESP_LED0_TYPE_INVALID
5120 #define PORT_LED_QCFG_RESP_LED0_STATE_DEFAULT 0x0UL
5121 #define PORT_LED_QCFG_RESP_LED0_STATE_OFF 0x1UL
5122 #define PORT_LED_QCFG_RESP_LED0_STATE_ON 0x2UL
5123 #define PORT_LED_QCFG_RESP_LED0_STATE_BLINK 0x3UL
5124 #define PORT_LED_QCFG_RESP_LED0_STATE_BLINKALT 0x4UL
5125 #define PORT_LED_QCFG_RESP_LED0_STATE_LAST PORT_LED_QCFG_RESP_LED0_STATE_BLINKALT
5127 #define PORT_LED_QCFG_RESP_LED0_COLOR_DEFAULT 0x0UL
5128 #define PORT_LED_QCFG_RESP_LED0_COLOR_AMBER 0x1UL
5129 #define PORT_LED_QCFG_RESP_LED0_COLOR_GREEN 0x2UL
5130 #define PORT_LED_QCFG_RESP_LED0_COLOR_GREENAMBER 0x3UL
5131 #define PORT_LED_QCFG_RESP_LED0_COLOR_LAST PORT_LED_QCFG_RESP_LED0_COLOR_GREENAMBER
5133 __le16 led0_blink_on;
5134 __le16 led0_blink_off;
5138 #define PORT_LED_QCFG_RESP_LED1_TYPE_SPEED 0x0UL
5139 #define PORT_LED_QCFG_RESP_LED1_TYPE_ACTIVITY 0x1UL
5140 #define PORT_LED_QCFG_RESP_LED1_TYPE_INVALID 0xffUL
5141 #define PORT_LED_QCFG_RESP_LED1_TYPE_LAST PORT_LED_QCFG_RESP_LED1_TYPE_INVALID
5143 #define PORT_LED_QCFG_RESP_LED1_STATE_DEFAULT 0x0UL
5144 #define PORT_LED_QCFG_RESP_LED1_STATE_OFF 0x1UL
5145 #define PORT_LED_QCFG_RESP_LED1_STATE_ON 0x2UL
5146 #define PORT_LED_QCFG_RESP_LED1_STATE_BLINK 0x3UL
5147 #define PORT_LED_QCFG_RESP_LED1_STATE_BLINKALT 0x4UL
5148 #define PORT_LED_QCFG_RESP_LED1_STATE_LAST PORT_LED_QCFG_RESP_LED1_STATE_BLINKALT
5150 #define PORT_LED_QCFG_RESP_LED1_COLOR_DEFAULT 0x0UL
5151 #define PORT_LED_QCFG_RESP_LED1_COLOR_AMBER 0x1UL
5152 #define PORT_LED_QCFG_RESP_LED1_COLOR_GREEN 0x2UL
5153 #define PORT_LED_QCFG_RESP_LED1_COLOR_GREENAMBER 0x3UL
5154 #define PORT_LED_QCFG_RESP_LED1_COLOR_LAST PORT_LED_QCFG_RESP_LED1_COLOR_GREENAMBER
5156 __le16 led1_blink_on;
5157 __le16 led1_blink_off;
5161 #define PORT_LED_QCFG_RESP_LED2_TYPE_SPEED 0x0UL
5162 #define PORT_LED_QCFG_RESP_LED2_TYPE_ACTIVITY 0x1UL
5163 #define PORT_LED_QCFG_RESP_LED2_TYPE_INVALID 0xffUL
5164 #define PORT_LED_QCFG_RESP_LED2_TYPE_LAST PORT_LED_QCFG_RESP_LED2_TYPE_INVALID
5166 #define PORT_LED_QCFG_RESP_LED2_STATE_DEFAULT 0x0UL
5167 #define PORT_LED_QCFG_RESP_LED2_STATE_OFF 0x1UL
5168 #define PORT_LED_QCFG_RESP_LED2_STATE_ON 0x2UL
5169 #define PORT_LED_QCFG_RESP_LED2_STATE_BLINK 0x3UL
5170 #define PORT_LED_QCFG_RESP_LED2_STATE_BLINKALT 0x4UL
5171 #define PORT_LED_QCFG_RESP_LED2_STATE_LAST PORT_LED_QCFG_RESP_LED2_STATE_BLINKALT
5173 #define PORT_LED_QCFG_RESP_LED2_COLOR_DEFAULT 0x0UL
5174 #define PORT_LED_QCFG_RESP_LED2_COLOR_AMBER 0x1UL
5175 #define PORT_LED_QCFG_RESP_LED2_COLOR_GREEN 0x2UL
5176 #define PORT_LED_QCFG_RESP_LED2_COLOR_GREENAMBER 0x3UL
5177 #define PORT_LED_QCFG_RESP_LED2_COLOR_LAST PORT_LED_QCFG_RESP_LED2_COLOR_GREENAMBER
5179 __le16 led2_blink_on;
5180 __le16 led2_blink_off;
5184 #define PORT_LED_QCFG_RESP_LED3_TYPE_SPEED 0x0UL
5185 #define PORT_LED_QCFG_RESP_LED3_TYPE_ACTIVITY 0x1UL
5186 #define PORT_LED_QCFG_RESP_LED3_TYPE_INVALID 0xffUL
5187 #define PORT_LED_QCFG_RESP_LED3_TYPE_LAST PORT_LED_QCFG_RESP_LED3_TYPE_INVALID
5189 #define PORT_LED_QCFG_RESP_LED3_STATE_DEFAULT 0x0UL
5190 #define PORT_LED_QCFG_RESP_LED3_STATE_OFF 0x1UL
5191 #define PORT_LED_QCFG_RESP_LED3_STATE_ON 0x2UL
5192 #define PORT_LED_QCFG_RESP_LED3_STATE_BLINK 0x3UL
5193 #define PORT_LED_QCFG_RESP_LED3_STATE_BLINKALT 0x4UL
5194 #define PORT_LED_QCFG_RESP_LED3_STATE_LAST PORT_LED_QCFG_RESP_LED3_STATE_BLINKALT
5196 #define PORT_LED_QCFG_RESP_LED3_COLOR_DEFAULT 0x0UL
5197 #define PORT_LED_QCFG_RESP_LED3_COLOR_AMBER 0x1UL
5198 #define PORT_LED_QCFG_RESP_LED3_COLOR_GREEN 0x2UL
5199 #define PORT_LED_QCFG_RESP_LED3_COLOR_GREENAMBER 0x3UL
5200 #define PORT_LED_QCFG_RESP_LED3_COLOR_LAST PORT_LED_QCFG_RESP_LED3_COLOR_GREENAMBER
5202 __le16 led3_blink_on;
5203 __le16 led3_blink_off;
5209 /* hwrm_port_led_qcaps_input (size:192b/24B) */
5210 struct hwrm_port_led_qcaps_input {
5220 /* hwrm_port_led_qcaps_output (size:384b/48B) */
5221 struct hwrm_port_led_qcaps_output {
5230 #define PORT_LED_QCAPS_RESP_LED0_TYPE_SPEED 0x0UL
5231 #define PORT_LED_QCAPS_RESP_LED0_TYPE_ACTIVITY 0x1UL
5232 #define PORT_LED_QCAPS_RESP_LED0_TYPE_INVALID 0xffUL
5233 #define PORT_LED_QCAPS_RESP_LED0_TYPE_LAST PORT_LED_QCAPS_RESP_LED0_TYPE_INVALID
5236 __le16 led0_state_caps;
5237 #define PORT_LED_QCAPS_RESP_LED0_STATE_CAPS_ENABLED 0x1UL
5238 #define PORT_LED_QCAPS_RESP_LED0_STATE_CAPS_OFF_SUPPORTED 0x2UL
5239 #define PORT_LED_QCAPS_RESP_LED0_STATE_CAPS_ON_SUPPORTED 0x4UL
5240 #define PORT_LED_QCAPS_RESP_LED0_STATE_CAPS_BLINK_SUPPORTED 0x8UL
5241 #define PORT_LED_QCAPS_RESP_LED0_STATE_CAPS_BLINK_ALT_SUPPORTED 0x10UL
5242 __le16 led0_color_caps;
5243 #define PORT_LED_QCAPS_RESP_LED0_COLOR_CAPS_RSVD 0x1UL
5244 #define PORT_LED_QCAPS_RESP_LED0_COLOR_CAPS_AMBER_SUPPORTED 0x2UL
5245 #define PORT_LED_QCAPS_RESP_LED0_COLOR_CAPS_GREEN_SUPPORTED 0x4UL
5248 #define PORT_LED_QCAPS_RESP_LED1_TYPE_SPEED 0x0UL
5249 #define PORT_LED_QCAPS_RESP_LED1_TYPE_ACTIVITY 0x1UL
5250 #define PORT_LED_QCAPS_RESP_LED1_TYPE_INVALID 0xffUL
5251 #define PORT_LED_QCAPS_RESP_LED1_TYPE_LAST PORT_LED_QCAPS_RESP_LED1_TYPE_INVALID
5254 __le16 led1_state_caps;
5255 #define PORT_LED_QCAPS_RESP_LED1_STATE_CAPS_ENABLED 0x1UL
5256 #define PORT_LED_QCAPS_RESP_LED1_STATE_CAPS_OFF_SUPPORTED 0x2UL
5257 #define PORT_LED_QCAPS_RESP_LED1_STATE_CAPS_ON_SUPPORTED 0x4UL
5258 #define PORT_LED_QCAPS_RESP_LED1_STATE_CAPS_BLINK_SUPPORTED 0x8UL
5259 #define PORT_LED_QCAPS_RESP_LED1_STATE_CAPS_BLINK_ALT_SUPPORTED 0x10UL
5260 __le16 led1_color_caps;
5261 #define PORT_LED_QCAPS_RESP_LED1_COLOR_CAPS_RSVD 0x1UL
5262 #define PORT_LED_QCAPS_RESP_LED1_COLOR_CAPS_AMBER_SUPPORTED 0x2UL
5263 #define PORT_LED_QCAPS_RESP_LED1_COLOR_CAPS_GREEN_SUPPORTED 0x4UL
5266 #define PORT_LED_QCAPS_RESP_LED2_TYPE_SPEED 0x0UL
5267 #define PORT_LED_QCAPS_RESP_LED2_TYPE_ACTIVITY 0x1UL
5268 #define PORT_LED_QCAPS_RESP_LED2_TYPE_INVALID 0xffUL
5269 #define PORT_LED_QCAPS_RESP_LED2_TYPE_LAST PORT_LED_QCAPS_RESP_LED2_TYPE_INVALID
5272 __le16 led2_state_caps;
5273 #define PORT_LED_QCAPS_RESP_LED2_STATE_CAPS_ENABLED 0x1UL
5274 #define PORT_LED_QCAPS_RESP_LED2_STATE_CAPS_OFF_SUPPORTED 0x2UL
5275 #define PORT_LED_QCAPS_RESP_LED2_STATE_CAPS_ON_SUPPORTED 0x4UL
5276 #define PORT_LED_QCAPS_RESP_LED2_STATE_CAPS_BLINK_SUPPORTED 0x8UL
5277 #define PORT_LED_QCAPS_RESP_LED2_STATE_CAPS_BLINK_ALT_SUPPORTED 0x10UL
5278 __le16 led2_color_caps;
5279 #define PORT_LED_QCAPS_RESP_LED2_COLOR_CAPS_RSVD 0x1UL
5280 #define PORT_LED_QCAPS_RESP_LED2_COLOR_CAPS_AMBER_SUPPORTED 0x2UL
5281 #define PORT_LED_QCAPS_RESP_LED2_COLOR_CAPS_GREEN_SUPPORTED 0x4UL
5284 #define PORT_LED_QCAPS_RESP_LED3_TYPE_SPEED 0x0UL
5285 #define PORT_LED_QCAPS_RESP_LED3_TYPE_ACTIVITY 0x1UL
5286 #define PORT_LED_QCAPS_RESP_LED3_TYPE_INVALID 0xffUL
5287 #define PORT_LED_QCAPS_RESP_LED3_TYPE_LAST PORT_LED_QCAPS_RESP_LED3_TYPE_INVALID
5290 __le16 led3_state_caps;
5291 #define PORT_LED_QCAPS_RESP_LED3_STATE_CAPS_ENABLED 0x1UL
5292 #define PORT_LED_QCAPS_RESP_LED3_STATE_CAPS_OFF_SUPPORTED 0x2UL
5293 #define PORT_LED_QCAPS_RESP_LED3_STATE_CAPS_ON_SUPPORTED 0x4UL
5294 #define PORT_LED_QCAPS_RESP_LED3_STATE_CAPS_BLINK_SUPPORTED 0x8UL
5295 #define PORT_LED_QCAPS_RESP_LED3_STATE_CAPS_BLINK_ALT_SUPPORTED 0x10UL
5296 __le16 led3_color_caps;
5297 #define PORT_LED_QCAPS_RESP_LED3_COLOR_CAPS_RSVD 0x1UL
5298 #define PORT_LED_QCAPS_RESP_LED3_COLOR_CAPS_AMBER_SUPPORTED 0x2UL
5299 #define PORT_LED_QCAPS_RESP_LED3_COLOR_CAPS_GREEN_SUPPORTED 0x4UL
5304 /* hwrm_queue_qportcfg_input (size:192b/24B) */
5305 struct hwrm_queue_qportcfg_input {
5312 #define QUEUE_QPORTCFG_REQ_FLAGS_PATH 0x1UL
5313 #define QUEUE_QPORTCFG_REQ_FLAGS_PATH_TX 0x0UL
5314 #define QUEUE_QPORTCFG_REQ_FLAGS_PATH_RX 0x1UL
5315 #define QUEUE_QPORTCFG_REQ_FLAGS_PATH_LAST QUEUE_QPORTCFG_REQ_FLAGS_PATH_RX
5318 #define QUEUE_QPORTCFG_REQ_DRV_QMAP_CAP_DISABLED 0x0UL
5319 #define QUEUE_QPORTCFG_REQ_DRV_QMAP_CAP_ENABLED 0x1UL
5320 #define QUEUE_QPORTCFG_REQ_DRV_QMAP_CAP_LAST QUEUE_QPORTCFG_REQ_DRV_QMAP_CAP_ENABLED
5324 /* hwrm_queue_qportcfg_output (size:1344b/168B) */
5325 struct hwrm_queue_qportcfg_output {
5330 u8 max_configurable_queues;
5331 u8 max_configurable_lossless_queues;
5332 u8 queue_cfg_allowed;
5334 #define QUEUE_QPORTCFG_RESP_QUEUE_CFG_INFO_ASYM_CFG 0x1UL
5335 #define QUEUE_QPORTCFG_RESP_QUEUE_CFG_INFO_USE_PROFILE_TYPE 0x2UL
5336 u8 queue_pfcenable_cfg_allowed;
5337 u8 queue_pri2cos_cfg_allowed;
5338 u8 queue_cos2bw_cfg_allowed;
5340 u8 queue_id0_service_profile;
5341 #define QUEUE_QPORTCFG_RESP_QUEUE_ID0_SERVICE_PROFILE_LOSSY 0x0UL
5342 #define QUEUE_QPORTCFG_RESP_QUEUE_ID0_SERVICE_PROFILE_LOSSLESS 0x1UL
5343 #define QUEUE_QPORTCFG_RESP_QUEUE_ID0_SERVICE_PROFILE_LOSSLESS_ROCE 0x1UL
5344 #define QUEUE_QPORTCFG_RESP_QUEUE_ID0_SERVICE_PROFILE_LOSSY_ROCE_CNP 0x2UL
5345 #define QUEUE_QPORTCFG_RESP_QUEUE_ID0_SERVICE_PROFILE_LOSSLESS_NIC 0x3UL
5346 #define QUEUE_QPORTCFG_RESP_QUEUE_ID0_SERVICE_PROFILE_UNKNOWN 0xffUL
5347 #define QUEUE_QPORTCFG_RESP_QUEUE_ID0_SERVICE_PROFILE_LAST QUEUE_QPORTCFG_RESP_QUEUE_ID0_SERVICE_PROFILE_UNKNOWN
5349 u8 queue_id1_service_profile;
5350 #define QUEUE_QPORTCFG_RESP_QUEUE_ID1_SERVICE_PROFILE_LOSSY 0x0UL
5351 #define QUEUE_QPORTCFG_RESP_QUEUE_ID1_SERVICE_PROFILE_LOSSLESS 0x1UL
5352 #define QUEUE_QPORTCFG_RESP_QUEUE_ID1_SERVICE_PROFILE_LOSSLESS_ROCE 0x1UL
5353 #define QUEUE_QPORTCFG_RESP_QUEUE_ID1_SERVICE_PROFILE_LOSSY_ROCE_CNP 0x2UL
5354 #define QUEUE_QPORTCFG_RESP_QUEUE_ID1_SERVICE_PROFILE_LOSSLESS_NIC 0x3UL
5355 #define QUEUE_QPORTCFG_RESP_QUEUE_ID1_SERVICE_PROFILE_UNKNOWN 0xffUL
5356 #define QUEUE_QPORTCFG_RESP_QUEUE_ID1_SERVICE_PROFILE_LAST QUEUE_QPORTCFG_RESP_QUEUE_ID1_SERVICE_PROFILE_UNKNOWN
5358 u8 queue_id2_service_profile;
5359 #define QUEUE_QPORTCFG_RESP_QUEUE_ID2_SERVICE_PROFILE_LOSSY 0x0UL
5360 #define QUEUE_QPORTCFG_RESP_QUEUE_ID2_SERVICE_PROFILE_LOSSLESS 0x1UL
5361 #define QUEUE_QPORTCFG_RESP_QUEUE_ID2_SERVICE_PROFILE_LOSSLESS_ROCE 0x1UL
5362 #define QUEUE_QPORTCFG_RESP_QUEUE_ID2_SERVICE_PROFILE_LOSSY_ROCE_CNP 0x2UL
5363 #define QUEUE_QPORTCFG_RESP_QUEUE_ID2_SERVICE_PROFILE_LOSSLESS_NIC 0x3UL
5364 #define QUEUE_QPORTCFG_RESP_QUEUE_ID2_SERVICE_PROFILE_UNKNOWN 0xffUL
5365 #define QUEUE_QPORTCFG_RESP_QUEUE_ID2_SERVICE_PROFILE_LAST QUEUE_QPORTCFG_RESP_QUEUE_ID2_SERVICE_PROFILE_UNKNOWN
5367 u8 queue_id3_service_profile;
5368 #define QUEUE_QPORTCFG_RESP_QUEUE_ID3_SERVICE_PROFILE_LOSSY 0x0UL
5369 #define QUEUE_QPORTCFG_RESP_QUEUE_ID3_SERVICE_PROFILE_LOSSLESS 0x1UL
5370 #define QUEUE_QPORTCFG_RESP_QUEUE_ID3_SERVICE_PROFILE_LOSSLESS_ROCE 0x1UL
5371 #define QUEUE_QPORTCFG_RESP_QUEUE_ID3_SERVICE_PROFILE_LOSSY_ROCE_CNP 0x2UL
5372 #define QUEUE_QPORTCFG_RESP_QUEUE_ID3_SERVICE_PROFILE_LOSSLESS_NIC 0x3UL
5373 #define QUEUE_QPORTCFG_RESP_QUEUE_ID3_SERVICE_PROFILE_UNKNOWN 0xffUL
5374 #define QUEUE_QPORTCFG_RESP_QUEUE_ID3_SERVICE_PROFILE_LAST QUEUE_QPORTCFG_RESP_QUEUE_ID3_SERVICE_PROFILE_UNKNOWN
5376 u8 queue_id4_service_profile;
5377 #define QUEUE_QPORTCFG_RESP_QUEUE_ID4_SERVICE_PROFILE_LOSSY 0x0UL
5378 #define QUEUE_QPORTCFG_RESP_QUEUE_ID4_SERVICE_PROFILE_LOSSLESS 0x1UL
5379 #define QUEUE_QPORTCFG_RESP_QUEUE_ID4_SERVICE_PROFILE_LOSSLESS_ROCE 0x1UL
5380 #define QUEUE_QPORTCFG_RESP_QUEUE_ID4_SERVICE_PROFILE_LOSSY_ROCE_CNP 0x2UL
5381 #define QUEUE_QPORTCFG_RESP_QUEUE_ID4_SERVICE_PROFILE_LOSSLESS_NIC 0x3UL
5382 #define QUEUE_QPORTCFG_RESP_QUEUE_ID4_SERVICE_PROFILE_UNKNOWN 0xffUL
5383 #define QUEUE_QPORTCFG_RESP_QUEUE_ID4_SERVICE_PROFILE_LAST QUEUE_QPORTCFG_RESP_QUEUE_ID4_SERVICE_PROFILE_UNKNOWN
5385 u8 queue_id5_service_profile;
5386 #define QUEUE_QPORTCFG_RESP_QUEUE_ID5_SERVICE_PROFILE_LOSSY 0x0UL
5387 #define QUEUE_QPORTCFG_RESP_QUEUE_ID5_SERVICE_PROFILE_LOSSLESS 0x1UL
5388 #define QUEUE_QPORTCFG_RESP_QUEUE_ID5_SERVICE_PROFILE_LOSSLESS_ROCE 0x1UL
5389 #define QUEUE_QPORTCFG_RESP_QUEUE_ID5_SERVICE_PROFILE_LOSSY_ROCE_CNP 0x2UL
5390 #define QUEUE_QPORTCFG_RESP_QUEUE_ID5_SERVICE_PROFILE_LOSSLESS_NIC 0x3UL
5391 #define QUEUE_QPORTCFG_RESP_QUEUE_ID5_SERVICE_PROFILE_UNKNOWN 0xffUL
5392 #define QUEUE_QPORTCFG_RESP_QUEUE_ID5_SERVICE_PROFILE_LAST QUEUE_QPORTCFG_RESP_QUEUE_ID5_SERVICE_PROFILE_UNKNOWN
5394 u8 queue_id6_service_profile;
5395 #define QUEUE_QPORTCFG_RESP_QUEUE_ID6_SERVICE_PROFILE_LOSSY 0x0UL
5396 #define QUEUE_QPORTCFG_RESP_QUEUE_ID6_SERVICE_PROFILE_LOSSLESS 0x1UL
5397 #define QUEUE_QPORTCFG_RESP_QUEUE_ID6_SERVICE_PROFILE_LOSSLESS_ROCE 0x1UL
5398 #define QUEUE_QPORTCFG_RESP_QUEUE_ID6_SERVICE_PROFILE_LOSSY_ROCE_CNP 0x2UL
5399 #define QUEUE_QPORTCFG_RESP_QUEUE_ID6_SERVICE_PROFILE_LOSSLESS_NIC 0x3UL
5400 #define QUEUE_QPORTCFG_RESP_QUEUE_ID6_SERVICE_PROFILE_UNKNOWN 0xffUL
5401 #define QUEUE_QPORTCFG_RESP_QUEUE_ID6_SERVICE_PROFILE_LAST QUEUE_QPORTCFG_RESP_QUEUE_ID6_SERVICE_PROFILE_UNKNOWN
5403 u8 queue_id7_service_profile;
5404 #define QUEUE_QPORTCFG_RESP_QUEUE_ID7_SERVICE_PROFILE_LOSSY 0x0UL
5405 #define QUEUE_QPORTCFG_RESP_QUEUE_ID7_SERVICE_PROFILE_LOSSLESS 0x1UL
5406 #define QUEUE_QPORTCFG_RESP_QUEUE_ID7_SERVICE_PROFILE_LOSSLESS_ROCE 0x1UL
5407 #define QUEUE_QPORTCFG_RESP_QUEUE_ID7_SERVICE_PROFILE_LOSSY_ROCE_CNP 0x2UL
5408 #define QUEUE_QPORTCFG_RESP_QUEUE_ID7_SERVICE_PROFILE_LOSSLESS_NIC 0x3UL
5409 #define QUEUE_QPORTCFG_RESP_QUEUE_ID7_SERVICE_PROFILE_UNKNOWN 0xffUL
5410 #define QUEUE_QPORTCFG_RESP_QUEUE_ID7_SERVICE_PROFILE_LAST QUEUE_QPORTCFG_RESP_QUEUE_ID7_SERVICE_PROFILE_UNKNOWN
5411 u8 queue_id0_service_profile_type;
5412 #define QUEUE_QPORTCFG_RESP_QUEUE_ID0_SERVICE_PROFILE_TYPE_ROCE 0x1UL
5413 #define QUEUE_QPORTCFG_RESP_QUEUE_ID0_SERVICE_PROFILE_TYPE_NIC 0x2UL
5414 #define QUEUE_QPORTCFG_RESP_QUEUE_ID0_SERVICE_PROFILE_TYPE_CNP 0x4UL
5423 u8 queue_id1_service_profile_type;
5424 #define QUEUE_QPORTCFG_RESP_QUEUE_ID1_SERVICE_PROFILE_TYPE_ROCE 0x1UL
5425 #define QUEUE_QPORTCFG_RESP_QUEUE_ID1_SERVICE_PROFILE_TYPE_NIC 0x2UL
5426 #define QUEUE_QPORTCFG_RESP_QUEUE_ID1_SERVICE_PROFILE_TYPE_CNP 0x4UL
5427 u8 queue_id2_service_profile_type;
5428 #define QUEUE_QPORTCFG_RESP_QUEUE_ID2_SERVICE_PROFILE_TYPE_ROCE 0x1UL
5429 #define QUEUE_QPORTCFG_RESP_QUEUE_ID2_SERVICE_PROFILE_TYPE_NIC 0x2UL
5430 #define QUEUE_QPORTCFG_RESP_QUEUE_ID2_SERVICE_PROFILE_TYPE_CNP 0x4UL
5431 u8 queue_id3_service_profile_type;
5432 #define QUEUE_QPORTCFG_RESP_QUEUE_ID3_SERVICE_PROFILE_TYPE_ROCE 0x1UL
5433 #define QUEUE_QPORTCFG_RESP_QUEUE_ID3_SERVICE_PROFILE_TYPE_NIC 0x2UL
5434 #define QUEUE_QPORTCFG_RESP_QUEUE_ID3_SERVICE_PROFILE_TYPE_CNP 0x4UL
5435 u8 queue_id4_service_profile_type;
5436 #define QUEUE_QPORTCFG_RESP_QUEUE_ID4_SERVICE_PROFILE_TYPE_ROCE 0x1UL
5437 #define QUEUE_QPORTCFG_RESP_QUEUE_ID4_SERVICE_PROFILE_TYPE_NIC 0x2UL
5438 #define QUEUE_QPORTCFG_RESP_QUEUE_ID4_SERVICE_PROFILE_TYPE_CNP 0x4UL
5439 u8 queue_id5_service_profile_type;
5440 #define QUEUE_QPORTCFG_RESP_QUEUE_ID5_SERVICE_PROFILE_TYPE_ROCE 0x1UL
5441 #define QUEUE_QPORTCFG_RESP_QUEUE_ID5_SERVICE_PROFILE_TYPE_NIC 0x2UL
5442 #define QUEUE_QPORTCFG_RESP_QUEUE_ID5_SERVICE_PROFILE_TYPE_CNP 0x4UL
5443 u8 queue_id6_service_profile_type;
5444 #define QUEUE_QPORTCFG_RESP_QUEUE_ID6_SERVICE_PROFILE_TYPE_ROCE 0x1UL
5445 #define QUEUE_QPORTCFG_RESP_QUEUE_ID6_SERVICE_PROFILE_TYPE_NIC 0x2UL
5446 #define QUEUE_QPORTCFG_RESP_QUEUE_ID6_SERVICE_PROFILE_TYPE_CNP 0x4UL
5447 u8 queue_id7_service_profile_type;
5448 #define QUEUE_QPORTCFG_RESP_QUEUE_ID7_SERVICE_PROFILE_TYPE_ROCE 0x1UL
5449 #define QUEUE_QPORTCFG_RESP_QUEUE_ID7_SERVICE_PROFILE_TYPE_NIC 0x2UL
5450 #define QUEUE_QPORTCFG_RESP_QUEUE_ID7_SERVICE_PROFILE_TYPE_CNP 0x4UL
5454 /* hwrm_queue_qcfg_input (size:192b/24B) */
5455 struct hwrm_queue_qcfg_input {
5462 #define QUEUE_QCFG_REQ_FLAGS_PATH 0x1UL
5463 #define QUEUE_QCFG_REQ_FLAGS_PATH_TX 0x0UL
5464 #define QUEUE_QCFG_REQ_FLAGS_PATH_RX 0x1UL
5465 #define QUEUE_QCFG_REQ_FLAGS_PATH_LAST QUEUE_QCFG_REQ_FLAGS_PATH_RX
5469 /* hwrm_queue_qcfg_output (size:128b/16B) */
5470 struct hwrm_queue_qcfg_output {
5477 #define QUEUE_QCFG_RESP_SERVICE_PROFILE_LOSSY 0x0UL
5478 #define QUEUE_QCFG_RESP_SERVICE_PROFILE_LOSSLESS 0x1UL
5479 #define QUEUE_QCFG_RESP_SERVICE_PROFILE_UNKNOWN 0xffUL
5480 #define QUEUE_QCFG_RESP_SERVICE_PROFILE_LAST QUEUE_QCFG_RESP_SERVICE_PROFILE_UNKNOWN
5482 #define QUEUE_QCFG_RESP_QUEUE_CFG_INFO_ASYM_CFG 0x1UL
5487 /* hwrm_queue_cfg_input (size:320b/40B) */
5488 struct hwrm_queue_cfg_input {
5495 #define QUEUE_CFG_REQ_FLAGS_PATH_MASK 0x3UL
5496 #define QUEUE_CFG_REQ_FLAGS_PATH_SFT 0
5497 #define QUEUE_CFG_REQ_FLAGS_PATH_TX 0x0UL
5498 #define QUEUE_CFG_REQ_FLAGS_PATH_RX 0x1UL
5499 #define QUEUE_CFG_REQ_FLAGS_PATH_BIDIR 0x2UL
5500 #define QUEUE_CFG_REQ_FLAGS_PATH_LAST QUEUE_CFG_REQ_FLAGS_PATH_BIDIR
5502 #define QUEUE_CFG_REQ_ENABLES_DFLT_LEN 0x1UL
5503 #define QUEUE_CFG_REQ_ENABLES_SERVICE_PROFILE 0x2UL
5507 #define QUEUE_CFG_REQ_SERVICE_PROFILE_LOSSY 0x0UL
5508 #define QUEUE_CFG_REQ_SERVICE_PROFILE_LOSSLESS 0x1UL
5509 #define QUEUE_CFG_REQ_SERVICE_PROFILE_UNKNOWN 0xffUL
5510 #define QUEUE_CFG_REQ_SERVICE_PROFILE_LAST QUEUE_CFG_REQ_SERVICE_PROFILE_UNKNOWN
5514 /* hwrm_queue_cfg_output (size:128b/16B) */
5515 struct hwrm_queue_cfg_output {
5524 /* hwrm_queue_pfcenable_qcfg_input (size:192b/24B) */
5525 struct hwrm_queue_pfcenable_qcfg_input {
5535 /* hwrm_queue_pfcenable_qcfg_output (size:128b/16B) */
5536 struct hwrm_queue_pfcenable_qcfg_output {
5542 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI0_PFC_ENABLED 0x1UL
5543 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI1_PFC_ENABLED 0x2UL
5544 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI2_PFC_ENABLED 0x4UL
5545 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI3_PFC_ENABLED 0x8UL
5546 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI4_PFC_ENABLED 0x10UL
5547 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI5_PFC_ENABLED 0x20UL
5548 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI6_PFC_ENABLED 0x40UL
5549 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI7_PFC_ENABLED 0x80UL
5550 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI0_PFC_WATCHDOG_ENABLED 0x100UL
5551 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI1_PFC_WATCHDOG_ENABLED 0x200UL
5552 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI2_PFC_WATCHDOG_ENABLED 0x400UL
5553 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI3_PFC_WATCHDOG_ENABLED 0x800UL
5554 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI4_PFC_WATCHDOG_ENABLED 0x1000UL
5555 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI5_PFC_WATCHDOG_ENABLED 0x2000UL
5556 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI6_PFC_WATCHDOG_ENABLED 0x4000UL
5557 #define QUEUE_PFCENABLE_QCFG_RESP_FLAGS_PRI7_PFC_WATCHDOG_ENABLED 0x8000UL
5562 /* hwrm_queue_pfcenable_cfg_input (size:192b/24B) */
5563 struct hwrm_queue_pfcenable_cfg_input {
5570 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI0_PFC_ENABLED 0x1UL
5571 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI1_PFC_ENABLED 0x2UL
5572 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI2_PFC_ENABLED 0x4UL
5573 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI3_PFC_ENABLED 0x8UL
5574 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI4_PFC_ENABLED 0x10UL
5575 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI5_PFC_ENABLED 0x20UL
5576 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI6_PFC_ENABLED 0x40UL
5577 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI7_PFC_ENABLED 0x80UL
5578 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI0_PFC_WATCHDOG_ENABLED 0x100UL
5579 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI1_PFC_WATCHDOG_ENABLED 0x200UL
5580 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI2_PFC_WATCHDOG_ENABLED 0x400UL
5581 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI3_PFC_WATCHDOG_ENABLED 0x800UL
5582 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI4_PFC_WATCHDOG_ENABLED 0x1000UL
5583 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI5_PFC_WATCHDOG_ENABLED 0x2000UL
5584 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI6_PFC_WATCHDOG_ENABLED 0x4000UL
5585 #define QUEUE_PFCENABLE_CFG_REQ_FLAGS_PRI7_PFC_WATCHDOG_ENABLED 0x8000UL
5590 /* hwrm_queue_pfcenable_cfg_output (size:128b/16B) */
5591 struct hwrm_queue_pfcenable_cfg_output {
5600 /* hwrm_queue_pri2cos_qcfg_input (size:192b/24B) */
5601 struct hwrm_queue_pri2cos_qcfg_input {
5608 #define QUEUE_PRI2COS_QCFG_REQ_FLAGS_PATH 0x1UL
5609 #define QUEUE_PRI2COS_QCFG_REQ_FLAGS_PATH_TX 0x0UL
5610 #define QUEUE_PRI2COS_QCFG_REQ_FLAGS_PATH_RX 0x1UL
5611 #define QUEUE_PRI2COS_QCFG_REQ_FLAGS_PATH_LAST QUEUE_PRI2COS_QCFG_REQ_FLAGS_PATH_RX
5612 #define QUEUE_PRI2COS_QCFG_REQ_FLAGS_IVLAN 0x2UL
5617 /* hwrm_queue_pri2cos_qcfg_output (size:192b/24B) */
5618 struct hwrm_queue_pri2cos_qcfg_output {
5623 u8 pri0_cos_queue_id;
5624 u8 pri1_cos_queue_id;
5625 u8 pri2_cos_queue_id;
5626 u8 pri3_cos_queue_id;
5627 u8 pri4_cos_queue_id;
5628 u8 pri5_cos_queue_id;
5629 u8 pri6_cos_queue_id;
5630 u8 pri7_cos_queue_id;
5632 #define QUEUE_PRI2COS_QCFG_RESP_QUEUE_CFG_INFO_ASYM_CFG 0x1UL
5637 /* hwrm_queue_pri2cos_cfg_input (size:320b/40B) */
5638 struct hwrm_queue_pri2cos_cfg_input {
5645 #define QUEUE_PRI2COS_CFG_REQ_FLAGS_PATH_MASK 0x3UL
5646 #define QUEUE_PRI2COS_CFG_REQ_FLAGS_PATH_SFT 0
5647 #define QUEUE_PRI2COS_CFG_REQ_FLAGS_PATH_TX 0x0UL
5648 #define QUEUE_PRI2COS_CFG_REQ_FLAGS_PATH_RX 0x1UL
5649 #define QUEUE_PRI2COS_CFG_REQ_FLAGS_PATH_BIDIR 0x2UL
5650 #define QUEUE_PRI2COS_CFG_REQ_FLAGS_PATH_LAST QUEUE_PRI2COS_CFG_REQ_FLAGS_PATH_BIDIR
5651 #define QUEUE_PRI2COS_CFG_REQ_FLAGS_IVLAN 0x4UL
5653 #define QUEUE_PRI2COS_CFG_REQ_ENABLES_PRI0_COS_QUEUE_ID 0x1UL
5654 #define QUEUE_PRI2COS_CFG_REQ_ENABLES_PRI1_COS_QUEUE_ID 0x2UL
5655 #define QUEUE_PRI2COS_CFG_REQ_ENABLES_PRI2_COS_QUEUE_ID 0x4UL
5656 #define QUEUE_PRI2COS_CFG_REQ_ENABLES_PRI3_COS_QUEUE_ID 0x8UL
5657 #define QUEUE_PRI2COS_CFG_REQ_ENABLES_PRI4_COS_QUEUE_ID 0x10UL
5658 #define QUEUE_PRI2COS_CFG_REQ_ENABLES_PRI5_COS_QUEUE_ID 0x20UL
5659 #define QUEUE_PRI2COS_CFG_REQ_ENABLES_PRI6_COS_QUEUE_ID 0x40UL
5660 #define QUEUE_PRI2COS_CFG_REQ_ENABLES_PRI7_COS_QUEUE_ID 0x80UL
5662 u8 pri0_cos_queue_id;
5663 u8 pri1_cos_queue_id;
5664 u8 pri2_cos_queue_id;
5665 u8 pri3_cos_queue_id;
5666 u8 pri4_cos_queue_id;
5667 u8 pri5_cos_queue_id;
5668 u8 pri6_cos_queue_id;
5669 u8 pri7_cos_queue_id;
5673 /* hwrm_queue_pri2cos_cfg_output (size:128b/16B) */
5674 struct hwrm_queue_pri2cos_cfg_output {
5683 /* hwrm_queue_cos2bw_qcfg_input (size:192b/24B) */
5684 struct hwrm_queue_cos2bw_qcfg_input {
5694 /* hwrm_queue_cos2bw_qcfg_output (size:896b/112B) */
5695 struct hwrm_queue_cos2bw_qcfg_output {
5703 __le32 queue_id0_min_bw;
5704 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_BW_VALUE_MASK 0xfffffffUL
5705 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_BW_VALUE_SFT 0
5706 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_SCALE 0x10000000UL
5707 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_SCALE_BITS (0x0UL << 28)
5708 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_SCALE_BYTES (0x1UL << 28)
5709 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_SCALE_BYTES
5710 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5711 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_SFT 29
5712 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5713 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5714 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5715 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5716 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5717 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5718 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_INVALID
5719 __le32 queue_id0_max_bw;
5720 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_BW_VALUE_MASK 0xfffffffUL
5721 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_BW_VALUE_SFT 0
5722 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_SCALE 0x10000000UL
5723 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_SCALE_BITS (0x0UL << 28)
5724 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_SCALE_BYTES (0x1UL << 28)
5725 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_SCALE_BYTES
5726 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5727 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_SFT 29
5728 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5729 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5730 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5731 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5732 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5733 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5734 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_INVALID
5735 u8 queue_id0_tsa_assign;
5736 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_TSA_ASSIGN_SP 0x0UL
5737 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_TSA_ASSIGN_ETS 0x1UL
5738 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_TSA_ASSIGN_RESERVED_FIRST 0x2UL
5739 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID0_TSA_ASSIGN_RESERVED_LAST 0xffUL
5740 u8 queue_id0_pri_lvl;
5741 u8 queue_id0_bw_weight;
5743 __le32 queue_id1_min_bw;
5744 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_BW_VALUE_MASK 0xfffffffUL
5745 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_BW_VALUE_SFT 0
5746 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_SCALE 0x10000000UL
5747 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_SCALE_BITS (0x0UL << 28)
5748 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_SCALE_BYTES (0x1UL << 28)
5749 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_SCALE_BYTES
5750 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5751 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_SFT 29
5752 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5753 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5754 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5755 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5756 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5757 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5758 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_INVALID
5759 __le32 queue_id1_max_bw;
5760 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_BW_VALUE_MASK 0xfffffffUL
5761 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_BW_VALUE_SFT 0
5762 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_SCALE 0x10000000UL
5763 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_SCALE_BITS (0x0UL << 28)
5764 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_SCALE_BYTES (0x1UL << 28)
5765 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_SCALE_BYTES
5766 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5767 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_SFT 29
5768 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5769 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5770 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5771 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5772 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5773 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5774 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_INVALID
5775 u8 queue_id1_tsa_assign;
5776 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_TSA_ASSIGN_SP 0x0UL
5777 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_TSA_ASSIGN_ETS 0x1UL
5778 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_TSA_ASSIGN_RESERVED_FIRST 0x2UL
5779 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID1_TSA_ASSIGN_RESERVED_LAST 0xffUL
5780 u8 queue_id1_pri_lvl;
5781 u8 queue_id1_bw_weight;
5783 __le32 queue_id2_min_bw;
5784 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_BW_VALUE_MASK 0xfffffffUL
5785 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_BW_VALUE_SFT 0
5786 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_SCALE 0x10000000UL
5787 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_SCALE_BITS (0x0UL << 28)
5788 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_SCALE_BYTES (0x1UL << 28)
5789 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_SCALE_BYTES
5790 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5791 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_SFT 29
5792 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5793 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5794 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5795 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5796 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5797 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5798 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_INVALID
5799 __le32 queue_id2_max_bw;
5800 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_BW_VALUE_MASK 0xfffffffUL
5801 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_BW_VALUE_SFT 0
5802 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_SCALE 0x10000000UL
5803 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_SCALE_BITS (0x0UL << 28)
5804 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_SCALE_BYTES (0x1UL << 28)
5805 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_SCALE_BYTES
5806 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5807 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_SFT 29
5808 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5809 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5810 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5811 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5812 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5813 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5814 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_INVALID
5815 u8 queue_id2_tsa_assign;
5816 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_TSA_ASSIGN_SP 0x0UL
5817 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_TSA_ASSIGN_ETS 0x1UL
5818 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_TSA_ASSIGN_RESERVED_FIRST 0x2UL
5819 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID2_TSA_ASSIGN_RESERVED_LAST 0xffUL
5820 u8 queue_id2_pri_lvl;
5821 u8 queue_id2_bw_weight;
5823 __le32 queue_id3_min_bw;
5824 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_BW_VALUE_MASK 0xfffffffUL
5825 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_BW_VALUE_SFT 0
5826 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_SCALE 0x10000000UL
5827 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_SCALE_BITS (0x0UL << 28)
5828 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_SCALE_BYTES (0x1UL << 28)
5829 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_SCALE_BYTES
5830 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5831 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_SFT 29
5832 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5833 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5834 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5835 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5836 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5837 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5838 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_INVALID
5839 __le32 queue_id3_max_bw;
5840 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_BW_VALUE_MASK 0xfffffffUL
5841 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_BW_VALUE_SFT 0
5842 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_SCALE 0x10000000UL
5843 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_SCALE_BITS (0x0UL << 28)
5844 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_SCALE_BYTES (0x1UL << 28)
5845 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_SCALE_BYTES
5846 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5847 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_SFT 29
5848 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5849 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5850 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5851 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5852 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5853 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5854 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_INVALID
5855 u8 queue_id3_tsa_assign;
5856 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_TSA_ASSIGN_SP 0x0UL
5857 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_TSA_ASSIGN_ETS 0x1UL
5858 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_TSA_ASSIGN_RESERVED_FIRST 0x2UL
5859 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID3_TSA_ASSIGN_RESERVED_LAST 0xffUL
5860 u8 queue_id3_pri_lvl;
5861 u8 queue_id3_bw_weight;
5863 __le32 queue_id4_min_bw;
5864 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_BW_VALUE_MASK 0xfffffffUL
5865 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_BW_VALUE_SFT 0
5866 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_SCALE 0x10000000UL
5867 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_SCALE_BITS (0x0UL << 28)
5868 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_SCALE_BYTES (0x1UL << 28)
5869 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_SCALE_BYTES
5870 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5871 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_SFT 29
5872 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5873 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5874 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5875 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5876 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5877 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5878 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_INVALID
5879 __le32 queue_id4_max_bw;
5880 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_BW_VALUE_MASK 0xfffffffUL
5881 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_BW_VALUE_SFT 0
5882 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_SCALE 0x10000000UL
5883 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_SCALE_BITS (0x0UL << 28)
5884 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_SCALE_BYTES (0x1UL << 28)
5885 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_SCALE_BYTES
5886 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5887 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_SFT 29
5888 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5889 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5890 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5891 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5892 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5893 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5894 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_INVALID
5895 u8 queue_id4_tsa_assign;
5896 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_TSA_ASSIGN_SP 0x0UL
5897 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_TSA_ASSIGN_ETS 0x1UL
5898 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_TSA_ASSIGN_RESERVED_FIRST 0x2UL
5899 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID4_TSA_ASSIGN_RESERVED_LAST 0xffUL
5900 u8 queue_id4_pri_lvl;
5901 u8 queue_id4_bw_weight;
5903 __le32 queue_id5_min_bw;
5904 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_BW_VALUE_MASK 0xfffffffUL
5905 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_BW_VALUE_SFT 0
5906 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_SCALE 0x10000000UL
5907 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_SCALE_BITS (0x0UL << 28)
5908 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_SCALE_BYTES (0x1UL << 28)
5909 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_SCALE_BYTES
5910 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5911 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_SFT 29
5912 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5913 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5914 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5915 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5916 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5917 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5918 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_INVALID
5919 __le32 queue_id5_max_bw;
5920 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_BW_VALUE_MASK 0xfffffffUL
5921 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_BW_VALUE_SFT 0
5922 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_SCALE 0x10000000UL
5923 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_SCALE_BITS (0x0UL << 28)
5924 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_SCALE_BYTES (0x1UL << 28)
5925 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_SCALE_BYTES
5926 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5927 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_SFT 29
5928 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5929 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5930 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5931 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5932 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5933 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5934 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_INVALID
5935 u8 queue_id5_tsa_assign;
5936 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_TSA_ASSIGN_SP 0x0UL
5937 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_TSA_ASSIGN_ETS 0x1UL
5938 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_TSA_ASSIGN_RESERVED_FIRST 0x2UL
5939 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID5_TSA_ASSIGN_RESERVED_LAST 0xffUL
5940 u8 queue_id5_pri_lvl;
5941 u8 queue_id5_bw_weight;
5943 __le32 queue_id6_min_bw;
5944 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_BW_VALUE_MASK 0xfffffffUL
5945 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_BW_VALUE_SFT 0
5946 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_SCALE 0x10000000UL
5947 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_SCALE_BITS (0x0UL << 28)
5948 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_SCALE_BYTES (0x1UL << 28)
5949 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_SCALE_BYTES
5950 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5951 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_SFT 29
5952 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5953 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5954 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5955 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5956 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5957 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5958 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_INVALID
5959 __le32 queue_id6_max_bw;
5960 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_BW_VALUE_MASK 0xfffffffUL
5961 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_BW_VALUE_SFT 0
5962 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_SCALE 0x10000000UL
5963 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_SCALE_BITS (0x0UL << 28)
5964 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_SCALE_BYTES (0x1UL << 28)
5965 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_SCALE_BYTES
5966 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5967 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_SFT 29
5968 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5969 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5970 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5971 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5972 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5973 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5974 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_INVALID
5975 u8 queue_id6_tsa_assign;
5976 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_TSA_ASSIGN_SP 0x0UL
5977 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_TSA_ASSIGN_ETS 0x1UL
5978 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_TSA_ASSIGN_RESERVED_FIRST 0x2UL
5979 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID6_TSA_ASSIGN_RESERVED_LAST 0xffUL
5980 u8 queue_id6_pri_lvl;
5981 u8 queue_id6_bw_weight;
5983 __le32 queue_id7_min_bw;
5984 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_BW_VALUE_MASK 0xfffffffUL
5985 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_BW_VALUE_SFT 0
5986 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_SCALE 0x10000000UL
5987 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_SCALE_BITS (0x0UL << 28)
5988 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_SCALE_BYTES (0x1UL << 28)
5989 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_SCALE_BYTES
5990 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
5991 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_SFT 29
5992 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
5993 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
5994 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
5995 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
5996 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
5997 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
5998 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_INVALID
5999 __le32 queue_id7_max_bw;
6000 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_BW_VALUE_MASK 0xfffffffUL
6001 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_BW_VALUE_SFT 0
6002 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_SCALE 0x10000000UL
6003 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_SCALE_BITS (0x0UL << 28)
6004 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_SCALE_BYTES (0x1UL << 28)
6005 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_SCALE_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_SCALE_BYTES
6006 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6007 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_SFT 29
6008 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6009 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6010 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6011 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6012 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6013 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6014 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_INVALID
6015 u8 queue_id7_tsa_assign;
6016 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_TSA_ASSIGN_SP 0x0UL
6017 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_TSA_ASSIGN_ETS 0x1UL
6018 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_TSA_ASSIGN_RESERVED_FIRST 0x2UL
6019 #define QUEUE_COS2BW_QCFG_RESP_QUEUE_ID7_TSA_ASSIGN_RESERVED_LAST 0xffUL
6020 u8 queue_id7_pri_lvl;
6021 u8 queue_id7_bw_weight;
6026 /* hwrm_queue_cos2bw_cfg_input (size:1024b/128B) */
6027 struct hwrm_queue_cos2bw_cfg_input {
6035 #define QUEUE_COS2BW_CFG_REQ_ENABLES_COS_QUEUE_ID0_VALID 0x1UL
6036 #define QUEUE_COS2BW_CFG_REQ_ENABLES_COS_QUEUE_ID1_VALID 0x2UL
6037 #define QUEUE_COS2BW_CFG_REQ_ENABLES_COS_QUEUE_ID2_VALID 0x4UL
6038 #define QUEUE_COS2BW_CFG_REQ_ENABLES_COS_QUEUE_ID3_VALID 0x8UL
6039 #define QUEUE_COS2BW_CFG_REQ_ENABLES_COS_QUEUE_ID4_VALID 0x10UL
6040 #define QUEUE_COS2BW_CFG_REQ_ENABLES_COS_QUEUE_ID5_VALID 0x20UL
6041 #define QUEUE_COS2BW_CFG_REQ_ENABLES_COS_QUEUE_ID6_VALID 0x40UL
6042 #define QUEUE_COS2BW_CFG_REQ_ENABLES_COS_QUEUE_ID7_VALID 0x80UL
6046 __le32 queue_id0_min_bw;
6047 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_BW_VALUE_MASK 0xfffffffUL
6048 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_BW_VALUE_SFT 0
6049 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_SCALE 0x10000000UL
6050 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_SCALE_BITS (0x0UL << 28)
6051 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_SCALE_BYTES (0x1UL << 28)
6052 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_SCALE_BYTES
6053 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6054 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_SFT 29
6055 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6056 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6057 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6058 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6059 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6060 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6061 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MIN_BW_BW_VALUE_UNIT_INVALID
6062 __le32 queue_id0_max_bw;
6063 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_BW_VALUE_MASK 0xfffffffUL
6064 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_BW_VALUE_SFT 0
6065 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_SCALE 0x10000000UL
6066 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_SCALE_BITS (0x0UL << 28)
6067 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_SCALE_BYTES (0x1UL << 28)
6068 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_SCALE_BYTES
6069 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6070 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_SFT 29
6071 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6072 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6073 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6074 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6075 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6076 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6077 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_MAX_BW_BW_VALUE_UNIT_INVALID
6078 u8 queue_id0_tsa_assign;
6079 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_TSA_ASSIGN_SP 0x0UL
6080 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_TSA_ASSIGN_ETS 0x1UL
6081 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_TSA_ASSIGN_RESERVED_FIRST 0x2UL
6082 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID0_TSA_ASSIGN_RESERVED_LAST 0xffUL
6083 u8 queue_id0_pri_lvl;
6084 u8 queue_id0_bw_weight;
6086 __le32 queue_id1_min_bw;
6087 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_BW_VALUE_MASK 0xfffffffUL
6088 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_BW_VALUE_SFT 0
6089 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_SCALE 0x10000000UL
6090 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_SCALE_BITS (0x0UL << 28)
6091 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_SCALE_BYTES (0x1UL << 28)
6092 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_SCALE_BYTES
6093 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6094 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_SFT 29
6095 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6096 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6097 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6098 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6099 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6100 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6101 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MIN_BW_BW_VALUE_UNIT_INVALID
6102 __le32 queue_id1_max_bw;
6103 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_BW_VALUE_MASK 0xfffffffUL
6104 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_BW_VALUE_SFT 0
6105 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_SCALE 0x10000000UL
6106 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_SCALE_BITS (0x0UL << 28)
6107 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_SCALE_BYTES (0x1UL << 28)
6108 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_SCALE_BYTES
6109 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6110 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_SFT 29
6111 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6112 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6113 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6114 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6115 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6116 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6117 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_MAX_BW_BW_VALUE_UNIT_INVALID
6118 u8 queue_id1_tsa_assign;
6119 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_TSA_ASSIGN_SP 0x0UL
6120 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_TSA_ASSIGN_ETS 0x1UL
6121 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_TSA_ASSIGN_RESERVED_FIRST 0x2UL
6122 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID1_TSA_ASSIGN_RESERVED_LAST 0xffUL
6123 u8 queue_id1_pri_lvl;
6124 u8 queue_id1_bw_weight;
6126 __le32 queue_id2_min_bw;
6127 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_BW_VALUE_MASK 0xfffffffUL
6128 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_BW_VALUE_SFT 0
6129 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_SCALE 0x10000000UL
6130 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_SCALE_BITS (0x0UL << 28)
6131 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_SCALE_BYTES (0x1UL << 28)
6132 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_SCALE_BYTES
6133 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6134 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_SFT 29
6135 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6136 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6137 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6138 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6139 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6140 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6141 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MIN_BW_BW_VALUE_UNIT_INVALID
6142 __le32 queue_id2_max_bw;
6143 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_BW_VALUE_MASK 0xfffffffUL
6144 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_BW_VALUE_SFT 0
6145 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_SCALE 0x10000000UL
6146 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_SCALE_BITS (0x0UL << 28)
6147 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_SCALE_BYTES (0x1UL << 28)
6148 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_SCALE_BYTES
6149 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6150 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_SFT 29
6151 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6152 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6153 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6154 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6155 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6156 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6157 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_MAX_BW_BW_VALUE_UNIT_INVALID
6158 u8 queue_id2_tsa_assign;
6159 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_TSA_ASSIGN_SP 0x0UL
6160 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_TSA_ASSIGN_ETS 0x1UL
6161 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_TSA_ASSIGN_RESERVED_FIRST 0x2UL
6162 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID2_TSA_ASSIGN_RESERVED_LAST 0xffUL
6163 u8 queue_id2_pri_lvl;
6164 u8 queue_id2_bw_weight;
6166 __le32 queue_id3_min_bw;
6167 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_BW_VALUE_MASK 0xfffffffUL
6168 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_BW_VALUE_SFT 0
6169 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_SCALE 0x10000000UL
6170 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_SCALE_BITS (0x0UL << 28)
6171 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_SCALE_BYTES (0x1UL << 28)
6172 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_SCALE_BYTES
6173 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6174 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_SFT 29
6175 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6176 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6177 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6178 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6179 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6180 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6181 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MIN_BW_BW_VALUE_UNIT_INVALID
6182 __le32 queue_id3_max_bw;
6183 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_BW_VALUE_MASK 0xfffffffUL
6184 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_BW_VALUE_SFT 0
6185 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_SCALE 0x10000000UL
6186 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_SCALE_BITS (0x0UL << 28)
6187 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_SCALE_BYTES (0x1UL << 28)
6188 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_SCALE_BYTES
6189 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6190 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_SFT 29
6191 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6192 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6193 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6194 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6195 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6196 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6197 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_MAX_BW_BW_VALUE_UNIT_INVALID
6198 u8 queue_id3_tsa_assign;
6199 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_TSA_ASSIGN_SP 0x0UL
6200 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_TSA_ASSIGN_ETS 0x1UL
6201 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_TSA_ASSIGN_RESERVED_FIRST 0x2UL
6202 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID3_TSA_ASSIGN_RESERVED_LAST 0xffUL
6203 u8 queue_id3_pri_lvl;
6204 u8 queue_id3_bw_weight;
6206 __le32 queue_id4_min_bw;
6207 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_BW_VALUE_MASK 0xfffffffUL
6208 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_BW_VALUE_SFT 0
6209 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_SCALE 0x10000000UL
6210 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_SCALE_BITS (0x0UL << 28)
6211 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_SCALE_BYTES (0x1UL << 28)
6212 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_SCALE_BYTES
6213 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6214 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_SFT 29
6215 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6216 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6217 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6218 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6219 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6220 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6221 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MIN_BW_BW_VALUE_UNIT_INVALID
6222 __le32 queue_id4_max_bw;
6223 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_BW_VALUE_MASK 0xfffffffUL
6224 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_BW_VALUE_SFT 0
6225 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_SCALE 0x10000000UL
6226 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_SCALE_BITS (0x0UL << 28)
6227 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_SCALE_BYTES (0x1UL << 28)
6228 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_SCALE_BYTES
6229 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6230 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_SFT 29
6231 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6232 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6233 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6234 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6235 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6236 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6237 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_MAX_BW_BW_VALUE_UNIT_INVALID
6238 u8 queue_id4_tsa_assign;
6239 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_TSA_ASSIGN_SP 0x0UL
6240 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_TSA_ASSIGN_ETS 0x1UL
6241 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_TSA_ASSIGN_RESERVED_FIRST 0x2UL
6242 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID4_TSA_ASSIGN_RESERVED_LAST 0xffUL
6243 u8 queue_id4_pri_lvl;
6244 u8 queue_id4_bw_weight;
6246 __le32 queue_id5_min_bw;
6247 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_BW_VALUE_MASK 0xfffffffUL
6248 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_BW_VALUE_SFT 0
6249 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_SCALE 0x10000000UL
6250 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_SCALE_BITS (0x0UL << 28)
6251 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_SCALE_BYTES (0x1UL << 28)
6252 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_SCALE_BYTES
6253 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6254 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_SFT 29
6255 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6256 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6257 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6258 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6259 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6260 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6261 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MIN_BW_BW_VALUE_UNIT_INVALID
6262 __le32 queue_id5_max_bw;
6263 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_BW_VALUE_MASK 0xfffffffUL
6264 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_BW_VALUE_SFT 0
6265 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_SCALE 0x10000000UL
6266 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_SCALE_BITS (0x0UL << 28)
6267 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_SCALE_BYTES (0x1UL << 28)
6268 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_SCALE_BYTES
6269 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6270 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_SFT 29
6271 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6272 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6273 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6274 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6275 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6276 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6277 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_MAX_BW_BW_VALUE_UNIT_INVALID
6278 u8 queue_id5_tsa_assign;
6279 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_TSA_ASSIGN_SP 0x0UL
6280 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_TSA_ASSIGN_ETS 0x1UL
6281 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_TSA_ASSIGN_RESERVED_FIRST 0x2UL
6282 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID5_TSA_ASSIGN_RESERVED_LAST 0xffUL
6283 u8 queue_id5_pri_lvl;
6284 u8 queue_id5_bw_weight;
6286 __le32 queue_id6_min_bw;
6287 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_BW_VALUE_MASK 0xfffffffUL
6288 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_BW_VALUE_SFT 0
6289 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_SCALE 0x10000000UL
6290 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_SCALE_BITS (0x0UL << 28)
6291 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_SCALE_BYTES (0x1UL << 28)
6292 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_SCALE_BYTES
6293 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6294 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_SFT 29
6295 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6296 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6297 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6298 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6299 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6300 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6301 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MIN_BW_BW_VALUE_UNIT_INVALID
6302 __le32 queue_id6_max_bw;
6303 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_BW_VALUE_MASK 0xfffffffUL
6304 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_BW_VALUE_SFT 0
6305 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_SCALE 0x10000000UL
6306 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_SCALE_BITS (0x0UL << 28)
6307 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_SCALE_BYTES (0x1UL << 28)
6308 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_SCALE_BYTES
6309 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6310 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_SFT 29
6311 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6312 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6313 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6314 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6315 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6316 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6317 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_MAX_BW_BW_VALUE_UNIT_INVALID
6318 u8 queue_id6_tsa_assign;
6319 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_TSA_ASSIGN_SP 0x0UL
6320 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_TSA_ASSIGN_ETS 0x1UL
6321 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_TSA_ASSIGN_RESERVED_FIRST 0x2UL
6322 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID6_TSA_ASSIGN_RESERVED_LAST 0xffUL
6323 u8 queue_id6_pri_lvl;
6324 u8 queue_id6_bw_weight;
6326 __le32 queue_id7_min_bw;
6327 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_BW_VALUE_MASK 0xfffffffUL
6328 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_BW_VALUE_SFT 0
6329 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_SCALE 0x10000000UL
6330 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_SCALE_BITS (0x0UL << 28)
6331 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_SCALE_BYTES (0x1UL << 28)
6332 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_SCALE_BYTES
6333 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6334 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_SFT 29
6335 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6336 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6337 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6338 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6339 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6340 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6341 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MIN_BW_BW_VALUE_UNIT_INVALID
6342 __le32 queue_id7_max_bw;
6343 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_BW_VALUE_MASK 0xfffffffUL
6344 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_BW_VALUE_SFT 0
6345 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_SCALE 0x10000000UL
6346 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_SCALE_BITS (0x0UL << 28)
6347 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_SCALE_BYTES (0x1UL << 28)
6348 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_SCALE_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_SCALE_BYTES
6349 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6350 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_SFT 29
6351 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6352 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6353 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6354 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6355 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6356 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6357 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_LAST QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_MAX_BW_BW_VALUE_UNIT_INVALID
6358 u8 queue_id7_tsa_assign;
6359 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_TSA_ASSIGN_SP 0x0UL
6360 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_TSA_ASSIGN_ETS 0x1UL
6361 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_TSA_ASSIGN_RESERVED_FIRST 0x2UL
6362 #define QUEUE_COS2BW_CFG_REQ_QUEUE_ID7_TSA_ASSIGN_RESERVED_LAST 0xffUL
6363 u8 queue_id7_pri_lvl;
6364 u8 queue_id7_bw_weight;
6368 /* hwrm_queue_cos2bw_cfg_output (size:128b/16B) */
6369 struct hwrm_queue_cos2bw_cfg_output {
6378 /* hwrm_queue_dscp_qcaps_input (size:192b/24B) */
6379 struct hwrm_queue_dscp_qcaps_input {
6389 /* hwrm_queue_dscp_qcaps_output (size:128b/16B) */
6390 struct hwrm_queue_dscp_qcaps_output {
6402 /* hwrm_queue_dscp2pri_qcfg_input (size:256b/32B) */
6403 struct hwrm_queue_dscp2pri_qcfg_input {
6409 __le64 dest_data_addr;
6412 __le16 dest_data_buffer_size;
6416 /* hwrm_queue_dscp2pri_qcfg_output (size:128b/16B) */
6417 struct hwrm_queue_dscp2pri_qcfg_output {
6428 /* hwrm_queue_dscp2pri_cfg_input (size:320b/40B) */
6429 struct hwrm_queue_dscp2pri_cfg_input {
6435 __le64 src_data_addr;
6437 #define QUEUE_DSCP2PRI_CFG_REQ_FLAGS_USE_HW_DEFAULT_PRI 0x1UL
6439 #define QUEUE_DSCP2PRI_CFG_REQ_ENABLES_DEFAULT_PRI 0x1UL
6446 /* hwrm_queue_dscp2pri_cfg_output (size:128b/16B) */
6447 struct hwrm_queue_dscp2pri_cfg_output {
6456 /* hwrm_vnic_alloc_input (size:192b/24B) */
6457 struct hwrm_vnic_alloc_input {
6464 #define VNIC_ALLOC_REQ_FLAGS_DEFAULT 0x1UL
6465 #define VNIC_ALLOC_REQ_FLAGS_VIRTIO_NET_FID_VALID 0x2UL
6466 __le16 virtio_net_fid;
6470 /* hwrm_vnic_alloc_output (size:128b/16B) */
6471 struct hwrm_vnic_alloc_output {
6481 /* hwrm_vnic_free_input (size:192b/24B) */
6482 struct hwrm_vnic_free_input {
6492 /* hwrm_vnic_free_output (size:128b/16B) */
6493 struct hwrm_vnic_free_output {
6502 /* hwrm_vnic_cfg_input (size:384b/48B) */
6503 struct hwrm_vnic_cfg_input {
6510 #define VNIC_CFG_REQ_FLAGS_DEFAULT 0x1UL
6511 #define VNIC_CFG_REQ_FLAGS_VLAN_STRIP_MODE 0x2UL
6512 #define VNIC_CFG_REQ_FLAGS_BD_STALL_MODE 0x4UL
6513 #define VNIC_CFG_REQ_FLAGS_ROCE_DUAL_VNIC_MODE 0x8UL
6514 #define VNIC_CFG_REQ_FLAGS_ROCE_ONLY_VNIC_MODE 0x10UL
6515 #define VNIC_CFG_REQ_FLAGS_RSS_DFLT_CR_MODE 0x20UL
6516 #define VNIC_CFG_REQ_FLAGS_ROCE_MIRRORING_CAPABLE_VNIC_MODE 0x40UL
6518 #define VNIC_CFG_REQ_ENABLES_DFLT_RING_GRP 0x1UL
6519 #define VNIC_CFG_REQ_ENABLES_RSS_RULE 0x2UL
6520 #define VNIC_CFG_REQ_ENABLES_COS_RULE 0x4UL
6521 #define VNIC_CFG_REQ_ENABLES_LB_RULE 0x8UL
6522 #define VNIC_CFG_REQ_ENABLES_MRU 0x10UL
6523 #define VNIC_CFG_REQ_ENABLES_DEFAULT_RX_RING_ID 0x20UL
6524 #define VNIC_CFG_REQ_ENABLES_DEFAULT_CMPL_RING_ID 0x40UL
6525 #define VNIC_CFG_REQ_ENABLES_QUEUE_ID 0x80UL
6526 #define VNIC_CFG_REQ_ENABLES_RX_CSUM_V2_MODE 0x100UL
6527 #define VNIC_CFG_REQ_ENABLES_L2_CQE_MODE 0x200UL
6529 __le16 dflt_ring_grp;
6534 __le16 default_rx_ring_id;
6535 __le16 default_cmpl_ring_id;
6538 #define VNIC_CFG_REQ_RX_CSUM_V2_MODE_DEFAULT 0x0UL
6539 #define VNIC_CFG_REQ_RX_CSUM_V2_MODE_ALL_OK 0x1UL
6540 #define VNIC_CFG_REQ_RX_CSUM_V2_MODE_MAX 0x2UL
6541 #define VNIC_CFG_REQ_RX_CSUM_V2_MODE_LAST VNIC_CFG_REQ_RX_CSUM_V2_MODE_MAX
6543 #define VNIC_CFG_REQ_L2_CQE_MODE_DEFAULT 0x0UL
6544 #define VNIC_CFG_REQ_L2_CQE_MODE_COMPRESSED 0x1UL
6545 #define VNIC_CFG_REQ_L2_CQE_MODE_MIXED 0x2UL
6546 #define VNIC_CFG_REQ_L2_CQE_MODE_LAST VNIC_CFG_REQ_L2_CQE_MODE_MIXED
6550 /* hwrm_vnic_cfg_output (size:128b/16B) */
6551 struct hwrm_vnic_cfg_output {
6560 /* hwrm_vnic_qcaps_input (size:192b/24B) */
6561 struct hwrm_vnic_qcaps_input {
6571 /* hwrm_vnic_qcaps_output (size:192b/24B) */
6572 struct hwrm_vnic_qcaps_output {
6580 #define VNIC_QCAPS_RESP_FLAGS_UNUSED 0x1UL
6581 #define VNIC_QCAPS_RESP_FLAGS_VLAN_STRIP_CAP 0x2UL
6582 #define VNIC_QCAPS_RESP_FLAGS_BD_STALL_CAP 0x4UL
6583 #define VNIC_QCAPS_RESP_FLAGS_ROCE_DUAL_VNIC_CAP 0x8UL
6584 #define VNIC_QCAPS_RESP_FLAGS_ROCE_ONLY_VNIC_CAP 0x10UL
6585 #define VNIC_QCAPS_RESP_FLAGS_RSS_DFLT_CR_CAP 0x20UL
6586 #define VNIC_QCAPS_RESP_FLAGS_ROCE_MIRRORING_CAPABLE_VNIC_CAP 0x40UL
6587 #define VNIC_QCAPS_RESP_FLAGS_OUTERMOST_RSS_CAP 0x80UL
6588 #define VNIC_QCAPS_RESP_FLAGS_COS_ASSIGNMENT_CAP 0x100UL
6589 #define VNIC_QCAPS_RESP_FLAGS_RX_CMPL_V2_CAP 0x200UL
6590 #define VNIC_QCAPS_RESP_FLAGS_VNIC_STATE_CAP 0x400UL
6591 #define VNIC_QCAPS_RESP_FLAGS_VIRTIO_NET_VNIC_ALLOC_CAP 0x800UL
6592 #define VNIC_QCAPS_RESP_FLAGS_METADATA_FORMAT_CAP 0x1000UL
6593 #define VNIC_QCAPS_RESP_FLAGS_RSS_STRICT_HASH_TYPE_CAP 0x2000UL
6594 #define VNIC_QCAPS_RESP_FLAGS_RSS_HASH_TYPE_DELTA_CAP 0x4000UL
6595 #define VNIC_QCAPS_RESP_FLAGS_RING_SELECT_MODE_TOEPLITZ_CAP 0x8000UL
6596 #define VNIC_QCAPS_RESP_FLAGS_RING_SELECT_MODE_XOR_CAP 0x10000UL
6597 #define VNIC_QCAPS_RESP_FLAGS_RING_SELECT_MODE_TOEPLITZ_CHKSM_CAP 0x20000UL
6598 #define VNIC_QCAPS_RESP_FLAGS_RSS_IPV6_FLOW_LABEL_CAP 0x40000UL
6599 #define VNIC_QCAPS_RESP_FLAGS_RX_CMPL_V3_CAP 0x80000UL
6600 #define VNIC_QCAPS_RESP_FLAGS_L2_CQE_MODE_CAP 0x100000UL
6601 #define VNIC_QCAPS_RESP_FLAGS_RSS_IPSEC_AH_SPI_IPV4_CAP 0x200000UL
6602 #define VNIC_QCAPS_RESP_FLAGS_RSS_IPSEC_ESP_SPI_IPV4_CAP 0x400000UL
6603 #define VNIC_QCAPS_RESP_FLAGS_RSS_IPSEC_AH_SPI_IPV6_CAP 0x800000UL
6604 #define VNIC_QCAPS_RESP_FLAGS_RSS_IPSEC_ESP_SPI_IPV6_CAP 0x1000000UL
6605 #define VNIC_QCAPS_RESP_FLAGS_OUTERMOST_RSS_TRUSTED_VF_CAP 0x2000000UL
6606 __le16 max_aggs_supported;
6611 /* hwrm_vnic_tpa_cfg_input (size:320b/40B) */
6612 struct hwrm_vnic_tpa_cfg_input {
6619 #define VNIC_TPA_CFG_REQ_FLAGS_TPA 0x1UL
6620 #define VNIC_TPA_CFG_REQ_FLAGS_ENCAP_TPA 0x2UL
6621 #define VNIC_TPA_CFG_REQ_FLAGS_RSC_WND_UPDATE 0x4UL
6622 #define VNIC_TPA_CFG_REQ_FLAGS_GRO 0x8UL
6623 #define VNIC_TPA_CFG_REQ_FLAGS_AGG_WITH_ECN 0x10UL
6624 #define VNIC_TPA_CFG_REQ_FLAGS_AGG_WITH_SAME_GRE_SEQ 0x20UL
6625 #define VNIC_TPA_CFG_REQ_FLAGS_GRO_IPID_CHECK 0x40UL
6626 #define VNIC_TPA_CFG_REQ_FLAGS_GRO_TTL_CHECK 0x80UL
6627 #define VNIC_TPA_CFG_REQ_FLAGS_AGG_PACK_AS_GRO 0x100UL
6629 #define VNIC_TPA_CFG_REQ_ENABLES_MAX_AGG_SEGS 0x1UL
6630 #define VNIC_TPA_CFG_REQ_ENABLES_MAX_AGGS 0x2UL
6631 #define VNIC_TPA_CFG_REQ_ENABLES_MAX_AGG_TIMER 0x4UL
6632 #define VNIC_TPA_CFG_REQ_ENABLES_MIN_AGG_LEN 0x8UL
6634 __le16 max_agg_segs;
6635 #define VNIC_TPA_CFG_REQ_MAX_AGG_SEGS_1 0x0UL
6636 #define VNIC_TPA_CFG_REQ_MAX_AGG_SEGS_2 0x1UL
6637 #define VNIC_TPA_CFG_REQ_MAX_AGG_SEGS_4 0x2UL
6638 #define VNIC_TPA_CFG_REQ_MAX_AGG_SEGS_8 0x3UL
6639 #define VNIC_TPA_CFG_REQ_MAX_AGG_SEGS_MAX 0x1fUL
6640 #define VNIC_TPA_CFG_REQ_MAX_AGG_SEGS_LAST VNIC_TPA_CFG_REQ_MAX_AGG_SEGS_MAX
6642 #define VNIC_TPA_CFG_REQ_MAX_AGGS_1 0x0UL
6643 #define VNIC_TPA_CFG_REQ_MAX_AGGS_2 0x1UL
6644 #define VNIC_TPA_CFG_REQ_MAX_AGGS_4 0x2UL
6645 #define VNIC_TPA_CFG_REQ_MAX_AGGS_8 0x3UL
6646 #define VNIC_TPA_CFG_REQ_MAX_AGGS_16 0x4UL
6647 #define VNIC_TPA_CFG_REQ_MAX_AGGS_MAX 0x7UL
6648 #define VNIC_TPA_CFG_REQ_MAX_AGGS_LAST VNIC_TPA_CFG_REQ_MAX_AGGS_MAX
6650 __le32 max_agg_timer;
6654 /* hwrm_vnic_tpa_cfg_output (size:128b/16B) */
6655 struct hwrm_vnic_tpa_cfg_output {
6664 /* hwrm_vnic_tpa_qcfg_input (size:192b/24B) */
6665 struct hwrm_vnic_tpa_qcfg_input {
6675 /* hwrm_vnic_tpa_qcfg_output (size:256b/32B) */
6676 struct hwrm_vnic_tpa_qcfg_output {
6682 #define VNIC_TPA_QCFG_RESP_FLAGS_TPA 0x1UL
6683 #define VNIC_TPA_QCFG_RESP_FLAGS_ENCAP_TPA 0x2UL
6684 #define VNIC_TPA_QCFG_RESP_FLAGS_RSC_WND_UPDATE 0x4UL
6685 #define VNIC_TPA_QCFG_RESP_FLAGS_GRO 0x8UL
6686 #define VNIC_TPA_QCFG_RESP_FLAGS_AGG_WITH_ECN 0x10UL
6687 #define VNIC_TPA_QCFG_RESP_FLAGS_AGG_WITH_SAME_GRE_SEQ 0x20UL
6688 #define VNIC_TPA_QCFG_RESP_FLAGS_GRO_IPID_CHECK 0x40UL
6689 #define VNIC_TPA_QCFG_RESP_FLAGS_GRO_TTL_CHECK 0x80UL
6690 __le16 max_agg_segs;
6691 #define VNIC_TPA_QCFG_RESP_MAX_AGG_SEGS_1 0x0UL
6692 #define VNIC_TPA_QCFG_RESP_MAX_AGG_SEGS_2 0x1UL
6693 #define VNIC_TPA_QCFG_RESP_MAX_AGG_SEGS_4 0x2UL
6694 #define VNIC_TPA_QCFG_RESP_MAX_AGG_SEGS_8 0x3UL
6695 #define VNIC_TPA_QCFG_RESP_MAX_AGG_SEGS_MAX 0x1fUL
6696 #define VNIC_TPA_QCFG_RESP_MAX_AGG_SEGS_LAST VNIC_TPA_QCFG_RESP_MAX_AGG_SEGS_MAX
6698 #define VNIC_TPA_QCFG_RESP_MAX_AGGS_1 0x0UL
6699 #define VNIC_TPA_QCFG_RESP_MAX_AGGS_2 0x1UL
6700 #define VNIC_TPA_QCFG_RESP_MAX_AGGS_4 0x2UL
6701 #define VNIC_TPA_QCFG_RESP_MAX_AGGS_8 0x3UL
6702 #define VNIC_TPA_QCFG_RESP_MAX_AGGS_16 0x4UL
6703 #define VNIC_TPA_QCFG_RESP_MAX_AGGS_MAX 0x7UL
6704 #define VNIC_TPA_QCFG_RESP_MAX_AGGS_LAST VNIC_TPA_QCFG_RESP_MAX_AGGS_MAX
6705 __le32 max_agg_timer;
6711 /* hwrm_vnic_rss_cfg_input (size:384b/48B) */
6712 struct hwrm_vnic_rss_cfg_input {
6719 #define VNIC_RSS_CFG_REQ_HASH_TYPE_IPV4 0x1UL
6720 #define VNIC_RSS_CFG_REQ_HASH_TYPE_TCP_IPV4 0x2UL
6721 #define VNIC_RSS_CFG_REQ_HASH_TYPE_UDP_IPV4 0x4UL
6722 #define VNIC_RSS_CFG_REQ_HASH_TYPE_IPV6 0x8UL
6723 #define VNIC_RSS_CFG_REQ_HASH_TYPE_TCP_IPV6 0x10UL
6724 #define VNIC_RSS_CFG_REQ_HASH_TYPE_UDP_IPV6 0x20UL
6725 #define VNIC_RSS_CFG_REQ_HASH_TYPE_IPV6_FLOW_LABEL 0x40UL
6726 #define VNIC_RSS_CFG_REQ_HASH_TYPE_AH_SPI_IPV4 0x80UL
6727 #define VNIC_RSS_CFG_REQ_HASH_TYPE_ESP_SPI_IPV4 0x100UL
6728 #define VNIC_RSS_CFG_REQ_HASH_TYPE_AH_SPI_IPV6 0x200UL
6729 #define VNIC_RSS_CFG_REQ_HASH_TYPE_ESP_SPI_IPV6 0x400UL
6731 u8 ring_table_pair_index;
6733 #define VNIC_RSS_CFG_REQ_HASH_MODE_FLAGS_DEFAULT 0x1UL
6734 #define VNIC_RSS_CFG_REQ_HASH_MODE_FLAGS_INNERMOST_4 0x2UL
6735 #define VNIC_RSS_CFG_REQ_HASH_MODE_FLAGS_INNERMOST_2 0x4UL
6736 #define VNIC_RSS_CFG_REQ_HASH_MODE_FLAGS_OUTERMOST_4 0x8UL
6737 #define VNIC_RSS_CFG_REQ_HASH_MODE_FLAGS_OUTERMOST_2 0x10UL
6738 __le64 ring_grp_tbl_addr;
6739 __le64 hash_key_tbl_addr;
6742 #define VNIC_RSS_CFG_REQ_FLAGS_HASH_TYPE_INCLUDE 0x1UL
6743 #define VNIC_RSS_CFG_REQ_FLAGS_HASH_TYPE_EXCLUDE 0x2UL
6744 u8 ring_select_mode;
6745 #define VNIC_RSS_CFG_REQ_RING_SELECT_MODE_TOEPLITZ 0x0UL
6746 #define VNIC_RSS_CFG_REQ_RING_SELECT_MODE_XOR 0x1UL
6747 #define VNIC_RSS_CFG_REQ_RING_SELECT_MODE_TOEPLITZ_CHECKSUM 0x2UL
6748 #define VNIC_RSS_CFG_REQ_RING_SELECT_MODE_LAST VNIC_RSS_CFG_REQ_RING_SELECT_MODE_TOEPLITZ_CHECKSUM
6752 /* hwrm_vnic_rss_cfg_output (size:128b/16B) */
6753 struct hwrm_vnic_rss_cfg_output {
6762 /* hwrm_vnic_rss_cfg_cmd_err (size:64b/8B) */
6763 struct hwrm_vnic_rss_cfg_cmd_err {
6765 #define VNIC_RSS_CFG_CMD_ERR_CODE_UNKNOWN 0x0UL
6766 #define VNIC_RSS_CFG_CMD_ERR_CODE_INTERFACE_NOT_READY 0x1UL
6767 #define VNIC_RSS_CFG_CMD_ERR_CODE_LAST VNIC_RSS_CFG_CMD_ERR_CODE_INTERFACE_NOT_READY
6771 /* hwrm_vnic_rss_qcfg_input (size:192b/24B) */
6772 struct hwrm_vnic_rss_qcfg_input {
6783 /* hwrm_vnic_rss_qcfg_output (size:512b/64B) */
6784 struct hwrm_vnic_rss_qcfg_output {
6790 #define VNIC_RSS_QCFG_RESP_HASH_TYPE_IPV4 0x1UL
6791 #define VNIC_RSS_QCFG_RESP_HASH_TYPE_TCP_IPV4 0x2UL
6792 #define VNIC_RSS_QCFG_RESP_HASH_TYPE_UDP_IPV4 0x4UL
6793 #define VNIC_RSS_QCFG_RESP_HASH_TYPE_IPV6 0x8UL
6794 #define VNIC_RSS_QCFG_RESP_HASH_TYPE_TCP_IPV6 0x10UL
6795 #define VNIC_RSS_QCFG_RESP_HASH_TYPE_UDP_IPV6 0x20UL
6796 #define VNIC_RSS_QCFG_RESP_HASH_TYPE_IPV6_FLOW_LABEL 0x40UL
6797 #define VNIC_RSS_QCFG_RESP_HASH_TYPE_AH_SPI_IPV4 0x80UL
6798 #define VNIC_RSS_QCFG_RESP_HASH_TYPE_ESP_SPI_IPV4 0x100UL
6799 #define VNIC_RSS_QCFG_RESP_HASH_TYPE_AH_SPI_IPV6 0x200UL
6800 #define VNIC_RSS_QCFG_RESP_HASH_TYPE_ESP_SPI_IPV6 0x400UL
6802 __le32 hash_key[10];
6804 #define VNIC_RSS_QCFG_RESP_HASH_MODE_FLAGS_DEFAULT 0x1UL
6805 #define VNIC_RSS_QCFG_RESP_HASH_MODE_FLAGS_INNERMOST_4 0x2UL
6806 #define VNIC_RSS_QCFG_RESP_HASH_MODE_FLAGS_INNERMOST_2 0x4UL
6807 #define VNIC_RSS_QCFG_RESP_HASH_MODE_FLAGS_OUTERMOST_4 0x8UL
6808 #define VNIC_RSS_QCFG_RESP_HASH_MODE_FLAGS_OUTERMOST_2 0x10UL
6809 u8 ring_select_mode;
6810 #define VNIC_RSS_QCFG_RESP_RING_SELECT_MODE_TOEPLITZ 0x0UL
6811 #define VNIC_RSS_QCFG_RESP_RING_SELECT_MODE_XOR 0x1UL
6812 #define VNIC_RSS_QCFG_RESP_RING_SELECT_MODE_TOEPLITZ_CHECKSUM 0x2UL
6813 #define VNIC_RSS_QCFG_RESP_RING_SELECT_MODE_LAST VNIC_RSS_QCFG_RESP_RING_SELECT_MODE_TOEPLITZ_CHECKSUM
6818 /* hwrm_vnic_plcmodes_cfg_input (size:320b/40B) */
6819 struct hwrm_vnic_plcmodes_cfg_input {
6826 #define VNIC_PLCMODES_CFG_REQ_FLAGS_REGULAR_PLACEMENT 0x1UL
6827 #define VNIC_PLCMODES_CFG_REQ_FLAGS_JUMBO_PLACEMENT 0x2UL
6828 #define VNIC_PLCMODES_CFG_REQ_FLAGS_HDS_IPV4 0x4UL
6829 #define VNIC_PLCMODES_CFG_REQ_FLAGS_HDS_IPV6 0x8UL
6830 #define VNIC_PLCMODES_CFG_REQ_FLAGS_HDS_FCOE 0x10UL
6831 #define VNIC_PLCMODES_CFG_REQ_FLAGS_HDS_ROCE 0x20UL
6832 #define VNIC_PLCMODES_CFG_REQ_FLAGS_VIRTIO_PLACEMENT 0x40UL
6834 #define VNIC_PLCMODES_CFG_REQ_ENABLES_JUMBO_THRESH_VALID 0x1UL
6835 #define VNIC_PLCMODES_CFG_REQ_ENABLES_HDS_OFFSET_VALID 0x2UL
6836 #define VNIC_PLCMODES_CFG_REQ_ENABLES_HDS_THRESHOLD_VALID 0x4UL
6837 #define VNIC_PLCMODES_CFG_REQ_ENABLES_MAX_BDS_VALID 0x8UL
6839 __le16 jumbo_thresh;
6841 __le16 hds_threshold;
6846 /* hwrm_vnic_plcmodes_cfg_output (size:128b/16B) */
6847 struct hwrm_vnic_plcmodes_cfg_output {
6856 /* hwrm_vnic_rss_cos_lb_ctx_alloc_input (size:128b/16B) */
6857 struct hwrm_vnic_rss_cos_lb_ctx_alloc_input {
6865 /* hwrm_vnic_rss_cos_lb_ctx_alloc_output (size:128b/16B) */
6866 struct hwrm_vnic_rss_cos_lb_ctx_alloc_output {
6871 __le16 rss_cos_lb_ctx_id;
6876 /* hwrm_vnic_rss_cos_lb_ctx_free_input (size:192b/24B) */
6877 struct hwrm_vnic_rss_cos_lb_ctx_free_input {
6883 __le16 rss_cos_lb_ctx_id;
6887 /* hwrm_vnic_rss_cos_lb_ctx_free_output (size:128b/16B) */
6888 struct hwrm_vnic_rss_cos_lb_ctx_free_output {
6897 /* hwrm_ring_alloc_input (size:704b/88B) */
6898 struct hwrm_ring_alloc_input {
6905 #define RING_ALLOC_REQ_ENABLES_RING_ARB_CFG 0x2UL
6906 #define RING_ALLOC_REQ_ENABLES_STAT_CTX_ID_VALID 0x8UL
6907 #define RING_ALLOC_REQ_ENABLES_MAX_BW_VALID 0x20UL
6908 #define RING_ALLOC_REQ_ENABLES_RX_RING_ID_VALID 0x40UL
6909 #define RING_ALLOC_REQ_ENABLES_NQ_RING_ID_VALID 0x80UL
6910 #define RING_ALLOC_REQ_ENABLES_RX_BUF_SIZE_VALID 0x100UL
6911 #define RING_ALLOC_REQ_ENABLES_SCHQ_ID 0x200UL
6912 #define RING_ALLOC_REQ_ENABLES_MPC_CHNLS_TYPE 0x400UL
6914 #define RING_ALLOC_REQ_RING_TYPE_L2_CMPL 0x0UL
6915 #define RING_ALLOC_REQ_RING_TYPE_TX 0x1UL
6916 #define RING_ALLOC_REQ_RING_TYPE_RX 0x2UL
6917 #define RING_ALLOC_REQ_RING_TYPE_ROCE_CMPL 0x3UL
6918 #define RING_ALLOC_REQ_RING_TYPE_RX_AGG 0x4UL
6919 #define RING_ALLOC_REQ_RING_TYPE_NQ 0x5UL
6920 #define RING_ALLOC_REQ_RING_TYPE_LAST RING_ALLOC_REQ_RING_TYPE_NQ
6922 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_OFF 0x0UL
6923 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_4 0x1UL
6924 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_8 0x2UL
6925 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_12 0x3UL
6926 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_16 0x4UL
6927 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_24 0x5UL
6928 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_32 0x6UL
6929 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_48 0x7UL
6930 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_64 0x8UL
6931 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_96 0x9UL
6932 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_128 0xaUL
6933 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_192 0xbUL
6934 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_256 0xcUL
6935 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_320 0xdUL
6936 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_384 0xeUL
6937 #define RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_MAX 0xfUL
6938 #define RING_ALLOC_REQ_CMPL_COAL_CNT_LAST RING_ALLOC_REQ_CMPL_COAL_CNT_COAL_MAX
6940 #define RING_ALLOC_REQ_FLAGS_RX_SOP_PAD 0x1UL
6941 #define RING_ALLOC_REQ_FLAGS_DISABLE_CQ_OVERFLOW_DETECTION 0x2UL
6942 #define RING_ALLOC_REQ_FLAGS_NQ_DBR_PACING 0x4UL
6943 #define RING_ALLOC_REQ_FLAGS_TX_PKT_TS_CMPL_ENABLE 0x8UL
6944 __le64 page_tbl_addr;
6951 __le16 cmpl_ring_id;
6956 __le16 ring_arb_cfg;
6957 #define RING_ALLOC_REQ_RING_ARB_CFG_ARB_POLICY_MASK 0xfUL
6958 #define RING_ALLOC_REQ_RING_ARB_CFG_ARB_POLICY_SFT 0
6959 #define RING_ALLOC_REQ_RING_ARB_CFG_ARB_POLICY_SP 0x1UL
6960 #define RING_ALLOC_REQ_RING_ARB_CFG_ARB_POLICY_WFQ 0x2UL
6961 #define RING_ALLOC_REQ_RING_ARB_CFG_ARB_POLICY_LAST RING_ALLOC_REQ_RING_ARB_CFG_ARB_POLICY_WFQ
6962 #define RING_ALLOC_REQ_RING_ARB_CFG_RSVD_MASK 0xf0UL
6963 #define RING_ALLOC_REQ_RING_ARB_CFG_RSVD_SFT 4
6964 #define RING_ALLOC_REQ_RING_ARB_CFG_ARB_POLICY_PARAM_MASK 0xff00UL
6965 #define RING_ALLOC_REQ_RING_ARB_CFG_ARB_POLICY_PARAM_SFT 8
6971 #define RING_ALLOC_REQ_MAX_BW_BW_VALUE_MASK 0xfffffffUL
6972 #define RING_ALLOC_REQ_MAX_BW_BW_VALUE_SFT 0
6973 #define RING_ALLOC_REQ_MAX_BW_SCALE 0x10000000UL
6974 #define RING_ALLOC_REQ_MAX_BW_SCALE_BITS (0x0UL << 28)
6975 #define RING_ALLOC_REQ_MAX_BW_SCALE_BYTES (0x1UL << 28)
6976 #define RING_ALLOC_REQ_MAX_BW_SCALE_LAST RING_ALLOC_REQ_MAX_BW_SCALE_BYTES
6977 #define RING_ALLOC_REQ_MAX_BW_BW_VALUE_UNIT_MASK 0xe0000000UL
6978 #define RING_ALLOC_REQ_MAX_BW_BW_VALUE_UNIT_SFT 29
6979 #define RING_ALLOC_REQ_MAX_BW_BW_VALUE_UNIT_MEGA (0x0UL << 29)
6980 #define RING_ALLOC_REQ_MAX_BW_BW_VALUE_UNIT_KILO (0x2UL << 29)
6981 #define RING_ALLOC_REQ_MAX_BW_BW_VALUE_UNIT_BASE (0x4UL << 29)
6982 #define RING_ALLOC_REQ_MAX_BW_BW_VALUE_UNIT_GIGA (0x6UL << 29)
6983 #define RING_ALLOC_REQ_MAX_BW_BW_VALUE_UNIT_PERCENT1_100 (0x1UL << 29)
6984 #define RING_ALLOC_REQ_MAX_BW_BW_VALUE_UNIT_INVALID (0x7UL << 29)
6985 #define RING_ALLOC_REQ_MAX_BW_BW_VALUE_UNIT_LAST RING_ALLOC_REQ_MAX_BW_BW_VALUE_UNIT_INVALID
6987 #define RING_ALLOC_REQ_INT_MODE_LEGACY 0x0UL
6988 #define RING_ALLOC_REQ_INT_MODE_RSVD 0x1UL
6989 #define RING_ALLOC_REQ_INT_MODE_MSIX 0x2UL
6990 #define RING_ALLOC_REQ_INT_MODE_POLL 0x3UL
6991 #define RING_ALLOC_REQ_INT_MODE_LAST RING_ALLOC_REQ_INT_MODE_POLL
6993 #define RING_ALLOC_REQ_MPC_CHNLS_TYPE_TCE 0x0UL
6994 #define RING_ALLOC_REQ_MPC_CHNLS_TYPE_RCE 0x1UL
6995 #define RING_ALLOC_REQ_MPC_CHNLS_TYPE_TE_CFA 0x2UL
6996 #define RING_ALLOC_REQ_MPC_CHNLS_TYPE_RE_CFA 0x3UL
6997 #define RING_ALLOC_REQ_MPC_CHNLS_TYPE_PRIMATE 0x4UL
6998 #define RING_ALLOC_REQ_MPC_CHNLS_TYPE_LAST RING_ALLOC_REQ_MPC_CHNLS_TYPE_PRIMATE
7003 /* hwrm_ring_alloc_output (size:128b/16B) */
7004 struct hwrm_ring_alloc_output {
7010 __le16 logical_ring_id;
7011 u8 push_buffer_index;
7012 #define RING_ALLOC_RESP_PUSH_BUFFER_INDEX_PING_BUFFER 0x0UL
7013 #define RING_ALLOC_RESP_PUSH_BUFFER_INDEX_PONG_BUFFER 0x1UL
7014 #define RING_ALLOC_RESP_PUSH_BUFFER_INDEX_LAST RING_ALLOC_RESP_PUSH_BUFFER_INDEX_PONG_BUFFER
7019 /* hwrm_ring_free_input (size:256b/32B) */
7020 struct hwrm_ring_free_input {
7027 #define RING_FREE_REQ_RING_TYPE_L2_CMPL 0x0UL
7028 #define RING_FREE_REQ_RING_TYPE_TX 0x1UL
7029 #define RING_FREE_REQ_RING_TYPE_RX 0x2UL
7030 #define RING_FREE_REQ_RING_TYPE_ROCE_CMPL 0x3UL
7031 #define RING_FREE_REQ_RING_TYPE_RX_AGG 0x4UL
7032 #define RING_FREE_REQ_RING_TYPE_NQ 0x5UL
7033 #define RING_FREE_REQ_RING_TYPE_LAST RING_FREE_REQ_RING_TYPE_NQ
7035 #define RING_FREE_REQ_FLAGS_VIRTIO_RING_VALID 0x1UL
7036 #define RING_FREE_REQ_FLAGS_LAST RING_FREE_REQ_FLAGS_VIRTIO_RING_VALID
7043 /* hwrm_ring_free_output (size:128b/16B) */
7044 struct hwrm_ring_free_output {
7053 /* hwrm_ring_reset_input (size:192b/24B) */
7054 struct hwrm_ring_reset_input {
7061 #define RING_RESET_REQ_RING_TYPE_L2_CMPL 0x0UL
7062 #define RING_RESET_REQ_RING_TYPE_TX 0x1UL
7063 #define RING_RESET_REQ_RING_TYPE_RX 0x2UL
7064 #define RING_RESET_REQ_RING_TYPE_ROCE_CMPL 0x3UL
7065 #define RING_RESET_REQ_RING_TYPE_RX_RING_GRP 0x6UL
7066 #define RING_RESET_REQ_RING_TYPE_LAST RING_RESET_REQ_RING_TYPE_RX_RING_GRP
7072 /* hwrm_ring_reset_output (size:128b/16B) */
7073 struct hwrm_ring_reset_output {
7078 u8 push_buffer_index;
7079 #define RING_RESET_RESP_PUSH_BUFFER_INDEX_PING_BUFFER 0x0UL
7080 #define RING_RESET_RESP_PUSH_BUFFER_INDEX_PONG_BUFFER 0x1UL
7081 #define RING_RESET_RESP_PUSH_BUFFER_INDEX_LAST RING_RESET_RESP_PUSH_BUFFER_INDEX_PONG_BUFFER
7087 /* hwrm_ring_aggint_qcaps_input (size:128b/16B) */
7088 struct hwrm_ring_aggint_qcaps_input {
7096 /* hwrm_ring_aggint_qcaps_output (size:384b/48B) */
7097 struct hwrm_ring_aggint_qcaps_output {
7103 #define RING_AGGINT_QCAPS_RESP_CMPL_PARAMS_INT_LAT_TMR_MIN 0x1UL
7104 #define RING_AGGINT_QCAPS_RESP_CMPL_PARAMS_INT_LAT_TMR_MAX 0x2UL
7105 #define RING_AGGINT_QCAPS_RESP_CMPL_PARAMS_TIMER_RESET 0x4UL
7106 #define RING_AGGINT_QCAPS_RESP_CMPL_PARAMS_RING_IDLE 0x8UL
7107 #define RING_AGGINT_QCAPS_RESP_CMPL_PARAMS_NUM_CMPL_DMA_AGGR 0x10UL
7108 #define RING_AGGINT_QCAPS_RESP_CMPL_PARAMS_NUM_CMPL_DMA_AGGR_DURING_INT 0x20UL
7109 #define RING_AGGINT_QCAPS_RESP_CMPL_PARAMS_CMPL_AGGR_DMA_TMR 0x40UL
7110 #define RING_AGGINT_QCAPS_RESP_CMPL_PARAMS_CMPL_AGGR_DMA_TMR_DURING_INT 0x80UL
7111 #define RING_AGGINT_QCAPS_RESP_CMPL_PARAMS_NUM_CMPL_AGGR_INT 0x100UL
7113 #define RING_AGGINT_QCAPS_RESP_NQ_PARAMS_INT_LAT_TMR_MIN 0x1UL
7114 __le16 num_cmpl_dma_aggr_min;
7115 __le16 num_cmpl_dma_aggr_max;
7116 __le16 num_cmpl_dma_aggr_during_int_min;
7117 __le16 num_cmpl_dma_aggr_during_int_max;
7118 __le16 cmpl_aggr_dma_tmr_min;
7119 __le16 cmpl_aggr_dma_tmr_max;
7120 __le16 cmpl_aggr_dma_tmr_during_int_min;
7121 __le16 cmpl_aggr_dma_tmr_during_int_max;
7122 __le16 int_lat_tmr_min_min;
7123 __le16 int_lat_tmr_min_max;
7124 __le16 int_lat_tmr_max_min;
7125 __le16 int_lat_tmr_max_max;
7126 __le16 num_cmpl_aggr_int_min;
7127 __le16 num_cmpl_aggr_int_max;
7133 /* hwrm_ring_cmpl_ring_qaggint_params_input (size:192b/24B) */
7134 struct hwrm_ring_cmpl_ring_qaggint_params_input {
7142 #define RING_CMPL_RING_QAGGINT_PARAMS_REQ_FLAGS_UNUSED_0_MASK 0x3UL
7143 #define RING_CMPL_RING_QAGGINT_PARAMS_REQ_FLAGS_UNUSED_0_SFT 0
7144 #define RING_CMPL_RING_QAGGINT_PARAMS_REQ_FLAGS_IS_NQ 0x4UL
7148 /* hwrm_ring_cmpl_ring_qaggint_params_output (size:256b/32B) */
7149 struct hwrm_ring_cmpl_ring_qaggint_params_output {
7155 #define RING_CMPL_RING_QAGGINT_PARAMS_RESP_FLAGS_TIMER_RESET 0x1UL
7156 #define RING_CMPL_RING_QAGGINT_PARAMS_RESP_FLAGS_RING_IDLE 0x2UL
7157 __le16 num_cmpl_dma_aggr;
7158 __le16 num_cmpl_dma_aggr_during_int;
7159 __le16 cmpl_aggr_dma_tmr;
7160 __le16 cmpl_aggr_dma_tmr_during_int;
7161 __le16 int_lat_tmr_min;
7162 __le16 int_lat_tmr_max;
7163 __le16 num_cmpl_aggr_int;
7168 /* hwrm_ring_cmpl_ring_cfg_aggint_params_input (size:320b/40B) */
7169 struct hwrm_ring_cmpl_ring_cfg_aggint_params_input {
7177 #define RING_CMPL_RING_CFG_AGGINT_PARAMS_REQ_FLAGS_TIMER_RESET 0x1UL
7178 #define RING_CMPL_RING_CFG_AGGINT_PARAMS_REQ_FLAGS_RING_IDLE 0x2UL
7179 #define RING_CMPL_RING_CFG_AGGINT_PARAMS_REQ_FLAGS_IS_NQ 0x4UL
7180 __le16 num_cmpl_dma_aggr;
7181 __le16 num_cmpl_dma_aggr_during_int;
7182 __le16 cmpl_aggr_dma_tmr;
7183 __le16 cmpl_aggr_dma_tmr_during_int;
7184 __le16 int_lat_tmr_min;
7185 __le16 int_lat_tmr_max;
7186 __le16 num_cmpl_aggr_int;
7188 #define RING_CMPL_RING_CFG_AGGINT_PARAMS_REQ_ENABLES_NUM_CMPL_DMA_AGGR 0x1UL
7189 #define RING_CMPL_RING_CFG_AGGINT_PARAMS_REQ_ENABLES_NUM_CMPL_DMA_AGGR_DURING_INT 0x2UL
7190 #define RING_CMPL_RING_CFG_AGGINT_PARAMS_REQ_ENABLES_CMPL_AGGR_DMA_TMR 0x4UL
7191 #define RING_CMPL_RING_CFG_AGGINT_PARAMS_REQ_ENABLES_INT_LAT_TMR_MIN 0x8UL
7192 #define RING_CMPL_RING_CFG_AGGINT_PARAMS_REQ_ENABLES_INT_LAT_TMR_MAX 0x10UL
7193 #define RING_CMPL_RING_CFG_AGGINT_PARAMS_REQ_ENABLES_NUM_CMPL_AGGR_INT 0x20UL
7197 /* hwrm_ring_cmpl_ring_cfg_aggint_params_output (size:128b/16B) */
7198 struct hwrm_ring_cmpl_ring_cfg_aggint_params_output {
7207 /* hwrm_ring_grp_alloc_input (size:192b/24B) */
7208 struct hwrm_ring_grp_alloc_input {
7220 /* hwrm_ring_grp_alloc_output (size:128b/16B) */
7221 struct hwrm_ring_grp_alloc_output {
7226 __le32 ring_group_id;
7231 /* hwrm_ring_grp_free_input (size:192b/24B) */
7232 struct hwrm_ring_grp_free_input {
7238 __le32 ring_group_id;
7242 /* hwrm_ring_grp_free_output (size:128b/16B) */
7243 struct hwrm_ring_grp_free_output {
7252 #define DEFAULT_FLOW_ID 0xFFFFFFFFUL
7253 #define ROCEV1_FLOW_ID 0xFFFFFFFEUL
7254 #define ROCEV2_FLOW_ID 0xFFFFFFFDUL
7255 #define ROCEV2_CNP_FLOW_ID 0xFFFFFFFCUL
7257 /* hwrm_cfa_l2_filter_alloc_input (size:768b/96B) */
7258 struct hwrm_cfa_l2_filter_alloc_input {
7265 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_PATH 0x1UL
7266 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_PATH_TX 0x0UL
7267 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_PATH_RX 0x1UL
7268 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_PATH_LAST CFA_L2_FILTER_ALLOC_REQ_FLAGS_PATH_RX
7269 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_LOOPBACK 0x2UL
7270 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_DROP 0x4UL
7271 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_OUTERMOST 0x8UL
7272 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_TRAFFIC_MASK 0x30UL
7273 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_TRAFFIC_SFT 4
7274 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_TRAFFIC_NO_ROCE_L2 (0x0UL << 4)
7275 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_TRAFFIC_L2 (0x1UL << 4)
7276 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_TRAFFIC_ROCE (0x2UL << 4)
7277 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_TRAFFIC_LAST CFA_L2_FILTER_ALLOC_REQ_FLAGS_TRAFFIC_ROCE
7278 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_XDP_DISABLE 0x40UL
7279 #define CFA_L2_FILTER_ALLOC_REQ_FLAGS_SOURCE_VALID 0x80UL
7281 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_L2_ADDR 0x1UL
7282 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_L2_ADDR_MASK 0x2UL
7283 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_L2_OVLAN 0x4UL
7284 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_L2_OVLAN_MASK 0x8UL
7285 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_L2_IVLAN 0x10UL
7286 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_L2_IVLAN_MASK 0x20UL
7287 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_T_L2_ADDR 0x40UL
7288 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_T_L2_ADDR_MASK 0x80UL
7289 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_T_L2_OVLAN 0x100UL
7290 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_T_L2_OVLAN_MASK 0x200UL
7291 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_T_L2_IVLAN 0x400UL
7292 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_T_L2_IVLAN_MASK 0x800UL
7293 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_SRC_TYPE 0x1000UL
7294 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_SRC_ID 0x2000UL
7295 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_TUNNEL_TYPE 0x4000UL
7296 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_DST_ID 0x8000UL
7297 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_MIRROR_VNIC_ID 0x10000UL
7298 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_NUM_VLANS 0x20000UL
7299 #define CFA_L2_FILTER_ALLOC_REQ_ENABLES_T_NUM_VLANS 0x40000UL
7305 __le16 l2_ovlan_mask;
7307 __le16 l2_ivlan_mask;
7311 u8 t_l2_addr_mask[6];
7313 __le16 t_l2_ovlan_mask;
7315 __le16 t_l2_ivlan_mask;
7317 #define CFA_L2_FILTER_ALLOC_REQ_SRC_TYPE_NPORT 0x0UL
7318 #define CFA_L2_FILTER_ALLOC_REQ_SRC_TYPE_PF 0x1UL
7319 #define CFA_L2_FILTER_ALLOC_REQ_SRC_TYPE_VF 0x2UL
7320 #define CFA_L2_FILTER_ALLOC_REQ_SRC_TYPE_VNIC 0x3UL
7321 #define CFA_L2_FILTER_ALLOC_REQ_SRC_TYPE_KONG 0x4UL
7322 #define CFA_L2_FILTER_ALLOC_REQ_SRC_TYPE_APE 0x5UL
7323 #define CFA_L2_FILTER_ALLOC_REQ_SRC_TYPE_BONO 0x6UL
7324 #define CFA_L2_FILTER_ALLOC_REQ_SRC_TYPE_TANG 0x7UL
7325 #define CFA_L2_FILTER_ALLOC_REQ_SRC_TYPE_LAST CFA_L2_FILTER_ALLOC_REQ_SRC_TYPE_TANG
7329 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_NONTUNNEL 0x0UL
7330 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_VXLAN 0x1UL
7331 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_NVGRE 0x2UL
7332 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_L2GRE 0x3UL
7333 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_IPIP 0x4UL
7334 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_GENEVE 0x5UL
7335 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_MPLS 0x6UL
7336 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_STT 0x7UL
7337 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_IPGRE 0x8UL
7338 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_VXLAN_V4 0x9UL
7339 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_IPGRE_V1 0xaUL
7340 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_L2_ETYPE 0xbUL
7341 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_VXLAN_GPE_V6 0xcUL
7342 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_ANYTUNNEL 0xffUL
7343 #define CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_LAST CFA_L2_FILTER_ALLOC_REQ_TUNNEL_TYPE_ANYTUNNEL
7346 __le16 mirror_vnic_id;
7348 #define CFA_L2_FILTER_ALLOC_REQ_PRI_HINT_NO_PREFER 0x0UL
7349 #define CFA_L2_FILTER_ALLOC_REQ_PRI_HINT_ABOVE_FILTER 0x1UL
7350 #define CFA_L2_FILTER_ALLOC_REQ_PRI_HINT_BELOW_FILTER 0x2UL
7351 #define CFA_L2_FILTER_ALLOC_REQ_PRI_HINT_MAX 0x3UL
7352 #define CFA_L2_FILTER_ALLOC_REQ_PRI_HINT_MIN 0x4UL
7353 #define CFA_L2_FILTER_ALLOC_REQ_PRI_HINT_LAST CFA_L2_FILTER_ALLOC_REQ_PRI_HINT_MIN
7356 __le64 l2_filter_id_hint;
7359 /* hwrm_cfa_l2_filter_alloc_output (size:192b/24B) */
7360 struct hwrm_cfa_l2_filter_alloc_output {
7365 __le64 l2_filter_id;
7367 #define CFA_L2_FILTER_ALLOC_RESP_FLOW_ID_VALUE_MASK 0x3fffffffUL
7368 #define CFA_L2_FILTER_ALLOC_RESP_FLOW_ID_VALUE_SFT 0
7369 #define CFA_L2_FILTER_ALLOC_RESP_FLOW_ID_TYPE 0x40000000UL
7370 #define CFA_L2_FILTER_ALLOC_RESP_FLOW_ID_TYPE_INT (0x0UL << 30)
7371 #define CFA_L2_FILTER_ALLOC_RESP_FLOW_ID_TYPE_EXT (0x1UL << 30)
7372 #define CFA_L2_FILTER_ALLOC_RESP_FLOW_ID_TYPE_LAST CFA_L2_FILTER_ALLOC_RESP_FLOW_ID_TYPE_EXT
7373 #define CFA_L2_FILTER_ALLOC_RESP_FLOW_ID_DIR 0x80000000UL
7374 #define CFA_L2_FILTER_ALLOC_RESP_FLOW_ID_DIR_RX (0x0UL << 31)
7375 #define CFA_L2_FILTER_ALLOC_RESP_FLOW_ID_DIR_TX (0x1UL << 31)
7376 #define CFA_L2_FILTER_ALLOC_RESP_FLOW_ID_DIR_LAST CFA_L2_FILTER_ALLOC_RESP_FLOW_ID_DIR_TX
7381 /* hwrm_cfa_l2_filter_free_input (size:192b/24B) */
7382 struct hwrm_cfa_l2_filter_free_input {
7388 __le64 l2_filter_id;
7391 /* hwrm_cfa_l2_filter_free_output (size:128b/16B) */
7392 struct hwrm_cfa_l2_filter_free_output {
7401 /* hwrm_cfa_l2_filter_cfg_input (size:320b/40B) */
7402 struct hwrm_cfa_l2_filter_cfg_input {
7409 #define CFA_L2_FILTER_CFG_REQ_FLAGS_PATH 0x1UL
7410 #define CFA_L2_FILTER_CFG_REQ_FLAGS_PATH_TX 0x0UL
7411 #define CFA_L2_FILTER_CFG_REQ_FLAGS_PATH_RX 0x1UL
7412 #define CFA_L2_FILTER_CFG_REQ_FLAGS_PATH_LAST CFA_L2_FILTER_CFG_REQ_FLAGS_PATH_RX
7413 #define CFA_L2_FILTER_CFG_REQ_FLAGS_DROP 0x2UL
7414 #define CFA_L2_FILTER_CFG_REQ_FLAGS_TRAFFIC_MASK 0xcUL
7415 #define CFA_L2_FILTER_CFG_REQ_FLAGS_TRAFFIC_SFT 2
7416 #define CFA_L2_FILTER_CFG_REQ_FLAGS_TRAFFIC_NO_ROCE_L2 (0x0UL << 2)
7417 #define CFA_L2_FILTER_CFG_REQ_FLAGS_TRAFFIC_L2 (0x1UL << 2)
7418 #define CFA_L2_FILTER_CFG_REQ_FLAGS_TRAFFIC_ROCE (0x2UL << 2)
7419 #define CFA_L2_FILTER_CFG_REQ_FLAGS_TRAFFIC_LAST CFA_L2_FILTER_CFG_REQ_FLAGS_TRAFFIC_ROCE
7421 #define CFA_L2_FILTER_CFG_REQ_ENABLES_DST_ID 0x1UL
7422 #define CFA_L2_FILTER_CFG_REQ_ENABLES_NEW_MIRROR_VNIC_ID 0x2UL
7423 __le64 l2_filter_id;
7425 __le32 new_mirror_vnic_id;
7428 /* hwrm_cfa_l2_filter_cfg_output (size:128b/16B) */
7429 struct hwrm_cfa_l2_filter_cfg_output {
7438 /* hwrm_cfa_l2_set_rx_mask_input (size:448b/56B) */
7439 struct hwrm_cfa_l2_set_rx_mask_input {
7447 #define CFA_L2_SET_RX_MASK_REQ_MASK_MCAST 0x2UL
7448 #define CFA_L2_SET_RX_MASK_REQ_MASK_ALL_MCAST 0x4UL
7449 #define CFA_L2_SET_RX_MASK_REQ_MASK_BCAST 0x8UL
7450 #define CFA_L2_SET_RX_MASK_REQ_MASK_PROMISCUOUS 0x10UL
7451 #define CFA_L2_SET_RX_MASK_REQ_MASK_OUTERMOST 0x20UL
7452 #define CFA_L2_SET_RX_MASK_REQ_MASK_VLANONLY 0x40UL
7453 #define CFA_L2_SET_RX_MASK_REQ_MASK_VLAN_NONVLAN 0x80UL
7454 #define CFA_L2_SET_RX_MASK_REQ_MASK_ANYVLAN_NONVLAN 0x100UL
7456 __le32 num_mc_entries;
7458 __le64 vlan_tag_tbl_addr;
7459 __le32 num_vlan_tags;
7463 /* hwrm_cfa_l2_set_rx_mask_output (size:128b/16B) */
7464 struct hwrm_cfa_l2_set_rx_mask_output {
7473 /* hwrm_cfa_l2_set_rx_mask_cmd_err (size:64b/8B) */
7474 struct hwrm_cfa_l2_set_rx_mask_cmd_err {
7476 #define CFA_L2_SET_RX_MASK_CMD_ERR_CODE_UNKNOWN 0x0UL
7477 #define CFA_L2_SET_RX_MASK_CMD_ERR_CODE_NTUPLE_FILTER_CONFLICT_ERR 0x1UL
7478 #define CFA_L2_SET_RX_MASK_CMD_ERR_CODE_LAST CFA_L2_SET_RX_MASK_CMD_ERR_CODE_NTUPLE_FILTER_CONFLICT_ERR
7482 /* hwrm_cfa_tunnel_filter_alloc_input (size:704b/88B) */
7483 struct hwrm_cfa_tunnel_filter_alloc_input {
7490 #define CFA_TUNNEL_FILTER_ALLOC_REQ_FLAGS_LOOPBACK 0x1UL
7492 #define CFA_TUNNEL_FILTER_ALLOC_REQ_ENABLES_L2_FILTER_ID 0x1UL
7493 #define CFA_TUNNEL_FILTER_ALLOC_REQ_ENABLES_L2_ADDR 0x2UL
7494 #define CFA_TUNNEL_FILTER_ALLOC_REQ_ENABLES_L2_IVLAN 0x4UL
7495 #define CFA_TUNNEL_FILTER_ALLOC_REQ_ENABLES_L3_ADDR 0x8UL
7496 #define CFA_TUNNEL_FILTER_ALLOC_REQ_ENABLES_L3_ADDR_TYPE 0x10UL
7497 #define CFA_TUNNEL_FILTER_ALLOC_REQ_ENABLES_T_L3_ADDR_TYPE 0x20UL
7498 #define CFA_TUNNEL_FILTER_ALLOC_REQ_ENABLES_T_L3_ADDR 0x40UL
7499 #define CFA_TUNNEL_FILTER_ALLOC_REQ_ENABLES_TUNNEL_TYPE 0x80UL
7500 #define CFA_TUNNEL_FILTER_ALLOC_REQ_ENABLES_VNI 0x100UL
7501 #define CFA_TUNNEL_FILTER_ALLOC_REQ_ENABLES_DST_VNIC_ID 0x200UL
7502 #define CFA_TUNNEL_FILTER_ALLOC_REQ_ENABLES_MIRROR_VNIC_ID 0x400UL
7503 __le64 l2_filter_id;
7507 __le32 t_l3_addr[4];
7511 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_NONTUNNEL 0x0UL
7512 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_VXLAN 0x1UL
7513 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_NVGRE 0x2UL
7514 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_L2GRE 0x3UL
7515 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_IPIP 0x4UL
7516 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_GENEVE 0x5UL
7517 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_MPLS 0x6UL
7518 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_STT 0x7UL
7519 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_IPGRE 0x8UL
7520 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_VXLAN_V4 0x9UL
7521 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_IPGRE_V1 0xaUL
7522 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_L2_ETYPE 0xbUL
7523 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_VXLAN_GPE_V6 0xcUL
7524 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_ANYTUNNEL 0xffUL
7525 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_LAST CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_TYPE_ANYTUNNEL
7527 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_FLAGS_TUN_FLAGS_OAM_CHECKSUM_EXPLHDR 0x1UL
7528 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_FLAGS_TUN_FLAGS_CRITICAL_OPT_S1 0x2UL
7529 #define CFA_TUNNEL_FILTER_ALLOC_REQ_TUNNEL_FLAGS_TUN_FLAGS_EXTHDR_SEQNUM_S0 0x4UL
7532 __le32 mirror_vnic_id;
7535 /* hwrm_cfa_tunnel_filter_alloc_output (size:192b/24B) */
7536 struct hwrm_cfa_tunnel_filter_alloc_output {
7541 __le64 tunnel_filter_id;
7543 #define CFA_TUNNEL_FILTER_ALLOC_RESP_FLOW_ID_VALUE_MASK 0x3fffffffUL
7544 #define CFA_TUNNEL_FILTER_ALLOC_RESP_FLOW_ID_VALUE_SFT 0
7545 #define CFA_TUNNEL_FILTER_ALLOC_RESP_FLOW_ID_TYPE 0x40000000UL
7546 #define CFA_TUNNEL_FILTER_ALLOC_RESP_FLOW_ID_TYPE_INT (0x0UL << 30)
7547 #define CFA_TUNNEL_FILTER_ALLOC_RESP_FLOW_ID_TYPE_EXT (0x1UL << 30)
7548 #define CFA_TUNNEL_FILTER_ALLOC_RESP_FLOW_ID_TYPE_LAST CFA_TUNNEL_FILTER_ALLOC_RESP_FLOW_ID_TYPE_EXT
7549 #define CFA_TUNNEL_FILTER_ALLOC_RESP_FLOW_ID_DIR 0x80000000UL
7550 #define CFA_TUNNEL_FILTER_ALLOC_RESP_FLOW_ID_DIR_RX (0x0UL << 31)
7551 #define CFA_TUNNEL_FILTER_ALLOC_RESP_FLOW_ID_DIR_TX (0x1UL << 31)
7552 #define CFA_TUNNEL_FILTER_ALLOC_RESP_FLOW_ID_DIR_LAST CFA_TUNNEL_FILTER_ALLOC_RESP_FLOW_ID_DIR_TX
7557 /* hwrm_cfa_tunnel_filter_free_input (size:192b/24B) */
7558 struct hwrm_cfa_tunnel_filter_free_input {
7564 __le64 tunnel_filter_id;
7567 /* hwrm_cfa_tunnel_filter_free_output (size:128b/16B) */
7568 struct hwrm_cfa_tunnel_filter_free_output {
7577 /* hwrm_vxlan_ipv4_hdr (size:128b/16B) */
7578 struct hwrm_vxlan_ipv4_hdr {
7580 #define VXLAN_IPV4_HDR_VER_HLEN_HEADER_LENGTH_MASK 0xfUL
7581 #define VXLAN_IPV4_HDR_VER_HLEN_HEADER_LENGTH_SFT 0
7582 #define VXLAN_IPV4_HDR_VER_HLEN_VERSION_MASK 0xf0UL
7583 #define VXLAN_IPV4_HDR_VER_HLEN_VERSION_SFT 4
7586 __be16 flags_frag_offset;
7590 __be32 dest_ip_addr;
7593 /* hwrm_vxlan_ipv6_hdr (size:320b/40B) */
7594 struct hwrm_vxlan_ipv6_hdr {
7595 __be32 ver_tc_flow_label;
7596 #define VXLAN_IPV6_HDR_VER_TC_FLOW_LABEL_VER_SFT 0x1cUL
7597 #define VXLAN_IPV6_HDR_VER_TC_FLOW_LABEL_VER_MASK 0xf0000000UL
7598 #define VXLAN_IPV6_HDR_VER_TC_FLOW_LABEL_TC_SFT 0x14UL
7599 #define VXLAN_IPV6_HDR_VER_TC_FLOW_LABEL_TC_MASK 0xff00000UL
7600 #define VXLAN_IPV6_HDR_VER_TC_FLOW_LABEL_FLOW_LABEL_SFT 0x0UL
7601 #define VXLAN_IPV6_HDR_VER_TC_FLOW_LABEL_FLOW_LABEL_MASK 0xfffffUL
7602 #define VXLAN_IPV6_HDR_VER_TC_FLOW_LABEL_LAST VXLAN_IPV6_HDR_VER_TC_FLOW_LABEL_FLOW_LABEL_MASK
7606 __be32 src_ip_addr[4];
7607 __be32 dest_ip_addr[4];
7610 /* hwrm_cfa_encap_data_vxlan (size:640b/80B) */
7611 struct hwrm_cfa_encap_data_vxlan {
7622 #define CFA_ENCAP_DATA_VXLAN_L3_VER_MASK 0xfUL
7623 #define CFA_ENCAP_DATA_VXLAN_L3_VER_IPV4 0x4UL
7624 #define CFA_ENCAP_DATA_VXLAN_L3_VER_IPV6 0x6UL
7625 #define CFA_ENCAP_DATA_VXLAN_L3_LAST CFA_ENCAP_DATA_VXLAN_L3_VER_IPV6
7635 /* hwrm_cfa_encap_record_alloc_input (size:832b/104B) */
7636 struct hwrm_cfa_encap_record_alloc_input {
7643 #define CFA_ENCAP_RECORD_ALLOC_REQ_FLAGS_LOOPBACK 0x1UL
7644 #define CFA_ENCAP_RECORD_ALLOC_REQ_FLAGS_EXTERNAL 0x2UL
7646 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_VXLAN 0x1UL
7647 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_NVGRE 0x2UL
7648 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_L2GRE 0x3UL
7649 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_IPIP 0x4UL
7650 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_GENEVE 0x5UL
7651 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_MPLS 0x6UL
7652 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_VLAN 0x7UL
7653 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_IPGRE 0x8UL
7654 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_VXLAN_V4 0x9UL
7655 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_IPGRE_V1 0xaUL
7656 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_L2_ETYPE 0xbUL
7657 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_VXLAN_GPE_V6 0xcUL
7658 #define CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_LAST CFA_ENCAP_RECORD_ALLOC_REQ_ENCAP_TYPE_VXLAN_GPE_V6
7660 __le32 encap_data[20];
7663 /* hwrm_cfa_encap_record_alloc_output (size:128b/16B) */
7664 struct hwrm_cfa_encap_record_alloc_output {
7669 __le32 encap_record_id;
7674 /* hwrm_cfa_encap_record_free_input (size:192b/24B) */
7675 struct hwrm_cfa_encap_record_free_input {
7681 __le32 encap_record_id;
7685 /* hwrm_cfa_encap_record_free_output (size:128b/16B) */
7686 struct hwrm_cfa_encap_record_free_output {
7695 /* hwrm_cfa_ntuple_filter_alloc_input (size:1024b/128B) */
7696 struct hwrm_cfa_ntuple_filter_alloc_input {
7703 #define CFA_NTUPLE_FILTER_ALLOC_REQ_FLAGS_LOOPBACK 0x1UL
7704 #define CFA_NTUPLE_FILTER_ALLOC_REQ_FLAGS_DROP 0x2UL
7705 #define CFA_NTUPLE_FILTER_ALLOC_REQ_FLAGS_METER 0x4UL
7706 #define CFA_NTUPLE_FILTER_ALLOC_REQ_FLAGS_DEST_FID 0x8UL
7707 #define CFA_NTUPLE_FILTER_ALLOC_REQ_FLAGS_ARP_REPLY 0x10UL
7708 #define CFA_NTUPLE_FILTER_ALLOC_REQ_FLAGS_DEST_RFS_RING_IDX 0x20UL
7709 #define CFA_NTUPLE_FILTER_ALLOC_REQ_FLAGS_NO_L2_CONTEXT 0x40UL
7711 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_L2_FILTER_ID 0x1UL
7712 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_ETHERTYPE 0x2UL
7713 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_TUNNEL_TYPE 0x4UL
7714 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_SRC_MACADDR 0x8UL
7715 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_IPADDR_TYPE 0x10UL
7716 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_SRC_IPADDR 0x20UL
7717 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_SRC_IPADDR_MASK 0x40UL
7718 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_DST_IPADDR 0x80UL
7719 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_DST_IPADDR_MASK 0x100UL
7720 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_IP_PROTOCOL 0x200UL
7721 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_SRC_PORT 0x400UL
7722 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_SRC_PORT_MASK 0x800UL
7723 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_DST_PORT 0x1000UL
7724 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_DST_PORT_MASK 0x2000UL
7725 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_PRI_HINT 0x4000UL
7726 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_NTUPLE_FILTER_ID 0x8000UL
7727 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_DST_ID 0x10000UL
7728 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_MIRROR_VNIC_ID 0x20000UL
7729 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_DST_MACADDR 0x40000UL
7730 #define CFA_NTUPLE_FILTER_ALLOC_REQ_ENABLES_RFS_RING_TBL_IDX 0x80000UL
7731 __le64 l2_filter_id;
7735 #define CFA_NTUPLE_FILTER_ALLOC_REQ_IP_ADDR_TYPE_UNKNOWN 0x0UL
7736 #define CFA_NTUPLE_FILTER_ALLOC_REQ_IP_ADDR_TYPE_IPV4 0x4UL
7737 #define CFA_NTUPLE_FILTER_ALLOC_REQ_IP_ADDR_TYPE_IPV6 0x6UL
7738 #define CFA_NTUPLE_FILTER_ALLOC_REQ_IP_ADDR_TYPE_LAST CFA_NTUPLE_FILTER_ALLOC_REQ_IP_ADDR_TYPE_IPV6
7740 #define CFA_NTUPLE_FILTER_ALLOC_REQ_IP_PROTOCOL_UNKNOWN 0x0UL
7741 #define CFA_NTUPLE_FILTER_ALLOC_REQ_IP_PROTOCOL_TCP 0x6UL
7742 #define CFA_NTUPLE_FILTER_ALLOC_REQ_IP_PROTOCOL_UDP 0x11UL
7743 #define CFA_NTUPLE_FILTER_ALLOC_REQ_IP_PROTOCOL_ICMP 0x1UL
7744 #define CFA_NTUPLE_FILTER_ALLOC_REQ_IP_PROTOCOL_ICMPV6 0x3aUL
7745 #define CFA_NTUPLE_FILTER_ALLOC_REQ_IP_PROTOCOL_RSVD 0xffUL
7746 #define CFA_NTUPLE_FILTER_ALLOC_REQ_IP_PROTOCOL_LAST CFA_NTUPLE_FILTER_ALLOC_REQ_IP_PROTOCOL_RSVD
7748 __le16 mirror_vnic_id;
7750 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_NONTUNNEL 0x0UL
7751 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_VXLAN 0x1UL
7752 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_NVGRE 0x2UL
7753 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_L2GRE 0x3UL
7754 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_IPIP 0x4UL
7755 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_GENEVE 0x5UL
7756 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_MPLS 0x6UL
7757 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_STT 0x7UL
7758 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_IPGRE 0x8UL
7759 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_VXLAN_V4 0x9UL
7760 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_IPGRE_V1 0xaUL
7761 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_L2_ETYPE 0xbUL
7762 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_VXLAN_GPE_V6 0xcUL
7763 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_ANYTUNNEL 0xffUL
7764 #define CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_LAST CFA_NTUPLE_FILTER_ALLOC_REQ_TUNNEL_TYPE_ANYTUNNEL
7766 #define CFA_NTUPLE_FILTER_ALLOC_REQ_PRI_HINT_NO_PREFER 0x0UL
7767 #define CFA_NTUPLE_FILTER_ALLOC_REQ_PRI_HINT_ABOVE 0x1UL
7768 #define CFA_NTUPLE_FILTER_ALLOC_REQ_PRI_HINT_BELOW 0x2UL
7769 #define CFA_NTUPLE_FILTER_ALLOC_REQ_PRI_HINT_HIGHEST 0x3UL
7770 #define CFA_NTUPLE_FILTER_ALLOC_REQ_PRI_HINT_LOWEST 0x4UL
7771 #define CFA_NTUPLE_FILTER_ALLOC_REQ_PRI_HINT_LAST CFA_NTUPLE_FILTER_ALLOC_REQ_PRI_HINT_LOWEST
7772 __be32 src_ipaddr[4];
7773 __be32 src_ipaddr_mask[4];
7774 __be32 dst_ipaddr[4];
7775 __be32 dst_ipaddr_mask[4];
7777 __be16 src_port_mask;
7779 __be16 dst_port_mask;
7780 __le64 ntuple_filter_id_hint;
7783 /* hwrm_cfa_ntuple_filter_alloc_output (size:192b/24B) */
7784 struct hwrm_cfa_ntuple_filter_alloc_output {
7789 __le64 ntuple_filter_id;
7791 #define CFA_NTUPLE_FILTER_ALLOC_RESP_FLOW_ID_VALUE_MASK 0x3fffffffUL
7792 #define CFA_NTUPLE_FILTER_ALLOC_RESP_FLOW_ID_VALUE_SFT 0
7793 #define CFA_NTUPLE_FILTER_ALLOC_RESP_FLOW_ID_TYPE 0x40000000UL
7794 #define CFA_NTUPLE_FILTER_ALLOC_RESP_FLOW_ID_TYPE_INT (0x0UL << 30)
7795 #define CFA_NTUPLE_FILTER_ALLOC_RESP_FLOW_ID_TYPE_EXT (0x1UL << 30)
7796 #define CFA_NTUPLE_FILTER_ALLOC_RESP_FLOW_ID_TYPE_LAST CFA_NTUPLE_FILTER_ALLOC_RESP_FLOW_ID_TYPE_EXT
7797 #define CFA_NTUPLE_FILTER_ALLOC_RESP_FLOW_ID_DIR 0x80000000UL
7798 #define CFA_NTUPLE_FILTER_ALLOC_RESP_FLOW_ID_DIR_RX (0x0UL << 31)
7799 #define CFA_NTUPLE_FILTER_ALLOC_RESP_FLOW_ID_DIR_TX (0x1UL << 31)
7800 #define CFA_NTUPLE_FILTER_ALLOC_RESP_FLOW_ID_DIR_LAST CFA_NTUPLE_FILTER_ALLOC_RESP_FLOW_ID_DIR_TX
7805 /* hwrm_cfa_ntuple_filter_alloc_cmd_err (size:64b/8B) */
7806 struct hwrm_cfa_ntuple_filter_alloc_cmd_err {
7808 #define CFA_NTUPLE_FILTER_ALLOC_CMD_ERR_CODE_UNKNOWN 0x0UL
7809 #define CFA_NTUPLE_FILTER_ALLOC_CMD_ERR_CODE_RX_MASK_VLAN_CONFLICT_ERR 0x1UL
7810 #define CFA_NTUPLE_FILTER_ALLOC_CMD_ERR_CODE_LAST CFA_NTUPLE_FILTER_ALLOC_CMD_ERR_CODE_RX_MASK_VLAN_CONFLICT_ERR
7814 /* hwrm_cfa_ntuple_filter_free_input (size:192b/24B) */
7815 struct hwrm_cfa_ntuple_filter_free_input {
7821 __le64 ntuple_filter_id;
7824 /* hwrm_cfa_ntuple_filter_free_output (size:128b/16B) */
7825 struct hwrm_cfa_ntuple_filter_free_output {
7834 /* hwrm_cfa_ntuple_filter_cfg_input (size:384b/48B) */
7835 struct hwrm_cfa_ntuple_filter_cfg_input {
7842 #define CFA_NTUPLE_FILTER_CFG_REQ_ENABLES_NEW_DST_ID 0x1UL
7843 #define CFA_NTUPLE_FILTER_CFG_REQ_ENABLES_NEW_MIRROR_VNIC_ID 0x2UL
7844 #define CFA_NTUPLE_FILTER_CFG_REQ_ENABLES_NEW_METER_INSTANCE_ID 0x4UL
7846 #define CFA_NTUPLE_FILTER_CFG_REQ_FLAGS_DEST_FID 0x1UL
7847 #define CFA_NTUPLE_FILTER_CFG_REQ_FLAGS_DEST_RFS_RING_IDX 0x2UL
7848 #define CFA_NTUPLE_FILTER_CFG_REQ_FLAGS_NO_L2_CONTEXT 0x4UL
7849 __le64 ntuple_filter_id;
7851 __le32 new_mirror_vnic_id;
7852 __le16 new_meter_instance_id;
7853 #define CFA_NTUPLE_FILTER_CFG_REQ_NEW_METER_INSTANCE_ID_INVALID 0xffffUL
7854 #define CFA_NTUPLE_FILTER_CFG_REQ_NEW_METER_INSTANCE_ID_LAST CFA_NTUPLE_FILTER_CFG_REQ_NEW_METER_INSTANCE_ID_INVALID
7858 /* hwrm_cfa_ntuple_filter_cfg_output (size:128b/16B) */
7859 struct hwrm_cfa_ntuple_filter_cfg_output {
7868 /* hwrm_cfa_decap_filter_alloc_input (size:832b/104B) */
7869 struct hwrm_cfa_decap_filter_alloc_input {
7876 #define CFA_DECAP_FILTER_ALLOC_REQ_FLAGS_OVS_TUNNEL 0x1UL
7878 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_TUNNEL_TYPE 0x1UL
7879 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_TUNNEL_ID 0x2UL
7880 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_SRC_MACADDR 0x4UL
7881 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_DST_MACADDR 0x8UL
7882 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_OVLAN_VID 0x10UL
7883 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_IVLAN_VID 0x20UL
7884 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_T_OVLAN_VID 0x40UL
7885 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_T_IVLAN_VID 0x80UL
7886 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_ETHERTYPE 0x100UL
7887 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_SRC_IPADDR 0x200UL
7888 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_DST_IPADDR 0x400UL
7889 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_IPADDR_TYPE 0x800UL
7890 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_IP_PROTOCOL 0x1000UL
7891 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_SRC_PORT 0x2000UL
7892 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_DST_PORT 0x4000UL
7893 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_DST_ID 0x8000UL
7894 #define CFA_DECAP_FILTER_ALLOC_REQ_ENABLES_MIRROR_VNIC_ID 0x10000UL
7897 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_NONTUNNEL 0x0UL
7898 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_VXLAN 0x1UL
7899 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_NVGRE 0x2UL
7900 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_L2GRE 0x3UL
7901 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_IPIP 0x4UL
7902 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_GENEVE 0x5UL
7903 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_MPLS 0x6UL
7904 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_STT 0x7UL
7905 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_IPGRE 0x8UL
7906 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_VXLAN_V4 0x9UL
7907 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_IPGRE_V1 0xaUL
7908 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_L2_ETYPE 0xbUL
7909 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_VXLAN_GPE_V6 0xcUL
7910 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_ANYTUNNEL 0xffUL
7911 #define CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_LAST CFA_DECAP_FILTER_ALLOC_REQ_TUNNEL_TYPE_ANYTUNNEL
7923 #define CFA_DECAP_FILTER_ALLOC_REQ_IP_ADDR_TYPE_UNKNOWN 0x0UL
7924 #define CFA_DECAP_FILTER_ALLOC_REQ_IP_ADDR_TYPE_IPV4 0x4UL
7925 #define CFA_DECAP_FILTER_ALLOC_REQ_IP_ADDR_TYPE_IPV6 0x6UL
7926 #define CFA_DECAP_FILTER_ALLOC_REQ_IP_ADDR_TYPE_LAST CFA_DECAP_FILTER_ALLOC_REQ_IP_ADDR_TYPE_IPV6
7928 #define CFA_DECAP_FILTER_ALLOC_REQ_IP_PROTOCOL_UNKNOWN 0x0UL
7929 #define CFA_DECAP_FILTER_ALLOC_REQ_IP_PROTOCOL_TCP 0x6UL
7930 #define CFA_DECAP_FILTER_ALLOC_REQ_IP_PROTOCOL_UDP 0x11UL
7931 #define CFA_DECAP_FILTER_ALLOC_REQ_IP_PROTOCOL_LAST CFA_DECAP_FILTER_ALLOC_REQ_IP_PROTOCOL_UDP
7934 __be32 src_ipaddr[4];
7935 __be32 dst_ipaddr[4];
7939 __le16 l2_ctxt_ref_id;
7942 /* hwrm_cfa_decap_filter_alloc_output (size:128b/16B) */
7943 struct hwrm_cfa_decap_filter_alloc_output {
7948 __le32 decap_filter_id;
7953 /* hwrm_cfa_decap_filter_free_input (size:192b/24B) */
7954 struct hwrm_cfa_decap_filter_free_input {
7960 __le32 decap_filter_id;
7964 /* hwrm_cfa_decap_filter_free_output (size:128b/16B) */
7965 struct hwrm_cfa_decap_filter_free_output {
7974 /* hwrm_cfa_flow_alloc_input (size:1024b/128B) */
7975 struct hwrm_cfa_flow_alloc_input {
7982 #define CFA_FLOW_ALLOC_REQ_FLAGS_TUNNEL 0x1UL
7983 #define CFA_FLOW_ALLOC_REQ_FLAGS_NUM_VLAN_MASK 0x6UL
7984 #define CFA_FLOW_ALLOC_REQ_FLAGS_NUM_VLAN_SFT 1
7985 #define CFA_FLOW_ALLOC_REQ_FLAGS_NUM_VLAN_NONE (0x0UL << 1)
7986 #define CFA_FLOW_ALLOC_REQ_FLAGS_NUM_VLAN_ONE (0x1UL << 1)
7987 #define CFA_FLOW_ALLOC_REQ_FLAGS_NUM_VLAN_TWO (0x2UL << 1)
7988 #define CFA_FLOW_ALLOC_REQ_FLAGS_NUM_VLAN_LAST CFA_FLOW_ALLOC_REQ_FLAGS_NUM_VLAN_TWO
7989 #define CFA_FLOW_ALLOC_REQ_FLAGS_FLOWTYPE_MASK 0x38UL
7990 #define CFA_FLOW_ALLOC_REQ_FLAGS_FLOWTYPE_SFT 3
7991 #define CFA_FLOW_ALLOC_REQ_FLAGS_FLOWTYPE_L2 (0x0UL << 3)
7992 #define CFA_FLOW_ALLOC_REQ_FLAGS_FLOWTYPE_IPV4 (0x1UL << 3)
7993 #define CFA_FLOW_ALLOC_REQ_FLAGS_FLOWTYPE_IPV6 (0x2UL << 3)
7994 #define CFA_FLOW_ALLOC_REQ_FLAGS_FLOWTYPE_LAST CFA_FLOW_ALLOC_REQ_FLAGS_FLOWTYPE_IPV6
7995 #define CFA_FLOW_ALLOC_REQ_FLAGS_PATH_TX 0x40UL
7996 #define CFA_FLOW_ALLOC_REQ_FLAGS_PATH_RX 0x80UL
7997 #define CFA_FLOW_ALLOC_REQ_FLAGS_MATCH_VXLAN_IP_VNI 0x100UL
7998 #define CFA_FLOW_ALLOC_REQ_FLAGS_VHOST_ID_USE_VLAN 0x200UL
8000 __le32 tunnel_handle;
8001 __le16 action_flags;
8002 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_FWD 0x1UL
8003 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_RECYCLE 0x2UL
8004 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_DROP 0x4UL
8005 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_METER 0x8UL
8006 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_TUNNEL 0x10UL
8007 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_NAT_SRC 0x20UL
8008 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_NAT_DEST 0x40UL
8009 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_NAT_IPV4_ADDRESS 0x80UL
8010 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_L2_HEADER_REWRITE 0x100UL
8011 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_TTL_DECREMENT 0x200UL
8012 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_TUNNEL_IP 0x400UL
8013 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_FLOW_AGING_ENABLED 0x800UL
8014 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_PRI_HINT 0x1000UL
8015 #define CFA_FLOW_ALLOC_REQ_ACTION_FLAGS_NO_FLOW_COUNTER_ALLOC 0x2000UL
8017 __be16 l2_rewrite_vlan_tpid;
8018 __be16 l2_rewrite_vlan_tci;
8019 __le16 act_meter_id;
8020 __le16 ref_flow_handle;
8022 __be16 outer_vlan_tci;
8024 __be16 inner_vlan_tci;
8031 __be16 l4_src_port_mask;
8033 __be16 l4_dst_port_mask;
8034 __be32 nat_ip_address[4];
8035 __be16 l2_rewrite_dmac[3];
8037 __be16 l2_rewrite_smac[3];
8040 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_NONTUNNEL 0x0UL
8041 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_VXLAN 0x1UL
8042 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_NVGRE 0x2UL
8043 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_L2GRE 0x3UL
8044 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_IPIP 0x4UL
8045 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_GENEVE 0x5UL
8046 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_MPLS 0x6UL
8047 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_STT 0x7UL
8048 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_IPGRE 0x8UL
8049 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_VXLAN_V4 0x9UL
8050 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_IPGRE_V1 0xaUL
8051 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_L2_ETYPE 0xbUL
8052 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_VXLAN_GPE_V6 0xcUL
8053 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_ANYTUNNEL 0xffUL
8054 #define CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_LAST CFA_FLOW_ALLOC_REQ_TUNNEL_TYPE_ANYTUNNEL
8057 /* hwrm_cfa_flow_alloc_output (size:256b/32B) */
8058 struct hwrm_cfa_flow_alloc_output {
8066 #define CFA_FLOW_ALLOC_RESP_FLOW_ID_VALUE_MASK 0x3fffffffUL
8067 #define CFA_FLOW_ALLOC_RESP_FLOW_ID_VALUE_SFT 0
8068 #define CFA_FLOW_ALLOC_RESP_FLOW_ID_TYPE 0x40000000UL
8069 #define CFA_FLOW_ALLOC_RESP_FLOW_ID_TYPE_INT (0x0UL << 30)
8070 #define CFA_FLOW_ALLOC_RESP_FLOW_ID_TYPE_EXT (0x1UL << 30)
8071 #define CFA_FLOW_ALLOC_RESP_FLOW_ID_TYPE_LAST CFA_FLOW_ALLOC_RESP_FLOW_ID_TYPE_EXT
8072 #define CFA_FLOW_ALLOC_RESP_FLOW_ID_DIR 0x80000000UL
8073 #define CFA_FLOW_ALLOC_RESP_FLOW_ID_DIR_RX (0x0UL << 31)
8074 #define CFA_FLOW_ALLOC_RESP_FLOW_ID_DIR_TX (0x1UL << 31)
8075 #define CFA_FLOW_ALLOC_RESP_FLOW_ID_DIR_LAST CFA_FLOW_ALLOC_RESP_FLOW_ID_DIR_TX
8076 __le64 ext_flow_handle;
8077 __le32 flow_counter_id;
8082 /* hwrm_cfa_flow_alloc_cmd_err (size:64b/8B) */
8083 struct hwrm_cfa_flow_alloc_cmd_err {
8085 #define CFA_FLOW_ALLOC_CMD_ERR_CODE_UNKNOWN 0x0UL
8086 #define CFA_FLOW_ALLOC_CMD_ERR_CODE_L2_CONTEXT_TCAM 0x1UL
8087 #define CFA_FLOW_ALLOC_CMD_ERR_CODE_ACTION_RECORD 0x2UL
8088 #define CFA_FLOW_ALLOC_CMD_ERR_CODE_FLOW_COUNTER 0x3UL
8089 #define CFA_FLOW_ALLOC_CMD_ERR_CODE_WILD_CARD_TCAM 0x4UL
8090 #define CFA_FLOW_ALLOC_CMD_ERR_CODE_HASH_COLLISION 0x5UL
8091 #define CFA_FLOW_ALLOC_CMD_ERR_CODE_KEY_EXISTS 0x6UL
8092 #define CFA_FLOW_ALLOC_CMD_ERR_CODE_FLOW_CTXT_DB 0x7UL
8093 #define CFA_FLOW_ALLOC_CMD_ERR_CODE_LAST CFA_FLOW_ALLOC_CMD_ERR_CODE_FLOW_CTXT_DB
8097 /* hwrm_cfa_flow_free_input (size:256b/32B) */
8098 struct hwrm_cfa_flow_free_input {
8106 __le32 flow_counter_id;
8107 __le64 ext_flow_handle;
8110 /* hwrm_cfa_flow_free_output (size:256b/32B) */
8111 struct hwrm_cfa_flow_free_output {
8122 /* hwrm_cfa_flow_info_input (size:256b/32B) */
8123 struct hwrm_cfa_flow_info_input {
8130 #define CFA_FLOW_INFO_REQ_FLOW_HANDLE_MAX_MASK 0xfffUL
8131 #define CFA_FLOW_INFO_REQ_FLOW_HANDLE_CNP_CNT 0x1000UL
8132 #define CFA_FLOW_INFO_REQ_FLOW_HANDLE_ROCEV1_CNT 0x2000UL
8133 #define CFA_FLOW_INFO_REQ_FLOW_HANDLE_NIC_TX 0x3000UL
8134 #define CFA_FLOW_INFO_REQ_FLOW_HANDLE_ROCEV2_CNT 0x4000UL
8135 #define CFA_FLOW_INFO_REQ_FLOW_HANDLE_DIR_RX 0x8000UL
8136 #define CFA_FLOW_INFO_REQ_FLOW_HANDLE_CNP_CNT_RX 0x9000UL
8137 #define CFA_FLOW_INFO_REQ_FLOW_HANDLE_ROCEV1_CNT_RX 0xa000UL
8138 #define CFA_FLOW_INFO_REQ_FLOW_HANDLE_NIC_RX 0xb000UL
8139 #define CFA_FLOW_INFO_REQ_FLOW_HANDLE_ROCEV2_CNT_RX 0xc000UL
8140 #define CFA_FLOW_INFO_REQ_FLOW_HANDLE_LAST CFA_FLOW_INFO_REQ_FLOW_HANDLE_ROCEV2_CNT_RX
8142 __le64 ext_flow_handle;
8145 /* hwrm_cfa_flow_info_output (size:5632b/704B) */
8146 struct hwrm_cfa_flow_info_output {
8152 #define CFA_FLOW_INFO_RESP_FLAGS_PATH_TX 0x1UL
8153 #define CFA_FLOW_INFO_RESP_FLAGS_PATH_RX 0x2UL
8160 __le64 vfp_tcam_info;
8163 __le32 tunnel_handle;
8166 __le32 flow_key_data[130];
8167 __le32 flow_action_info[30];
8172 /* hwrm_cfa_flow_stats_input (size:640b/80B) */
8173 struct hwrm_cfa_flow_stats_input {
8180 __le16 flow_handle_0;
8181 __le16 flow_handle_1;
8182 __le16 flow_handle_2;
8183 __le16 flow_handle_3;
8184 __le16 flow_handle_4;
8185 __le16 flow_handle_5;
8186 __le16 flow_handle_6;
8187 __le16 flow_handle_7;
8188 __le16 flow_handle_8;
8189 __le16 flow_handle_9;
8203 /* hwrm_cfa_flow_stats_output (size:1408b/176B) */
8204 struct hwrm_cfa_flow_stats_output {
8234 /* hwrm_cfa_vfr_alloc_input (size:448b/56B) */
8235 struct hwrm_cfa_vfr_alloc_input {
8247 /* hwrm_cfa_vfr_alloc_output (size:128b/16B) */
8248 struct hwrm_cfa_vfr_alloc_output {
8254 __le16 tx_cfa_action;
8259 /* hwrm_cfa_vfr_free_input (size:448b/56B) */
8260 struct hwrm_cfa_vfr_free_input {
8272 /* hwrm_cfa_vfr_free_output (size:128b/16B) */
8273 struct hwrm_cfa_vfr_free_output {
8282 /* hwrm_cfa_eem_qcaps_input (size:192b/24B) */
8283 struct hwrm_cfa_eem_qcaps_input {
8290 #define CFA_EEM_QCAPS_REQ_FLAGS_PATH_TX 0x1UL
8291 #define CFA_EEM_QCAPS_REQ_FLAGS_PATH_RX 0x2UL
8292 #define CFA_EEM_QCAPS_REQ_FLAGS_PREFERRED_OFFLOAD 0x4UL
8296 /* hwrm_cfa_eem_qcaps_output (size:320b/40B) */
8297 struct hwrm_cfa_eem_qcaps_output {
8303 #define CFA_EEM_QCAPS_RESP_FLAGS_PATH_TX 0x1UL
8304 #define CFA_EEM_QCAPS_RESP_FLAGS_PATH_RX 0x2UL
8305 #define CFA_EEM_QCAPS_RESP_FLAGS_CENTRALIZED_MEMORY_MODEL_SUPPORTED 0x4UL
8306 #define CFA_EEM_QCAPS_RESP_FLAGS_DETACHED_CENTRALIZED_MEMORY_MODEL_SUPPORTED 0x8UL
8309 #define CFA_EEM_QCAPS_RESP_SUPPORTED_KEY0_TABLE 0x1UL
8310 #define CFA_EEM_QCAPS_RESP_SUPPORTED_KEY1_TABLE 0x2UL
8311 #define CFA_EEM_QCAPS_RESP_SUPPORTED_EXTERNAL_RECORD_TABLE 0x4UL
8312 #define CFA_EEM_QCAPS_RESP_SUPPORTED_EXTERNAL_FLOW_COUNTERS_TABLE 0x8UL
8313 #define CFA_EEM_QCAPS_RESP_SUPPORTED_FID_TABLE 0x10UL
8314 __le32 max_entries_supported;
8315 __le16 key_entry_size;
8316 __le16 record_entry_size;
8317 __le16 efc_entry_size;
8318 __le16 fid_entry_size;
8323 /* hwrm_cfa_eem_cfg_input (size:384b/48B) */
8324 struct hwrm_cfa_eem_cfg_input {
8331 #define CFA_EEM_CFG_REQ_FLAGS_PATH_TX 0x1UL
8332 #define CFA_EEM_CFG_REQ_FLAGS_PATH_RX 0x2UL
8333 #define CFA_EEM_CFG_REQ_FLAGS_PREFERRED_OFFLOAD 0x4UL
8334 #define CFA_EEM_CFG_REQ_FLAGS_SECONDARY_PF 0x8UL
8341 __le16 record_ctx_id;
8348 /* hwrm_cfa_eem_cfg_output (size:128b/16B) */
8349 struct hwrm_cfa_eem_cfg_output {
8358 /* hwrm_cfa_eem_qcfg_input (size:192b/24B) */
8359 struct hwrm_cfa_eem_qcfg_input {
8366 #define CFA_EEM_QCFG_REQ_FLAGS_PATH_TX 0x1UL
8367 #define CFA_EEM_QCFG_REQ_FLAGS_PATH_RX 0x2UL
8371 /* hwrm_cfa_eem_qcfg_output (size:256b/32B) */
8372 struct hwrm_cfa_eem_qcfg_output {
8378 #define CFA_EEM_QCFG_RESP_FLAGS_PATH_TX 0x1UL
8379 #define CFA_EEM_QCFG_RESP_FLAGS_PATH_RX 0x2UL
8380 #define CFA_EEM_QCFG_RESP_FLAGS_PREFERRED_OFFLOAD 0x4UL
8384 __le16 record_ctx_id;
8391 /* hwrm_cfa_eem_op_input (size:192b/24B) */
8392 struct hwrm_cfa_eem_op_input {
8399 #define CFA_EEM_OP_REQ_FLAGS_PATH_TX 0x1UL
8400 #define CFA_EEM_OP_REQ_FLAGS_PATH_RX 0x2UL
8403 #define CFA_EEM_OP_REQ_OP_RESERVED 0x0UL
8404 #define CFA_EEM_OP_REQ_OP_EEM_DISABLE 0x1UL
8405 #define CFA_EEM_OP_REQ_OP_EEM_ENABLE 0x2UL
8406 #define CFA_EEM_OP_REQ_OP_EEM_CLEANUP 0x3UL
8407 #define CFA_EEM_OP_REQ_OP_LAST CFA_EEM_OP_REQ_OP_EEM_CLEANUP
8410 /* hwrm_cfa_eem_op_output (size:128b/16B) */
8411 struct hwrm_cfa_eem_op_output {
8420 /* hwrm_cfa_adv_flow_mgnt_qcaps_input (size:256b/32B) */
8421 struct hwrm_cfa_adv_flow_mgnt_qcaps_input {
8430 /* hwrm_cfa_adv_flow_mgnt_qcaps_output (size:128b/16B) */
8431 struct hwrm_cfa_adv_flow_mgnt_qcaps_output {
8437 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_FLOW_HND_16BIT_SUPPORTED 0x1UL
8438 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_FLOW_HND_64BIT_SUPPORTED 0x2UL
8439 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_FLOW_BATCH_DELETE_SUPPORTED 0x4UL
8440 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_FLOW_RESET_ALL_SUPPORTED 0x8UL
8441 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_NTUPLE_FLOW_DEST_FUNC_SUPPORTED 0x10UL
8442 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_TX_EEM_FLOW_SUPPORTED 0x20UL
8443 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_RX_EEM_FLOW_SUPPORTED 0x40UL
8444 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_FLOW_COUNTER_ALLOC_SUPPORTED 0x80UL
8445 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_RFS_RING_TBL_IDX_SUPPORTED 0x100UL
8446 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_UNTAGGED_VLAN_SUPPORTED 0x200UL
8447 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_XDP_SUPPORTED 0x400UL
8448 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_L2_HEADER_SOURCE_FIELDS_SUPPORTED 0x800UL
8449 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_NTUPLE_FLOW_RX_ARP_SUPPORTED 0x1000UL
8450 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_RFS_RING_TBL_IDX_V2_SUPPORTED 0x2000UL
8451 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_NTUPLE_FLOW_RX_ETHERTYPE_IP_SUPPORTED 0x4000UL
8452 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_TRUFLOW_CAPABLE 0x8000UL
8453 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_L2_FILTER_TRAFFIC_TYPE_L2_ROCE_SUPPORTED 0x10000UL
8454 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_LAG_SUPPORTED 0x20000UL
8455 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_NTUPLE_FLOW_NO_L2CTX_SUPPORTED 0x40000UL
8456 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_NIC_FLOW_STATS_SUPPORTED 0x80000UL
8457 #define CFA_ADV_FLOW_MGNT_QCAPS_RESP_FLAGS_NTUPLE_FLOW_RX_EXT_IP_PROTO_SUPPORTED 0x100000UL
8462 /* hwrm_tunnel_dst_port_query_input (size:192b/24B) */
8463 struct hwrm_tunnel_dst_port_query_input {
8470 #define TUNNEL_DST_PORT_QUERY_REQ_TUNNEL_TYPE_VXLAN 0x1UL
8471 #define TUNNEL_DST_PORT_QUERY_REQ_TUNNEL_TYPE_GENEVE 0x5UL
8472 #define TUNNEL_DST_PORT_QUERY_REQ_TUNNEL_TYPE_VXLAN_V4 0x9UL
8473 #define TUNNEL_DST_PORT_QUERY_REQ_TUNNEL_TYPE_IPGRE_V1 0xaUL
8474 #define TUNNEL_DST_PORT_QUERY_REQ_TUNNEL_TYPE_L2_ETYPE 0xbUL
8475 #define TUNNEL_DST_PORT_QUERY_REQ_TUNNEL_TYPE_VXLAN_GPE_V6 0xcUL
8476 #define TUNNEL_DST_PORT_QUERY_REQ_TUNNEL_TYPE_CUSTOM_GRE 0xdUL
8477 #define TUNNEL_DST_PORT_QUERY_REQ_TUNNEL_TYPE_ECPRI 0xeUL
8478 #define TUNNEL_DST_PORT_QUERY_REQ_TUNNEL_TYPE_LAST TUNNEL_DST_PORT_QUERY_REQ_TUNNEL_TYPE_ECPRI
8482 /* hwrm_tunnel_dst_port_query_output (size:128b/16B) */
8483 struct hwrm_tunnel_dst_port_query_output {
8488 __le16 tunnel_dst_port_id;
8489 __be16 tunnel_dst_port_val;
8491 #define TUNNEL_DST_PORT_QUERY_RESP_UPAR_IN_USE_UPAR0 0x1UL
8492 #define TUNNEL_DST_PORT_QUERY_RESP_UPAR_IN_USE_UPAR1 0x2UL
8493 #define TUNNEL_DST_PORT_QUERY_RESP_UPAR_IN_USE_UPAR2 0x4UL
8494 #define TUNNEL_DST_PORT_QUERY_RESP_UPAR_IN_USE_UPAR3 0x8UL
8495 #define TUNNEL_DST_PORT_QUERY_RESP_UPAR_IN_USE_UPAR4 0x10UL
8496 #define TUNNEL_DST_PORT_QUERY_RESP_UPAR_IN_USE_UPAR5 0x20UL
8497 #define TUNNEL_DST_PORT_QUERY_RESP_UPAR_IN_USE_UPAR6 0x40UL
8498 #define TUNNEL_DST_PORT_QUERY_RESP_UPAR_IN_USE_UPAR7 0x80UL
8503 /* hwrm_tunnel_dst_port_alloc_input (size:192b/24B) */
8504 struct hwrm_tunnel_dst_port_alloc_input {
8511 #define TUNNEL_DST_PORT_ALLOC_REQ_TUNNEL_TYPE_VXLAN 0x1UL
8512 #define TUNNEL_DST_PORT_ALLOC_REQ_TUNNEL_TYPE_GENEVE 0x5UL
8513 #define TUNNEL_DST_PORT_ALLOC_REQ_TUNNEL_TYPE_VXLAN_V4 0x9UL
8514 #define TUNNEL_DST_PORT_ALLOC_REQ_TUNNEL_TYPE_IPGRE_V1 0xaUL
8515 #define TUNNEL_DST_PORT_ALLOC_REQ_TUNNEL_TYPE_L2_ETYPE 0xbUL
8516 #define TUNNEL_DST_PORT_ALLOC_REQ_TUNNEL_TYPE_VXLAN_GPE_V6 0xcUL
8517 #define TUNNEL_DST_PORT_ALLOC_REQ_TUNNEL_TYPE_CUSTOM_GRE 0xdUL
8518 #define TUNNEL_DST_PORT_ALLOC_REQ_TUNNEL_TYPE_ECPRI 0xeUL
8519 #define TUNNEL_DST_PORT_ALLOC_REQ_TUNNEL_TYPE_LAST TUNNEL_DST_PORT_ALLOC_REQ_TUNNEL_TYPE_ECPRI
8521 __be16 tunnel_dst_port_val;
8525 /* hwrm_tunnel_dst_port_alloc_output (size:128b/16B) */
8526 struct hwrm_tunnel_dst_port_alloc_output {
8531 __le16 tunnel_dst_port_id;
8533 #define TUNNEL_DST_PORT_ALLOC_RESP_ERROR_INFO_SUCCESS 0x0UL
8534 #define TUNNEL_DST_PORT_ALLOC_RESP_ERROR_INFO_ERR_ALLOCATED 0x1UL
8535 #define TUNNEL_DST_PORT_ALLOC_RESP_ERROR_INFO_ERR_NO_RESOURCE 0x2UL
8536 #define TUNNEL_DST_PORT_ALLOC_RESP_ERROR_INFO_LAST TUNNEL_DST_PORT_ALLOC_RESP_ERROR_INFO_ERR_NO_RESOURCE
8538 #define TUNNEL_DST_PORT_ALLOC_RESP_UPAR_IN_USE_UPAR0 0x1UL
8539 #define TUNNEL_DST_PORT_ALLOC_RESP_UPAR_IN_USE_UPAR1 0x2UL
8540 #define TUNNEL_DST_PORT_ALLOC_RESP_UPAR_IN_USE_UPAR2 0x4UL
8541 #define TUNNEL_DST_PORT_ALLOC_RESP_UPAR_IN_USE_UPAR3 0x8UL
8542 #define TUNNEL_DST_PORT_ALLOC_RESP_UPAR_IN_USE_UPAR4 0x10UL
8543 #define TUNNEL_DST_PORT_ALLOC_RESP_UPAR_IN_USE_UPAR5 0x20UL
8544 #define TUNNEL_DST_PORT_ALLOC_RESP_UPAR_IN_USE_UPAR6 0x40UL
8545 #define TUNNEL_DST_PORT_ALLOC_RESP_UPAR_IN_USE_UPAR7 0x80UL
8550 /* hwrm_tunnel_dst_port_free_input (size:192b/24B) */
8551 struct hwrm_tunnel_dst_port_free_input {
8558 #define TUNNEL_DST_PORT_FREE_REQ_TUNNEL_TYPE_VXLAN 0x1UL
8559 #define TUNNEL_DST_PORT_FREE_REQ_TUNNEL_TYPE_GENEVE 0x5UL
8560 #define TUNNEL_DST_PORT_FREE_REQ_TUNNEL_TYPE_VXLAN_V4 0x9UL
8561 #define TUNNEL_DST_PORT_FREE_REQ_TUNNEL_TYPE_IPGRE_V1 0xaUL
8562 #define TUNNEL_DST_PORT_FREE_REQ_TUNNEL_TYPE_L2_ETYPE 0xbUL
8563 #define TUNNEL_DST_PORT_FREE_REQ_TUNNEL_TYPE_VXLAN_GPE_V6 0xcUL
8564 #define TUNNEL_DST_PORT_FREE_REQ_TUNNEL_TYPE_CUSTOM_GRE 0xdUL
8565 #define TUNNEL_DST_PORT_FREE_REQ_TUNNEL_TYPE_ECPRI 0xeUL
8566 #define TUNNEL_DST_PORT_FREE_REQ_TUNNEL_TYPE_LAST TUNNEL_DST_PORT_FREE_REQ_TUNNEL_TYPE_ECPRI
8568 __le16 tunnel_dst_port_id;
8572 /* hwrm_tunnel_dst_port_free_output (size:128b/16B) */
8573 struct hwrm_tunnel_dst_port_free_output {
8579 #define TUNNEL_DST_PORT_FREE_RESP_ERROR_INFO_SUCCESS 0x0UL
8580 #define TUNNEL_DST_PORT_FREE_RESP_ERROR_INFO_ERR_NOT_OWNER 0x1UL
8581 #define TUNNEL_DST_PORT_FREE_RESP_ERROR_INFO_ERR_NOT_ALLOCATED 0x2UL
8582 #define TUNNEL_DST_PORT_FREE_RESP_ERROR_INFO_LAST TUNNEL_DST_PORT_FREE_RESP_ERROR_INFO_ERR_NOT_ALLOCATED
8587 /* ctx_hw_stats (size:1280b/160B) */
8588 struct ctx_hw_stats {
8589 __le64 rx_ucast_pkts;
8590 __le64 rx_mcast_pkts;
8591 __le64 rx_bcast_pkts;
8592 __le64 rx_discard_pkts;
8593 __le64 rx_error_pkts;
8594 __le64 rx_ucast_bytes;
8595 __le64 rx_mcast_bytes;
8596 __le64 rx_bcast_bytes;
8597 __le64 tx_ucast_pkts;
8598 __le64 tx_mcast_pkts;
8599 __le64 tx_bcast_pkts;
8600 __le64 tx_error_pkts;
8601 __le64 tx_discard_pkts;
8602 __le64 tx_ucast_bytes;
8603 __le64 tx_mcast_bytes;
8604 __le64 tx_bcast_bytes;
8611 /* ctx_hw_stats_ext (size:1408b/176B) */
8612 struct ctx_hw_stats_ext {
8613 __le64 rx_ucast_pkts;
8614 __le64 rx_mcast_pkts;
8615 __le64 rx_bcast_pkts;
8616 __le64 rx_discard_pkts;
8617 __le64 rx_error_pkts;
8618 __le64 rx_ucast_bytes;
8619 __le64 rx_mcast_bytes;
8620 __le64 rx_bcast_bytes;
8621 __le64 tx_ucast_pkts;
8622 __le64 tx_mcast_pkts;
8623 __le64 tx_bcast_pkts;
8624 __le64 tx_error_pkts;
8625 __le64 tx_discard_pkts;
8626 __le64 tx_ucast_bytes;
8627 __le64 tx_mcast_bytes;
8628 __le64 tx_bcast_bytes;
8629 __le64 rx_tpa_eligible_pkt;
8630 __le64 rx_tpa_eligible_bytes;
8632 __le64 rx_tpa_bytes;
8633 __le64 rx_tpa_errors;
8634 __le64 rx_tpa_events;
8637 /* hwrm_stat_ctx_alloc_input (size:256b/32B) */
8638 struct hwrm_stat_ctx_alloc_input {
8644 __le64 stats_dma_addr;
8645 __le32 update_period_ms;
8647 #define STAT_CTX_ALLOC_REQ_STAT_CTX_FLAGS_ROCE 0x1UL
8649 __le16 stats_dma_length;
8652 /* hwrm_stat_ctx_alloc_output (size:128b/16B) */
8653 struct hwrm_stat_ctx_alloc_output {
8663 /* hwrm_stat_ctx_free_input (size:192b/24B) */
8664 struct hwrm_stat_ctx_free_input {
8674 /* hwrm_stat_ctx_free_output (size:128b/16B) */
8675 struct hwrm_stat_ctx_free_output {
8685 /* hwrm_stat_ctx_query_input (size:192b/24B) */
8686 struct hwrm_stat_ctx_query_input {
8694 #define STAT_CTX_QUERY_REQ_FLAGS_COUNTER_MASK 0x1UL
8698 /* hwrm_stat_ctx_query_output (size:1408b/176B) */
8699 struct hwrm_stat_ctx_query_output {
8704 __le64 tx_ucast_pkts;
8705 __le64 tx_mcast_pkts;
8706 __le64 tx_bcast_pkts;
8707 __le64 tx_discard_pkts;
8708 __le64 tx_error_pkts;
8709 __le64 tx_ucast_bytes;
8710 __le64 tx_mcast_bytes;
8711 __le64 tx_bcast_bytes;
8712 __le64 rx_ucast_pkts;
8713 __le64 rx_mcast_pkts;
8714 __le64 rx_bcast_pkts;
8715 __le64 rx_discard_pkts;
8716 __le64 rx_error_pkts;
8717 __le64 rx_ucast_bytes;
8718 __le64 rx_mcast_bytes;
8719 __le64 rx_bcast_bytes;
8721 __le64 rx_agg_bytes;
8722 __le64 rx_agg_events;
8723 __le64 rx_agg_aborts;
8728 /* hwrm_stat_ext_ctx_query_input (size:192b/24B) */
8729 struct hwrm_stat_ext_ctx_query_input {
8737 #define STAT_EXT_CTX_QUERY_REQ_FLAGS_COUNTER_MASK 0x1UL
8741 /* hwrm_stat_ext_ctx_query_output (size:1536b/192B) */
8742 struct hwrm_stat_ext_ctx_query_output {
8747 __le64 rx_ucast_pkts;
8748 __le64 rx_mcast_pkts;
8749 __le64 rx_bcast_pkts;
8750 __le64 rx_discard_pkts;
8751 __le64 rx_error_pkts;
8752 __le64 rx_ucast_bytes;
8753 __le64 rx_mcast_bytes;
8754 __le64 rx_bcast_bytes;
8755 __le64 tx_ucast_pkts;
8756 __le64 tx_mcast_pkts;
8757 __le64 tx_bcast_pkts;
8758 __le64 tx_error_pkts;
8759 __le64 tx_discard_pkts;
8760 __le64 tx_ucast_bytes;
8761 __le64 tx_mcast_bytes;
8762 __le64 tx_bcast_bytes;
8763 __le64 rx_tpa_eligible_pkt;
8764 __le64 rx_tpa_eligible_bytes;
8766 __le64 rx_tpa_bytes;
8767 __le64 rx_tpa_errors;
8768 __le64 rx_tpa_events;
8773 /* hwrm_stat_ctx_clr_stats_input (size:192b/24B) */
8774 struct hwrm_stat_ctx_clr_stats_input {
8784 /* hwrm_stat_ctx_clr_stats_output (size:128b/16B) */
8785 struct hwrm_stat_ctx_clr_stats_output {
8794 /* hwrm_pcie_qstats_input (size:256b/32B) */
8795 struct hwrm_pcie_qstats_input {
8801 __le16 pcie_stat_size;
8803 __le64 pcie_stat_host_addr;
8806 /* hwrm_pcie_qstats_output (size:128b/16B) */
8807 struct hwrm_pcie_qstats_output {
8812 __le16 pcie_stat_size;
8817 /* pcie_ctx_hw_stats (size:768b/96B) */
8818 struct pcie_ctx_hw_stats {
8819 __le64 pcie_pl_signal_integrity;
8820 __le64 pcie_dl_signal_integrity;
8821 __le64 pcie_tl_signal_integrity;
8822 __le64 pcie_link_integrity;
8823 __le64 pcie_tx_traffic_rate;
8824 __le64 pcie_rx_traffic_rate;
8825 __le64 pcie_tx_dllp_statistics;
8826 __le64 pcie_rx_dllp_statistics;
8827 __le64 pcie_equalization_time;
8828 __le32 pcie_ltssm_histogram[4];
8829 __le64 pcie_recovery_histogram;
8832 /* hwrm_stat_generic_qstats_input (size:256b/32B) */
8833 struct hwrm_stat_generic_qstats_input {
8839 __le16 generic_stat_size;
8841 #define STAT_GENERIC_QSTATS_REQ_FLAGS_COUNTER_MASK 0x1UL
8843 __le64 generic_stat_host_addr;
8846 /* hwrm_stat_generic_qstats_output (size:128b/16B) */
8847 struct hwrm_stat_generic_qstats_output {
8852 __le16 generic_stat_size;
8857 /* generic_sw_hw_stats (size:1216b/152B) */
8858 struct generic_sw_hw_stats {
8859 __le64 pcie_statistics_tx_tlp;
8860 __le64 pcie_statistics_rx_tlp;
8861 __le64 pcie_credit_fc_hdr_posted;
8862 __le64 pcie_credit_fc_hdr_nonposted;
8863 __le64 pcie_credit_fc_hdr_cmpl;
8864 __le64 pcie_credit_fc_data_posted;
8865 __le64 pcie_credit_fc_data_nonposted;
8866 __le64 pcie_credit_fc_data_cmpl;
8867 __le64 pcie_credit_fc_tgt_nonposted;
8868 __le64 pcie_credit_fc_tgt_data_posted;
8869 __le64 pcie_credit_fc_tgt_hdr_posted;
8870 __le64 pcie_credit_fc_cmpl_hdr_posted;
8871 __le64 pcie_credit_fc_cmpl_data_posted;
8872 __le64 pcie_cmpl_longest;
8873 __le64 pcie_cmpl_shortest;
8874 __le64 cache_miss_count_cfcq;
8875 __le64 cache_miss_count_cfcs;
8876 __le64 cache_miss_count_cfcc;
8877 __le64 cache_miss_count_cfcm;
8880 /* hwrm_fw_reset_input (size:192b/24B) */
8881 struct hwrm_fw_reset_input {
8887 u8 embedded_proc_type;
8888 #define FW_RESET_REQ_EMBEDDED_PROC_TYPE_BOOT 0x0UL
8889 #define FW_RESET_REQ_EMBEDDED_PROC_TYPE_MGMT 0x1UL
8890 #define FW_RESET_REQ_EMBEDDED_PROC_TYPE_NETCTRL 0x2UL
8891 #define FW_RESET_REQ_EMBEDDED_PROC_TYPE_ROCE 0x3UL
8892 #define FW_RESET_REQ_EMBEDDED_PROC_TYPE_HOST 0x4UL
8893 #define FW_RESET_REQ_EMBEDDED_PROC_TYPE_AP 0x5UL
8894 #define FW_RESET_REQ_EMBEDDED_PROC_TYPE_CHIP 0x6UL
8895 #define FW_RESET_REQ_EMBEDDED_PROC_TYPE_HOST_RESOURCE_REINIT 0x7UL
8896 #define FW_RESET_REQ_EMBEDDED_PROC_TYPE_IMPACTLESS_ACTIVATION 0x8UL
8897 #define FW_RESET_REQ_EMBEDDED_PROC_TYPE_LAST FW_RESET_REQ_EMBEDDED_PROC_TYPE_IMPACTLESS_ACTIVATION
8899 #define FW_RESET_REQ_SELFRST_STATUS_SELFRSTNONE 0x0UL
8900 #define FW_RESET_REQ_SELFRST_STATUS_SELFRSTASAP 0x1UL
8901 #define FW_RESET_REQ_SELFRST_STATUS_SELFRSTPCIERST 0x2UL
8902 #define FW_RESET_REQ_SELFRST_STATUS_SELFRSTIMMEDIATE 0x3UL
8903 #define FW_RESET_REQ_SELFRST_STATUS_LAST FW_RESET_REQ_SELFRST_STATUS_SELFRSTIMMEDIATE
8906 #define FW_RESET_REQ_FLAGS_RESET_GRACEFUL 0x1UL
8907 #define FW_RESET_REQ_FLAGS_FW_ACTIVATION 0x2UL
8911 /* hwrm_fw_reset_output (size:128b/16B) */
8912 struct hwrm_fw_reset_output {
8918 #define FW_RESET_RESP_SELFRST_STATUS_SELFRSTNONE 0x0UL
8919 #define FW_RESET_RESP_SELFRST_STATUS_SELFRSTASAP 0x1UL
8920 #define FW_RESET_RESP_SELFRST_STATUS_SELFRSTPCIERST 0x2UL
8921 #define FW_RESET_RESP_SELFRST_STATUS_SELFRSTIMMEDIATE 0x3UL
8922 #define FW_RESET_RESP_SELFRST_STATUS_LAST FW_RESET_RESP_SELFRST_STATUS_SELFRSTIMMEDIATE
8927 /* hwrm_fw_qstatus_input (size:192b/24B) */
8928 struct hwrm_fw_qstatus_input {
8934 u8 embedded_proc_type;
8935 #define FW_QSTATUS_REQ_EMBEDDED_PROC_TYPE_BOOT 0x0UL
8936 #define FW_QSTATUS_REQ_EMBEDDED_PROC_TYPE_MGMT 0x1UL
8937 #define FW_QSTATUS_REQ_EMBEDDED_PROC_TYPE_NETCTRL 0x2UL
8938 #define FW_QSTATUS_REQ_EMBEDDED_PROC_TYPE_ROCE 0x3UL
8939 #define FW_QSTATUS_REQ_EMBEDDED_PROC_TYPE_HOST 0x4UL
8940 #define FW_QSTATUS_REQ_EMBEDDED_PROC_TYPE_AP 0x5UL
8941 #define FW_QSTATUS_REQ_EMBEDDED_PROC_TYPE_CHIP 0x6UL
8942 #define FW_QSTATUS_REQ_EMBEDDED_PROC_TYPE_LAST FW_QSTATUS_REQ_EMBEDDED_PROC_TYPE_CHIP
8946 /* hwrm_fw_qstatus_output (size:128b/16B) */
8947 struct hwrm_fw_qstatus_output {
8953 #define FW_QSTATUS_RESP_SELFRST_STATUS_SELFRSTNONE 0x0UL
8954 #define FW_QSTATUS_RESP_SELFRST_STATUS_SELFRSTASAP 0x1UL
8955 #define FW_QSTATUS_RESP_SELFRST_STATUS_SELFRSTPCIERST 0x2UL
8956 #define FW_QSTATUS_RESP_SELFRST_STATUS_SELFRSTPOWER 0x3UL
8957 #define FW_QSTATUS_RESP_SELFRST_STATUS_LAST FW_QSTATUS_RESP_SELFRST_STATUS_SELFRSTPOWER
8958 u8 nvm_option_action_status;
8959 #define FW_QSTATUS_RESP_NVM_OPTION_ACTION_STATUS_NVMOPT_ACTION_NONE 0x0UL
8960 #define FW_QSTATUS_RESP_NVM_OPTION_ACTION_STATUS_NVMOPT_ACTION_HOTRESET 0x1UL
8961 #define FW_QSTATUS_RESP_NVM_OPTION_ACTION_STATUS_NVMOPT_ACTION_WARMBOOT 0x2UL
8962 #define FW_QSTATUS_RESP_NVM_OPTION_ACTION_STATUS_NVMOPT_ACTION_COLDBOOT 0x3UL
8963 #define FW_QSTATUS_RESP_NVM_OPTION_ACTION_STATUS_LAST FW_QSTATUS_RESP_NVM_OPTION_ACTION_STATUS_NVMOPT_ACTION_COLDBOOT
8968 /* hwrm_fw_set_time_input (size:256b/32B) */
8969 struct hwrm_fw_set_time_input {
8976 #define FW_SET_TIME_REQ_YEAR_UNKNOWN 0x0UL
8977 #define FW_SET_TIME_REQ_YEAR_LAST FW_SET_TIME_REQ_YEAR_UNKNOWN
8986 #define FW_SET_TIME_REQ_ZONE_UTC 0
8987 #define FW_SET_TIME_REQ_ZONE_UNKNOWN 65535
8988 #define FW_SET_TIME_REQ_ZONE_LAST FW_SET_TIME_REQ_ZONE_UNKNOWN
8992 /* hwrm_fw_set_time_output (size:128b/16B) */
8993 struct hwrm_fw_set_time_output {
9002 /* hwrm_struct_hdr (size:128b/16B) */
9003 struct hwrm_struct_hdr {
9005 #define STRUCT_HDR_STRUCT_ID_LLDP_CFG 0x41bUL
9006 #define STRUCT_HDR_STRUCT_ID_DCBX_ETS 0x41dUL
9007 #define STRUCT_HDR_STRUCT_ID_DCBX_PFC 0x41fUL
9008 #define STRUCT_HDR_STRUCT_ID_DCBX_APP 0x421UL
9009 #define STRUCT_HDR_STRUCT_ID_DCBX_FEATURE_STATE 0x422UL
9010 #define STRUCT_HDR_STRUCT_ID_LLDP_GENERIC 0x424UL
9011 #define STRUCT_HDR_STRUCT_ID_LLDP_DEVICE 0x426UL
9012 #define STRUCT_HDR_STRUCT_ID_POWER_BKUP 0x427UL
9013 #define STRUCT_HDR_STRUCT_ID_AFM_OPAQUE 0x1UL
9014 #define STRUCT_HDR_STRUCT_ID_PORT_DESCRIPTION 0xaUL
9015 #define STRUCT_HDR_STRUCT_ID_RSS_V2 0x64UL
9016 #define STRUCT_HDR_STRUCT_ID_MSIX_PER_VF 0xc8UL
9017 #define STRUCT_HDR_STRUCT_ID_LAST STRUCT_HDR_STRUCT_ID_MSIX_PER_VF
9023 #define STRUCT_HDR_NEXT_OFFSET_LAST 0x0UL
9027 /* hwrm_struct_data_dcbx_app (size:64b/8B) */
9028 struct hwrm_struct_data_dcbx_app {
9030 u8 protocol_selector;
9031 #define STRUCT_DATA_DCBX_APP_PROTOCOL_SELECTOR_ETHER_TYPE 0x1UL
9032 #define STRUCT_DATA_DCBX_APP_PROTOCOL_SELECTOR_TCP_PORT 0x2UL
9033 #define STRUCT_DATA_DCBX_APP_PROTOCOL_SELECTOR_UDP_PORT 0x3UL
9034 #define STRUCT_DATA_DCBX_APP_PROTOCOL_SELECTOR_TCP_UDP_PORT 0x4UL
9035 #define STRUCT_DATA_DCBX_APP_PROTOCOL_SELECTOR_LAST STRUCT_DATA_DCBX_APP_PROTOCOL_SELECTOR_TCP_UDP_PORT
9041 /* hwrm_fw_set_structured_data_input (size:256b/32B) */
9042 struct hwrm_fw_set_structured_data_input {
9048 __le64 src_data_addr;
9054 /* hwrm_fw_set_structured_data_output (size:128b/16B) */
9055 struct hwrm_fw_set_structured_data_output {
9064 /* hwrm_fw_set_structured_data_cmd_err (size:64b/8B) */
9065 struct hwrm_fw_set_structured_data_cmd_err {
9067 #define FW_SET_STRUCTURED_DATA_CMD_ERR_CODE_UNKNOWN 0x0UL
9068 #define FW_SET_STRUCTURED_DATA_CMD_ERR_CODE_BAD_HDR_CNT 0x1UL
9069 #define FW_SET_STRUCTURED_DATA_CMD_ERR_CODE_BAD_FMT 0x2UL
9070 #define FW_SET_STRUCTURED_DATA_CMD_ERR_CODE_BAD_ID 0x3UL
9071 #define FW_SET_STRUCTURED_DATA_CMD_ERR_CODE_LAST FW_SET_STRUCTURED_DATA_CMD_ERR_CODE_BAD_ID
9075 /* hwrm_fw_get_structured_data_input (size:256b/32B) */
9076 struct hwrm_fw_get_structured_data_input {
9082 __le64 dest_data_addr;
9084 __le16 structure_id;
9086 #define FW_GET_STRUCTURED_DATA_REQ_SUBTYPE_UNUSED 0x0UL
9087 #define FW_GET_STRUCTURED_DATA_REQ_SUBTYPE_ALL 0xffffUL
9088 #define FW_GET_STRUCTURED_DATA_REQ_SUBTYPE_NEAR_BRIDGE_ADMIN 0x100UL
9089 #define FW_GET_STRUCTURED_DATA_REQ_SUBTYPE_NEAR_BRIDGE_PEER 0x101UL
9090 #define FW_GET_STRUCTURED_DATA_REQ_SUBTYPE_NEAR_BRIDGE_OPERATIONAL 0x102UL
9091 #define FW_GET_STRUCTURED_DATA_REQ_SUBTYPE_NON_TPMR_ADMIN 0x200UL
9092 #define FW_GET_STRUCTURED_DATA_REQ_SUBTYPE_NON_TPMR_PEER 0x201UL
9093 #define FW_GET_STRUCTURED_DATA_REQ_SUBTYPE_NON_TPMR_OPERATIONAL 0x202UL
9094 #define FW_GET_STRUCTURED_DATA_REQ_SUBTYPE_HOST_OPERATIONAL 0x300UL
9095 #define FW_GET_STRUCTURED_DATA_REQ_SUBTYPE_LAST FW_GET_STRUCTURED_DATA_REQ_SUBTYPE_HOST_OPERATIONAL
9100 /* hwrm_fw_get_structured_data_output (size:128b/16B) */
9101 struct hwrm_fw_get_structured_data_output {
9111 /* hwrm_fw_get_structured_data_cmd_err (size:64b/8B) */
9112 struct hwrm_fw_get_structured_data_cmd_err {
9114 #define FW_GET_STRUCTURED_DATA_CMD_ERR_CODE_UNKNOWN 0x0UL
9115 #define FW_GET_STRUCTURED_DATA_CMD_ERR_CODE_BAD_ID 0x3UL
9116 #define FW_GET_STRUCTURED_DATA_CMD_ERR_CODE_LAST FW_GET_STRUCTURED_DATA_CMD_ERR_CODE_BAD_ID
9120 /* hwrm_fw_livepatch_query_input (size:192b/24B) */
9121 struct hwrm_fw_livepatch_query_input {
9128 #define FW_LIVEPATCH_QUERY_REQ_FW_TARGET_COMMON_FW 0x1UL
9129 #define FW_LIVEPATCH_QUERY_REQ_FW_TARGET_SECURE_FW 0x2UL
9130 #define FW_LIVEPATCH_QUERY_REQ_FW_TARGET_LAST FW_LIVEPATCH_QUERY_REQ_FW_TARGET_SECURE_FW
9134 /* hwrm_fw_livepatch_query_output (size:640b/80B) */
9135 struct hwrm_fw_livepatch_query_output {
9140 char install_ver[32];
9141 char active_ver[32];
9142 __le16 status_flags;
9143 #define FW_LIVEPATCH_QUERY_RESP_STATUS_FLAGS_INSTALL 0x1UL
9144 #define FW_LIVEPATCH_QUERY_RESP_STATUS_FLAGS_ACTIVE 0x2UL
9149 /* hwrm_fw_livepatch_input (size:256b/32B) */
9150 struct hwrm_fw_livepatch_input {
9157 #define FW_LIVEPATCH_REQ_OPCODE_ACTIVATE 0x1UL
9158 #define FW_LIVEPATCH_REQ_OPCODE_DEACTIVATE 0x2UL
9159 #define FW_LIVEPATCH_REQ_OPCODE_LAST FW_LIVEPATCH_REQ_OPCODE_DEACTIVATE
9161 #define FW_LIVEPATCH_REQ_FW_TARGET_COMMON_FW 0x1UL
9162 #define FW_LIVEPATCH_REQ_FW_TARGET_SECURE_FW 0x2UL
9163 #define FW_LIVEPATCH_REQ_FW_TARGET_LAST FW_LIVEPATCH_REQ_FW_TARGET_SECURE_FW
9165 #define FW_LIVEPATCH_REQ_LOADTYPE_NVM_INSTALL 0x1UL
9166 #define FW_LIVEPATCH_REQ_LOADTYPE_MEMORY_DIRECT 0x2UL
9167 #define FW_LIVEPATCH_REQ_LOADTYPE_LAST FW_LIVEPATCH_REQ_LOADTYPE_MEMORY_DIRECT
9173 /* hwrm_fw_livepatch_output (size:128b/16B) */
9174 struct hwrm_fw_livepatch_output {
9183 /* hwrm_fw_livepatch_cmd_err (size:64b/8B) */
9184 struct hwrm_fw_livepatch_cmd_err {
9186 #define FW_LIVEPATCH_CMD_ERR_CODE_UNKNOWN 0x0UL
9187 #define FW_LIVEPATCH_CMD_ERR_CODE_INVALID_OPCODE 0x1UL
9188 #define FW_LIVEPATCH_CMD_ERR_CODE_INVALID_TARGET 0x2UL
9189 #define FW_LIVEPATCH_CMD_ERR_CODE_NOT_SUPPORTED 0x3UL
9190 #define FW_LIVEPATCH_CMD_ERR_CODE_NOT_INSTALLED 0x4UL
9191 #define FW_LIVEPATCH_CMD_ERR_CODE_NOT_PATCHED 0x5UL
9192 #define FW_LIVEPATCH_CMD_ERR_CODE_AUTH_FAIL 0x6UL
9193 #define FW_LIVEPATCH_CMD_ERR_CODE_INVALID_HEADER 0x7UL
9194 #define FW_LIVEPATCH_CMD_ERR_CODE_INVALID_SIZE 0x8UL
9195 #define FW_LIVEPATCH_CMD_ERR_CODE_ALREADY_PATCHED 0x9UL
9196 #define FW_LIVEPATCH_CMD_ERR_CODE_LAST FW_LIVEPATCH_CMD_ERR_CODE_ALREADY_PATCHED
9200 /* hwrm_exec_fwd_resp_input (size:1024b/128B) */
9201 struct hwrm_exec_fwd_resp_input {
9207 __le32 encap_request[26];
9208 __le16 encap_resp_target_id;
9212 /* hwrm_exec_fwd_resp_output (size:128b/16B) */
9213 struct hwrm_exec_fwd_resp_output {
9222 /* hwrm_reject_fwd_resp_input (size:1024b/128B) */
9223 struct hwrm_reject_fwd_resp_input {
9229 __le32 encap_request[26];
9230 __le16 encap_resp_target_id;
9234 /* hwrm_reject_fwd_resp_output (size:128b/16B) */
9235 struct hwrm_reject_fwd_resp_output {
9244 /* hwrm_fwd_resp_input (size:1024b/128B) */
9245 struct hwrm_fwd_resp_input {
9251 __le16 encap_resp_target_id;
9252 __le16 encap_resp_cmpl_ring;
9253 __le16 encap_resp_len;
9256 __le64 encap_resp_addr;
9257 __le32 encap_resp[24];
9260 /* hwrm_fwd_resp_output (size:128b/16B) */
9261 struct hwrm_fwd_resp_output {
9270 /* hwrm_fwd_async_event_cmpl_input (size:320b/40B) */
9271 struct hwrm_fwd_async_event_cmpl_input {
9277 __le16 encap_async_event_target_id;
9279 __le32 encap_async_event_cmpl[4];
9282 /* hwrm_fwd_async_event_cmpl_output (size:128b/16B) */
9283 struct hwrm_fwd_async_event_cmpl_output {
9292 /* hwrm_temp_monitor_query_input (size:128b/16B) */
9293 struct hwrm_temp_monitor_query_input {
9301 /* hwrm_temp_monitor_query_output (size:128b/16B) */
9302 struct hwrm_temp_monitor_query_output {
9311 #define TEMP_MONITOR_QUERY_RESP_FLAGS_TEMP_NOT_AVAILABLE 0x1UL
9312 #define TEMP_MONITOR_QUERY_RESP_FLAGS_PHY_TEMP_NOT_AVAILABLE 0x2UL
9313 #define TEMP_MONITOR_QUERY_RESP_FLAGS_OM_NOT_PRESENT 0x4UL
9314 #define TEMP_MONITOR_QUERY_RESP_FLAGS_OM_TEMP_NOT_AVAILABLE 0x8UL
9315 #define TEMP_MONITOR_QUERY_RESP_FLAGS_EXT_TEMP_FIELDS_AVAILABLE 0x10UL
9322 /* hwrm_wol_filter_alloc_input (size:512b/64B) */
9323 struct hwrm_wol_filter_alloc_input {
9331 #define WOL_FILTER_ALLOC_REQ_ENABLES_MAC_ADDRESS 0x1UL
9332 #define WOL_FILTER_ALLOC_REQ_ENABLES_PATTERN_OFFSET 0x2UL
9333 #define WOL_FILTER_ALLOC_REQ_ENABLES_PATTERN_BUF_SIZE 0x4UL
9334 #define WOL_FILTER_ALLOC_REQ_ENABLES_PATTERN_BUF_ADDR 0x8UL
9335 #define WOL_FILTER_ALLOC_REQ_ENABLES_PATTERN_MASK_ADDR 0x10UL
9336 #define WOL_FILTER_ALLOC_REQ_ENABLES_PATTERN_MASK_SIZE 0x20UL
9339 #define WOL_FILTER_ALLOC_REQ_WOL_TYPE_MAGICPKT 0x0UL
9340 #define WOL_FILTER_ALLOC_REQ_WOL_TYPE_BMP 0x1UL
9341 #define WOL_FILTER_ALLOC_REQ_WOL_TYPE_INVALID 0xffUL
9342 #define WOL_FILTER_ALLOC_REQ_WOL_TYPE_LAST WOL_FILTER_ALLOC_REQ_WOL_TYPE_INVALID
9345 __le16 pattern_offset;
9346 __le16 pattern_buf_size;
9347 __le16 pattern_mask_size;
9349 __le64 pattern_buf_addr;
9350 __le64 pattern_mask_addr;
9353 /* hwrm_wol_filter_alloc_output (size:128b/16B) */
9354 struct hwrm_wol_filter_alloc_output {
9364 /* hwrm_wol_filter_free_input (size:256b/32B) */
9365 struct hwrm_wol_filter_free_input {
9372 #define WOL_FILTER_FREE_REQ_FLAGS_FREE_ALL_WOL_FILTERS 0x1UL
9374 #define WOL_FILTER_FREE_REQ_ENABLES_WOL_FILTER_ID 0x1UL
9380 /* hwrm_wol_filter_free_output (size:128b/16B) */
9381 struct hwrm_wol_filter_free_output {
9390 /* hwrm_wol_filter_qcfg_input (size:448b/56B) */
9391 struct hwrm_wol_filter_qcfg_input {
9400 __le64 pattern_buf_addr;
9401 __le16 pattern_buf_size;
9403 __le64 pattern_mask_addr;
9404 __le16 pattern_mask_size;
9408 /* hwrm_wol_filter_qcfg_output (size:256b/32B) */
9409 struct hwrm_wol_filter_qcfg_output {
9417 #define WOL_FILTER_QCFG_RESP_WOL_TYPE_MAGICPKT 0x0UL
9418 #define WOL_FILTER_QCFG_RESP_WOL_TYPE_BMP 0x1UL
9419 #define WOL_FILTER_QCFG_RESP_WOL_TYPE_INVALID 0xffUL
9420 #define WOL_FILTER_QCFG_RESP_WOL_TYPE_LAST WOL_FILTER_QCFG_RESP_WOL_TYPE_INVALID
9423 __le16 pattern_offset;
9424 __le16 pattern_size;
9425 __le16 pattern_mask_size;
9430 /* hwrm_wol_reason_qcfg_input (size:320b/40B) */
9431 struct hwrm_wol_reason_qcfg_input {
9439 __le64 wol_pkt_buf_addr;
9440 __le16 wol_pkt_buf_size;
9444 /* hwrm_wol_reason_qcfg_output (size:128b/16B) */
9445 struct hwrm_wol_reason_qcfg_output {
9452 #define WOL_REASON_QCFG_RESP_WOL_REASON_MAGICPKT 0x0UL
9453 #define WOL_REASON_QCFG_RESP_WOL_REASON_BMP 0x1UL
9454 #define WOL_REASON_QCFG_RESP_WOL_REASON_INVALID 0xffUL
9455 #define WOL_REASON_QCFG_RESP_WOL_REASON_LAST WOL_REASON_QCFG_RESP_WOL_REASON_INVALID
9461 /* hwrm_dbg_read_direct_input (size:256b/32B) */
9462 struct hwrm_dbg_read_direct_input {
9468 __le64 host_dest_addr;
9473 /* hwrm_dbg_read_direct_output (size:128b/16B) */
9474 struct hwrm_dbg_read_direct_output {
9484 /* hwrm_dbg_qcaps_input (size:192b/24B) */
9485 struct hwrm_dbg_qcaps_input {
9495 /* hwrm_dbg_qcaps_output (size:192b/24B) */
9496 struct hwrm_dbg_qcaps_output {
9503 __le32 coredump_component_disable_caps;
9504 #define DBG_QCAPS_RESP_COREDUMP_COMPONENT_DISABLE_CAPS_NVRAM 0x1UL
9506 #define DBG_QCAPS_RESP_FLAGS_CRASHDUMP_NVM 0x1UL
9507 #define DBG_QCAPS_RESP_FLAGS_CRASHDUMP_HOST_DDR 0x2UL
9508 #define DBG_QCAPS_RESP_FLAGS_CRASHDUMP_SOC_DDR 0x4UL
9509 #define DBG_QCAPS_RESP_FLAGS_USEQ 0x8UL
9514 /* hwrm_dbg_qcfg_input (size:192b/24B) */
9515 struct hwrm_dbg_qcfg_input {
9523 #define DBG_QCFG_REQ_FLAGS_CRASHDUMP_SIZE_FOR_DEST_MASK 0x3UL
9524 #define DBG_QCFG_REQ_FLAGS_CRASHDUMP_SIZE_FOR_DEST_SFT 0
9525 #define DBG_QCFG_REQ_FLAGS_CRASHDUMP_SIZE_FOR_DEST_DEST_NVM 0x0UL
9526 #define DBG_QCFG_REQ_FLAGS_CRASHDUMP_SIZE_FOR_DEST_DEST_HOST_DDR 0x1UL
9527 #define DBG_QCFG_REQ_FLAGS_CRASHDUMP_SIZE_FOR_DEST_DEST_SOC_DDR 0x2UL
9528 #define DBG_QCFG_REQ_FLAGS_CRASHDUMP_SIZE_FOR_DEST_LAST DBG_QCFG_REQ_FLAGS_CRASHDUMP_SIZE_FOR_DEST_DEST_SOC_DDR
9529 __le32 coredump_component_disable_flags;
9530 #define DBG_QCFG_REQ_COREDUMP_COMPONENT_DISABLE_FLAGS_NVRAM 0x1UL
9533 /* hwrm_dbg_qcfg_output (size:256b/32B) */
9534 struct hwrm_dbg_qcfg_output {
9541 __le32 coredump_size;
9543 #define DBG_QCFG_RESP_FLAGS_UART_LOG 0x1UL
9544 #define DBG_QCFG_RESP_FLAGS_UART_LOG_SECONDARY 0x2UL
9545 #define DBG_QCFG_RESP_FLAGS_FW_TRACE 0x4UL
9546 #define DBG_QCFG_RESP_FLAGS_FW_TRACE_SECONDARY 0x8UL
9547 #define DBG_QCFG_RESP_FLAGS_DEBUG_NOTIFY 0x10UL
9548 #define DBG_QCFG_RESP_FLAGS_JTAG_DEBUG 0x20UL
9549 __le16 async_cmpl_ring;
9551 __le32 crashdump_size;
9556 /* hwrm_dbg_crashdump_medium_cfg_input (size:320b/40B) */
9557 struct hwrm_dbg_crashdump_medium_cfg_input {
9563 __le16 output_dest_flags;
9564 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_TYPE_DDR 0x1UL
9566 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_LVL_MASK 0x3UL
9567 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_LVL_SFT 0
9568 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_LVL_LVL_0 0x0UL
9569 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_LVL_LVL_1 0x1UL
9570 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_LVL_LVL_2 0x2UL
9571 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_LVL_LAST DBG_CRASHDUMP_MEDIUM_CFG_REQ_LVL_LVL_2
9572 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_PG_SIZE_MASK 0x1cUL
9573 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_PG_SIZE_SFT 2
9574 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_PG_SIZE_PG_4K (0x0UL << 2)
9575 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_PG_SIZE_PG_8K (0x1UL << 2)
9576 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_PG_SIZE_PG_64K (0x2UL << 2)
9577 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_PG_SIZE_PG_2M (0x3UL << 2)
9578 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_PG_SIZE_PG_8M (0x4UL << 2)
9579 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_PG_SIZE_PG_1G (0x5UL << 2)
9580 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_PG_SIZE_LAST DBG_CRASHDUMP_MEDIUM_CFG_REQ_PG_SIZE_PG_1G
9581 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_UNUSED11_MASK 0xffe0UL
9582 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_UNUSED11_SFT 5
9584 __le32 coredump_component_disable_flags;
9585 #define DBG_CRASHDUMP_MEDIUM_CFG_REQ_NVRAM 0x1UL
9590 /* hwrm_dbg_crashdump_medium_cfg_output (size:128b/16B) */
9591 struct hwrm_dbg_crashdump_medium_cfg_output {
9600 /* coredump_segment_record (size:128b/16B) */
9601 struct coredump_segment_record {
9602 __le16 component_id;
9604 __le16 max_instances;
9609 #define SFLAG_COMPRESSED_ZLIB 0x1UL
9614 /* hwrm_dbg_coredump_list_input (size:256b/32B) */
9615 struct hwrm_dbg_coredump_list_input {
9621 __le64 host_dest_addr;
9622 __le32 host_buf_len;
9625 #define DBG_COREDUMP_LIST_REQ_FLAGS_CRASHDUMP 0x1UL
9629 /* hwrm_dbg_coredump_list_output (size:128b/16B) */
9630 struct hwrm_dbg_coredump_list_output {
9636 #define DBG_COREDUMP_LIST_RESP_FLAGS_MORE 0x1UL
9638 __le16 total_segments;
9644 /* hwrm_dbg_coredump_initiate_input (size:256b/32B) */
9645 struct hwrm_dbg_coredump_initiate_input {
9651 __le16 component_id;
9659 /* hwrm_dbg_coredump_initiate_output (size:128b/16B) */
9660 struct hwrm_dbg_coredump_initiate_output {
9669 /* coredump_data_hdr (size:128b/16B) */
9670 struct coredump_data_hdr {
9672 __le32 flags_length;
9673 #define COREDUMP_DATA_HDR_FLAGS_LENGTH_ACTUAL_LEN_MASK 0xffffffUL
9674 #define COREDUMP_DATA_HDR_FLAGS_LENGTH_ACTUAL_LEN_SFT 0
9675 #define COREDUMP_DATA_HDR_FLAGS_LENGTH_INDIRECT_ACCESS 0x1000000UL
9680 /* hwrm_dbg_coredump_retrieve_input (size:448b/56B) */
9681 struct hwrm_dbg_coredump_retrieve_input {
9687 __le64 host_dest_addr;
9688 __le32 host_buf_len;
9690 __le16 component_id;
9702 /* hwrm_dbg_coredump_retrieve_output (size:128b/16B) */
9703 struct hwrm_dbg_coredump_retrieve_output {
9709 #define DBG_COREDUMP_RETRIEVE_RESP_FLAGS_MORE 0x1UL
9716 /* hwrm_dbg_ring_info_get_input (size:192b/24B) */
9717 struct hwrm_dbg_ring_info_get_input {
9724 #define DBG_RING_INFO_GET_REQ_RING_TYPE_L2_CMPL 0x0UL
9725 #define DBG_RING_INFO_GET_REQ_RING_TYPE_TX 0x1UL
9726 #define DBG_RING_INFO_GET_REQ_RING_TYPE_RX 0x2UL
9727 #define DBG_RING_INFO_GET_REQ_RING_TYPE_NQ 0x3UL
9728 #define DBG_RING_INFO_GET_REQ_RING_TYPE_LAST DBG_RING_INFO_GET_REQ_RING_TYPE_NQ
9733 /* hwrm_dbg_ring_info_get_output (size:192b/24B) */
9734 struct hwrm_dbg_ring_info_get_output {
9739 __le32 producer_index;
9740 __le32 consumer_index;
9741 __le32 cag_vector_ctrl;
9746 /* hwrm_nvm_read_input (size:320b/40B) */
9747 struct hwrm_nvm_read_input {
9753 __le64 host_dest_addr;
9761 /* hwrm_nvm_read_output (size:128b/16B) */
9762 struct hwrm_nvm_read_output {
9771 /* hwrm_nvm_get_dir_entries_input (size:192b/24B) */
9772 struct hwrm_nvm_get_dir_entries_input {
9778 __le64 host_dest_addr;
9781 /* hwrm_nvm_get_dir_entries_output (size:128b/16B) */
9782 struct hwrm_nvm_get_dir_entries_output {
9791 /* hwrm_nvm_get_dir_info_input (size:128b/16B) */
9792 struct hwrm_nvm_get_dir_info_input {
9800 /* hwrm_nvm_get_dir_info_output (size:192b/24B) */
9801 struct hwrm_nvm_get_dir_info_output {
9807 __le32 entry_length;
9812 /* hwrm_nvm_write_input (size:448b/56B) */
9813 struct hwrm_nvm_write_input {
9819 __le64 host_src_addr;
9824 __le32 dir_data_length;
9827 #define NVM_WRITE_REQ_FLAGS_KEEP_ORIG_ACTIVE_IMG 0x1UL
9828 #define NVM_WRITE_REQ_FLAGS_BATCH_MODE 0x2UL
9829 #define NVM_WRITE_REQ_FLAGS_BATCH_LAST 0x4UL
9830 __le32 dir_item_length;
9836 /* hwrm_nvm_write_output (size:128b/16B) */
9837 struct hwrm_nvm_write_output {
9842 __le32 dir_item_length;
9848 /* hwrm_nvm_write_cmd_err (size:64b/8B) */
9849 struct hwrm_nvm_write_cmd_err {
9851 #define NVM_WRITE_CMD_ERR_CODE_UNKNOWN 0x0UL
9852 #define NVM_WRITE_CMD_ERR_CODE_FRAG_ERR 0x1UL
9853 #define NVM_WRITE_CMD_ERR_CODE_NO_SPACE 0x2UL
9854 #define NVM_WRITE_CMD_ERR_CODE_LAST NVM_WRITE_CMD_ERR_CODE_NO_SPACE
9858 /* hwrm_nvm_modify_input (size:320b/40B) */
9859 struct hwrm_nvm_modify_input {
9865 __le64 host_src_addr;
9868 #define NVM_MODIFY_REQ_FLAGS_BATCH_MODE 0x1UL
9869 #define NVM_MODIFY_REQ_FLAGS_BATCH_LAST 0x2UL
9875 /* hwrm_nvm_modify_output (size:128b/16B) */
9876 struct hwrm_nvm_modify_output {
9885 /* hwrm_nvm_find_dir_entry_input (size:256b/32B) */
9886 struct hwrm_nvm_find_dir_entry_input {
9893 #define NVM_FIND_DIR_ENTRY_REQ_ENABLES_DIR_IDX_VALID 0x1UL
9899 #define NVM_FIND_DIR_ENTRY_REQ_OPT_ORDINAL_MASK 0x3UL
9900 #define NVM_FIND_DIR_ENTRY_REQ_OPT_ORDINAL_SFT 0
9901 #define NVM_FIND_DIR_ENTRY_REQ_OPT_ORDINAL_EQ 0x0UL
9902 #define NVM_FIND_DIR_ENTRY_REQ_OPT_ORDINAL_GE 0x1UL
9903 #define NVM_FIND_DIR_ENTRY_REQ_OPT_ORDINAL_GT 0x2UL
9904 #define NVM_FIND_DIR_ENTRY_REQ_OPT_ORDINAL_LAST NVM_FIND_DIR_ENTRY_REQ_OPT_ORDINAL_GT
9908 /* hwrm_nvm_find_dir_entry_output (size:256b/32B) */
9909 struct hwrm_nvm_find_dir_entry_output {
9914 __le32 dir_item_length;
9915 __le32 dir_data_length;
9923 /* hwrm_nvm_erase_dir_entry_input (size:192b/24B) */
9924 struct hwrm_nvm_erase_dir_entry_input {
9934 /* hwrm_nvm_erase_dir_entry_output (size:128b/16B) */
9935 struct hwrm_nvm_erase_dir_entry_output {
9944 /* hwrm_nvm_get_dev_info_input (size:128b/16B) */
9945 struct hwrm_nvm_get_dev_info_input {
9953 /* hwrm_nvm_get_dev_info_output (size:640b/80B) */
9954 struct hwrm_nvm_get_dev_info_output {
9959 __le16 manufacturer_id;
9963 __le32 reserved_size;
9964 __le32 available_size;
9969 #define NVM_GET_DEV_INFO_RESP_FLAGS_FW_VER_VALID 0x1UL
9971 __le16 hwrm_fw_major;
9972 __le16 hwrm_fw_minor;
9973 __le16 hwrm_fw_build;
9974 __le16 hwrm_fw_patch;
9975 __le16 mgmt_fw_major;
9976 __le16 mgmt_fw_minor;
9977 __le16 mgmt_fw_build;
9978 __le16 mgmt_fw_patch;
9979 __le16 roce_fw_major;
9980 __le16 roce_fw_minor;
9981 __le16 roce_fw_build;
9982 __le16 roce_fw_patch;
9987 /* hwrm_nvm_mod_dir_entry_input (size:256b/32B) */
9988 struct hwrm_nvm_mod_dir_entry_input {
9995 #define NVM_MOD_DIR_ENTRY_REQ_ENABLES_CHECKSUM 0x1UL
10003 /* hwrm_nvm_mod_dir_entry_output (size:128b/16B) */
10004 struct hwrm_nvm_mod_dir_entry_output {
10013 /* hwrm_nvm_verify_update_input (size:192b/24B) */
10014 struct hwrm_nvm_verify_update_input {
10021 __le16 dir_ordinal;
10026 /* hwrm_nvm_verify_update_output (size:128b/16B) */
10027 struct hwrm_nvm_verify_update_output {
10036 /* hwrm_nvm_install_update_input (size:192b/24B) */
10037 struct hwrm_nvm_install_update_input {
10043 __le32 install_type;
10044 #define NVM_INSTALL_UPDATE_REQ_INSTALL_TYPE_NORMAL 0x0UL
10045 #define NVM_INSTALL_UPDATE_REQ_INSTALL_TYPE_ALL 0xffffffffUL
10046 #define NVM_INSTALL_UPDATE_REQ_INSTALL_TYPE_LAST NVM_INSTALL_UPDATE_REQ_INSTALL_TYPE_ALL
10048 #define NVM_INSTALL_UPDATE_REQ_FLAGS_ERASE_UNUSED_SPACE 0x1UL
10049 #define NVM_INSTALL_UPDATE_REQ_FLAGS_REMOVE_UNUSED_PKG 0x2UL
10050 #define NVM_INSTALL_UPDATE_REQ_FLAGS_ALLOWED_TO_DEFRAG 0x4UL
10051 #define NVM_INSTALL_UPDATE_REQ_FLAGS_VERIFY_ONLY 0x8UL
10055 /* hwrm_nvm_install_update_output (size:192b/24B) */
10056 struct hwrm_nvm_install_update_output {
10061 __le64 installed_items;
10063 #define NVM_INSTALL_UPDATE_RESP_RESULT_SUCCESS 0x0UL
10064 #define NVM_INSTALL_UPDATE_RESP_RESULT_FAILURE 0xffUL
10065 #define NVM_INSTALL_UPDATE_RESP_RESULT_MALLOC_FAILURE 0xfdUL
10066 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_INDEX_PARAMETER 0xfbUL
10067 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_TYPE_PARAMETER 0xf3UL
10068 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_PREREQUISITE 0xf2UL
10069 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_FILE_HEADER 0xecUL
10070 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_SIGNATURE 0xebUL
10071 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_PROP_STREAM 0xeaUL
10072 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_PROP_LENGTH 0xe9UL
10073 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_MANIFEST 0xe8UL
10074 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_TRAILER 0xe7UL
10075 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_CHECKSUM 0xe6UL
10076 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_ITEM_CHECKSUM 0xe5UL
10077 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_DATA_LENGTH 0xe4UL
10078 #define NVM_INSTALL_UPDATE_RESP_RESULT_INVALID_DIRECTIVE 0xe1UL
10079 #define NVM_INSTALL_UPDATE_RESP_RESULT_UNSUPPORTED_CHIP_REV 0xceUL
10080 #define NVM_INSTALL_UPDATE_RESP_RESULT_UNSUPPORTED_DEVICE_ID 0xcdUL
10081 #define NVM_INSTALL_UPDATE_RESP_RESULT_UNSUPPORTED_SUBSYS_VENDOR 0xccUL
10082 #define NVM_INSTALL_UPDATE_RESP_RESULT_UNSUPPORTED_SUBSYS_ID 0xcbUL
10083 #define NVM_INSTALL_UPDATE_RESP_RESULT_UNSUPPORTED_PLATFORM 0xc5UL
10084 #define NVM_INSTALL_UPDATE_RESP_RESULT_DUPLICATE_ITEM 0xc4UL
10085 #define NVM_INSTALL_UPDATE_RESP_RESULT_ZERO_LENGTH_ITEM 0xc3UL
10086 #define NVM_INSTALL_UPDATE_RESP_RESULT_INSTALL_CHECKSUM_ERROR 0xb9UL
10087 #define NVM_INSTALL_UPDATE_RESP_RESULT_INSTALL_DATA_ERROR 0xb8UL
10088 #define NVM_INSTALL_UPDATE_RESP_RESULT_INSTALL_AUTHENTICATION_ERROR 0xb7UL
10089 #define NVM_INSTALL_UPDATE_RESP_RESULT_ITEM_NOT_FOUND 0xb0UL
10090 #define NVM_INSTALL_UPDATE_RESP_RESULT_ITEM_LOCKED 0xa7UL
10091 #define NVM_INSTALL_UPDATE_RESP_RESULT_LAST NVM_INSTALL_UPDATE_RESP_RESULT_ITEM_LOCKED
10093 #define NVM_INSTALL_UPDATE_RESP_PROBLEM_ITEM_NONE 0x0UL
10094 #define NVM_INSTALL_UPDATE_RESP_PROBLEM_ITEM_PACKAGE 0xffUL
10095 #define NVM_INSTALL_UPDATE_RESP_PROBLEM_ITEM_LAST NVM_INSTALL_UPDATE_RESP_PROBLEM_ITEM_PACKAGE
10097 #define NVM_INSTALL_UPDATE_RESP_RESET_REQUIRED_NONE 0x0UL
10098 #define NVM_INSTALL_UPDATE_RESP_RESET_REQUIRED_PCI 0x1UL
10099 #define NVM_INSTALL_UPDATE_RESP_RESET_REQUIRED_POWER 0x2UL
10100 #define NVM_INSTALL_UPDATE_RESP_RESET_REQUIRED_LAST NVM_INSTALL_UPDATE_RESP_RESET_REQUIRED_POWER
10105 /* hwrm_nvm_install_update_cmd_err (size:64b/8B) */
10106 struct hwrm_nvm_install_update_cmd_err {
10108 #define NVM_INSTALL_UPDATE_CMD_ERR_CODE_UNKNOWN 0x0UL
10109 #define NVM_INSTALL_UPDATE_CMD_ERR_CODE_FRAG_ERR 0x1UL
10110 #define NVM_INSTALL_UPDATE_CMD_ERR_CODE_NO_SPACE 0x2UL
10111 #define NVM_INSTALL_UPDATE_CMD_ERR_CODE_ANTI_ROLLBACK 0x3UL
10112 #define NVM_INSTALL_UPDATE_CMD_ERR_CODE_NO_VOLTREG_SUPPORT 0x4UL
10113 #define NVM_INSTALL_UPDATE_CMD_ERR_CODE_LAST NVM_INSTALL_UPDATE_CMD_ERR_CODE_NO_VOLTREG_SUPPORT
10117 /* hwrm_nvm_get_variable_input (size:320b/40B) */
10118 struct hwrm_nvm_get_variable_input {
10124 __le64 dest_data_addr;
10127 #define NVM_GET_VARIABLE_REQ_OPTION_NUM_RSVD_0 0x0UL
10128 #define NVM_GET_VARIABLE_REQ_OPTION_NUM_RSVD_FFFF 0xffffUL
10129 #define NVM_GET_VARIABLE_REQ_OPTION_NUM_LAST NVM_GET_VARIABLE_REQ_OPTION_NUM_RSVD_FFFF
10136 #define NVM_GET_VARIABLE_REQ_FLAGS_FACTORY_DFLT 0x1UL
10140 /* hwrm_nvm_get_variable_output (size:128b/16B) */
10141 struct hwrm_nvm_get_variable_output {
10148 #define NVM_GET_VARIABLE_RESP_OPTION_NUM_RSVD_0 0x0UL
10149 #define NVM_GET_VARIABLE_RESP_OPTION_NUM_RSVD_FFFF 0xffffUL
10150 #define NVM_GET_VARIABLE_RESP_OPTION_NUM_LAST NVM_GET_VARIABLE_RESP_OPTION_NUM_RSVD_FFFF
10155 /* hwrm_nvm_get_variable_cmd_err (size:64b/8B) */
10156 struct hwrm_nvm_get_variable_cmd_err {
10158 #define NVM_GET_VARIABLE_CMD_ERR_CODE_UNKNOWN 0x0UL
10159 #define NVM_GET_VARIABLE_CMD_ERR_CODE_VAR_NOT_EXIST 0x1UL
10160 #define NVM_GET_VARIABLE_CMD_ERR_CODE_CORRUPT_VAR 0x2UL
10161 #define NVM_GET_VARIABLE_CMD_ERR_CODE_LEN_TOO_SHORT 0x3UL
10162 #define NVM_GET_VARIABLE_CMD_ERR_CODE_LAST NVM_GET_VARIABLE_CMD_ERR_CODE_LEN_TOO_SHORT
10166 /* hwrm_nvm_set_variable_input (size:320b/40B) */
10167 struct hwrm_nvm_set_variable_input {
10173 __le64 src_data_addr;
10176 #define NVM_SET_VARIABLE_REQ_OPTION_NUM_RSVD_0 0x0UL
10177 #define NVM_SET_VARIABLE_REQ_OPTION_NUM_RSVD_FFFF 0xffffUL
10178 #define NVM_SET_VARIABLE_REQ_OPTION_NUM_LAST NVM_SET_VARIABLE_REQ_OPTION_NUM_RSVD_FFFF
10185 #define NVM_SET_VARIABLE_REQ_FLAGS_FORCE_FLUSH 0x1UL
10186 #define NVM_SET_VARIABLE_REQ_FLAGS_ENCRYPT_MODE_MASK 0xeUL
10187 #define NVM_SET_VARIABLE_REQ_FLAGS_ENCRYPT_MODE_SFT 1
10188 #define NVM_SET_VARIABLE_REQ_FLAGS_ENCRYPT_MODE_NONE (0x0UL << 1)
10189 #define NVM_SET_VARIABLE_REQ_FLAGS_ENCRYPT_MODE_HMAC_SHA1 (0x1UL << 1)
10190 #define NVM_SET_VARIABLE_REQ_FLAGS_ENCRYPT_MODE_AES256 (0x2UL << 1)
10191 #define NVM_SET_VARIABLE_REQ_FLAGS_ENCRYPT_MODE_HMAC_SHA1_AUTH (0x3UL << 1)
10192 #define NVM_SET_VARIABLE_REQ_FLAGS_ENCRYPT_MODE_LAST NVM_SET_VARIABLE_REQ_FLAGS_ENCRYPT_MODE_HMAC_SHA1_AUTH
10193 #define NVM_SET_VARIABLE_REQ_FLAGS_FLAGS_UNUSED_0_MASK 0x70UL
10194 #define NVM_SET_VARIABLE_REQ_FLAGS_FLAGS_UNUSED_0_SFT 4
10195 #define NVM_SET_VARIABLE_REQ_FLAGS_FACTORY_DEFAULT 0x80UL
10199 /* hwrm_nvm_set_variable_output (size:128b/16B) */
10200 struct hwrm_nvm_set_variable_output {
10209 /* hwrm_nvm_set_variable_cmd_err (size:64b/8B) */
10210 struct hwrm_nvm_set_variable_cmd_err {
10212 #define NVM_SET_VARIABLE_CMD_ERR_CODE_UNKNOWN 0x0UL
10213 #define NVM_SET_VARIABLE_CMD_ERR_CODE_VAR_NOT_EXIST 0x1UL
10214 #define NVM_SET_VARIABLE_CMD_ERR_CODE_CORRUPT_VAR 0x2UL
10215 #define NVM_SET_VARIABLE_CMD_ERR_CODE_LAST NVM_SET_VARIABLE_CMD_ERR_CODE_CORRUPT_VAR
10219 /* hwrm_selftest_qlist_input (size:128b/16B) */
10220 struct hwrm_selftest_qlist_input {
10228 /* hwrm_selftest_qlist_output (size:2240b/280B) */
10229 struct hwrm_selftest_qlist_output {
10235 u8 available_tests;
10236 #define SELFTEST_QLIST_RESP_AVAILABLE_TESTS_NVM_TEST 0x1UL
10237 #define SELFTEST_QLIST_RESP_AVAILABLE_TESTS_LINK_TEST 0x2UL
10238 #define SELFTEST_QLIST_RESP_AVAILABLE_TESTS_REGISTER_TEST 0x4UL
10239 #define SELFTEST_QLIST_RESP_AVAILABLE_TESTS_MEMORY_TEST 0x8UL
10240 #define SELFTEST_QLIST_RESP_AVAILABLE_TESTS_PCIE_SERDES_TEST 0x10UL
10241 #define SELFTEST_QLIST_RESP_AVAILABLE_TESTS_ETHERNET_SERDES_TEST 0x20UL
10243 #define SELFTEST_QLIST_RESP_OFFLINE_TESTS_NVM_TEST 0x1UL
10244 #define SELFTEST_QLIST_RESP_OFFLINE_TESTS_LINK_TEST 0x2UL
10245 #define SELFTEST_QLIST_RESP_OFFLINE_TESTS_REGISTER_TEST 0x4UL
10246 #define SELFTEST_QLIST_RESP_OFFLINE_TESTS_MEMORY_TEST 0x8UL
10247 #define SELFTEST_QLIST_RESP_OFFLINE_TESTS_PCIE_SERDES_TEST 0x10UL
10248 #define SELFTEST_QLIST_RESP_OFFLINE_TESTS_ETHERNET_SERDES_TEST 0x20UL
10250 __le16 test_timeout;
10252 char test_name[8][32];
10253 u8 eyescope_target_BER_support;
10254 #define SELFTEST_QLIST_RESP_EYESCOPE_TARGET_BER_SUPPORT_BER_1E8_SUPPORTED 0x0UL
10255 #define SELFTEST_QLIST_RESP_EYESCOPE_TARGET_BER_SUPPORT_BER_1E9_SUPPORTED 0x1UL
10256 #define SELFTEST_QLIST_RESP_EYESCOPE_TARGET_BER_SUPPORT_BER_1E10_SUPPORTED 0x2UL
10257 #define SELFTEST_QLIST_RESP_EYESCOPE_TARGET_BER_SUPPORT_BER_1E11_SUPPORTED 0x3UL
10258 #define SELFTEST_QLIST_RESP_EYESCOPE_TARGET_BER_SUPPORT_BER_1E12_SUPPORTED 0x4UL
10259 #define SELFTEST_QLIST_RESP_EYESCOPE_TARGET_BER_SUPPORT_LAST SELFTEST_QLIST_RESP_EYESCOPE_TARGET_BER_SUPPORT_BER_1E12_SUPPORTED
10264 /* hwrm_selftest_exec_input (size:192b/24B) */
10265 struct hwrm_selftest_exec_input {
10272 #define SELFTEST_EXEC_REQ_FLAGS_NVM_TEST 0x1UL
10273 #define SELFTEST_EXEC_REQ_FLAGS_LINK_TEST 0x2UL
10274 #define SELFTEST_EXEC_REQ_FLAGS_REGISTER_TEST 0x4UL
10275 #define SELFTEST_EXEC_REQ_FLAGS_MEMORY_TEST 0x8UL
10276 #define SELFTEST_EXEC_REQ_FLAGS_PCIE_SERDES_TEST 0x10UL
10277 #define SELFTEST_EXEC_REQ_FLAGS_ETHERNET_SERDES_TEST 0x20UL
10281 /* hwrm_selftest_exec_output (size:128b/16B) */
10282 struct hwrm_selftest_exec_output {
10287 u8 requested_tests;
10288 #define SELFTEST_EXEC_RESP_REQUESTED_TESTS_NVM_TEST 0x1UL
10289 #define SELFTEST_EXEC_RESP_REQUESTED_TESTS_LINK_TEST 0x2UL
10290 #define SELFTEST_EXEC_RESP_REQUESTED_TESTS_REGISTER_TEST 0x4UL
10291 #define SELFTEST_EXEC_RESP_REQUESTED_TESTS_MEMORY_TEST 0x8UL
10292 #define SELFTEST_EXEC_RESP_REQUESTED_TESTS_PCIE_SERDES_TEST 0x10UL
10293 #define SELFTEST_EXEC_RESP_REQUESTED_TESTS_ETHERNET_SERDES_TEST 0x20UL
10295 #define SELFTEST_EXEC_RESP_TEST_SUCCESS_NVM_TEST 0x1UL
10296 #define SELFTEST_EXEC_RESP_TEST_SUCCESS_LINK_TEST 0x2UL
10297 #define SELFTEST_EXEC_RESP_TEST_SUCCESS_REGISTER_TEST 0x4UL
10298 #define SELFTEST_EXEC_RESP_TEST_SUCCESS_MEMORY_TEST 0x8UL
10299 #define SELFTEST_EXEC_RESP_TEST_SUCCESS_PCIE_SERDES_TEST 0x10UL
10300 #define SELFTEST_EXEC_RESP_TEST_SUCCESS_ETHERNET_SERDES_TEST 0x20UL
10305 /* hwrm_selftest_irq_input (size:128b/16B) */
10306 struct hwrm_selftest_irq_input {
10314 /* hwrm_selftest_irq_output (size:128b/16B) */
10315 struct hwrm_selftest_irq_output {
10324 /* dbc_dbc (size:64b/8B) */
10327 #define DBC_DBC_INDEX_MASK 0xffffffUL
10328 #define DBC_DBC_INDEX_SFT 0
10329 #define DBC_DBC_EPOCH 0x1000000UL
10330 #define DBC_DBC_TOGGLE_MASK 0x6000000UL
10331 #define DBC_DBC_TOGGLE_SFT 25
10333 #define DBC_DBC_XID_MASK 0xfffffUL
10334 #define DBC_DBC_XID_SFT 0
10335 #define DBC_DBC_PATH_MASK 0x3000000UL
10336 #define DBC_DBC_PATH_SFT 24
10337 #define DBC_DBC_PATH_ROCE (0x0UL << 24)
10338 #define DBC_DBC_PATH_L2 (0x1UL << 24)
10339 #define DBC_DBC_PATH_ENGINE (0x2UL << 24)
10340 #define DBC_DBC_PATH_LAST DBC_DBC_PATH_ENGINE
10341 #define DBC_DBC_VALID 0x4000000UL
10342 #define DBC_DBC_DEBUG_TRACE 0x8000000UL
10343 #define DBC_DBC_TYPE_MASK 0xf0000000UL
10344 #define DBC_DBC_TYPE_SFT 28
10345 #define DBC_DBC_TYPE_SQ (0x0UL << 28)
10346 #define DBC_DBC_TYPE_RQ (0x1UL << 28)
10347 #define DBC_DBC_TYPE_SRQ (0x2UL << 28)
10348 #define DBC_DBC_TYPE_SRQ_ARM (0x3UL << 28)
10349 #define DBC_DBC_TYPE_CQ (0x4UL << 28)
10350 #define DBC_DBC_TYPE_CQ_ARMSE (0x5UL << 28)
10351 #define DBC_DBC_TYPE_CQ_ARMALL (0x6UL << 28)
10352 #define DBC_DBC_TYPE_CQ_ARMENA (0x7UL << 28)
10353 #define DBC_DBC_TYPE_SRQ_ARMENA (0x8UL << 28)
10354 #define DBC_DBC_TYPE_CQ_CUTOFF_ACK (0x9UL << 28)
10355 #define DBC_DBC_TYPE_NQ (0xaUL << 28)
10356 #define DBC_DBC_TYPE_NQ_ARM (0xbUL << 28)
10357 #define DBC_DBC_TYPE_NQ_MASK (0xeUL << 28)
10358 #define DBC_DBC_TYPE_NULL (0xfUL << 28)
10359 #define DBC_DBC_TYPE_LAST DBC_DBC_TYPE_NULL
10362 /* db_push_start (size:64b/8B) */
10363 struct db_push_start {
10365 #define DB_PUSH_START_DB_INDEX_MASK 0xffffffUL
10366 #define DB_PUSH_START_DB_INDEX_SFT 0
10367 #define DB_PUSH_START_DB_PI_LO_MASK 0xff000000UL
10368 #define DB_PUSH_START_DB_PI_LO_SFT 24
10369 #define DB_PUSH_START_DB_XID_MASK 0xfffff00000000ULL
10370 #define DB_PUSH_START_DB_XID_SFT 32
10371 #define DB_PUSH_START_DB_PI_HI_MASK 0xf0000000000000ULL
10372 #define DB_PUSH_START_DB_PI_HI_SFT 52
10373 #define DB_PUSH_START_DB_TYPE_MASK 0xf000000000000000ULL
10374 #define DB_PUSH_START_DB_TYPE_SFT 60
10375 #define DB_PUSH_START_DB_TYPE_PUSH_START (0xcULL << 60)
10376 #define DB_PUSH_START_DB_TYPE_PUSH_END (0xdULL << 60)
10377 #define DB_PUSH_START_DB_TYPE_LAST DB_PUSH_START_DB_TYPE_PUSH_END
10380 /* db_push_end (size:64b/8B) */
10381 struct db_push_end {
10383 #define DB_PUSH_END_DB_INDEX_MASK 0xffffffUL
10384 #define DB_PUSH_END_DB_INDEX_SFT 0
10385 #define DB_PUSH_END_DB_PI_LO_MASK 0xff000000UL
10386 #define DB_PUSH_END_DB_PI_LO_SFT 24
10387 #define DB_PUSH_END_DB_XID_MASK 0xfffff00000000ULL
10388 #define DB_PUSH_END_DB_XID_SFT 32
10389 #define DB_PUSH_END_DB_PI_HI_MASK 0xf0000000000000ULL
10390 #define DB_PUSH_END_DB_PI_HI_SFT 52
10391 #define DB_PUSH_END_DB_PATH_MASK 0x300000000000000ULL
10392 #define DB_PUSH_END_DB_PATH_SFT 56
10393 #define DB_PUSH_END_DB_PATH_ROCE (0x0ULL << 56)
10394 #define DB_PUSH_END_DB_PATH_L2 (0x1ULL << 56)
10395 #define DB_PUSH_END_DB_PATH_ENGINE (0x2ULL << 56)
10396 #define DB_PUSH_END_DB_PATH_LAST DB_PUSH_END_DB_PATH_ENGINE
10397 #define DB_PUSH_END_DB_DEBUG_TRACE 0x800000000000000ULL
10398 #define DB_PUSH_END_DB_TYPE_MASK 0xf000000000000000ULL
10399 #define DB_PUSH_END_DB_TYPE_SFT 60
10400 #define DB_PUSH_END_DB_TYPE_PUSH_START (0xcULL << 60)
10401 #define DB_PUSH_END_DB_TYPE_PUSH_END (0xdULL << 60)
10402 #define DB_PUSH_END_DB_TYPE_LAST DB_PUSH_END_DB_TYPE_PUSH_END
10405 /* db_push_info (size:64b/8B) */
10406 struct db_push_info {
10407 u32 push_size_push_index;
10408 #define DB_PUSH_INFO_PUSH_INDEX_MASK 0xffffffUL
10409 #define DB_PUSH_INFO_PUSH_INDEX_SFT 0
10410 #define DB_PUSH_INFO_PUSH_SIZE_MASK 0x1f000000UL
10411 #define DB_PUSH_INFO_PUSH_SIZE_SFT 24
10415 /* fw_status_reg (size:32b/4B) */
10416 struct fw_status_reg {
10418 #define FW_STATUS_REG_CODE_MASK 0xffffUL
10419 #define FW_STATUS_REG_CODE_SFT 0
10420 #define FW_STATUS_REG_CODE_READY 0x8000UL
10421 #define FW_STATUS_REG_CODE_LAST FW_STATUS_REG_CODE_READY
10422 #define FW_STATUS_REG_IMAGE_DEGRADED 0x10000UL
10423 #define FW_STATUS_REG_RECOVERABLE 0x20000UL
10424 #define FW_STATUS_REG_CRASHDUMP_ONGOING 0x40000UL
10425 #define FW_STATUS_REG_CRASHDUMP_COMPLETE 0x80000UL
10426 #define FW_STATUS_REG_SHUTDOWN 0x100000UL
10427 #define FW_STATUS_REG_CRASHED_NO_MASTER 0x200000UL
10428 #define FW_STATUS_REG_RECOVERING 0x400000UL
10429 #define FW_STATUS_REG_MANU_DEBUG_STATUS 0x800000UL
10432 /* hcomm_status (size:64b/8B) */
10433 struct hcomm_status {
10435 #define HCOMM_STATUS_VER_MASK 0xffUL
10436 #define HCOMM_STATUS_VER_SFT 0
10437 #define HCOMM_STATUS_VER_LATEST 0x1UL
10438 #define HCOMM_STATUS_VER_LAST HCOMM_STATUS_VER_LATEST
10439 #define HCOMM_STATUS_SIGNATURE_MASK 0xffffff00UL
10440 #define HCOMM_STATUS_SIGNATURE_SFT 8
10441 #define HCOMM_STATUS_SIGNATURE_VAL (0x484353UL << 8)
10442 #define HCOMM_STATUS_SIGNATURE_LAST HCOMM_STATUS_SIGNATURE_VAL
10444 #define HCOMM_STATUS_TRUE_ADDR_SPACE_MASK 0x3UL
10445 #define HCOMM_STATUS_TRUE_ADDR_SPACE_SFT 0
10446 #define HCOMM_STATUS_FW_STATUS_LOC_ADDR_SPACE_PCIE_CFG 0x0UL
10447 #define HCOMM_STATUS_FW_STATUS_LOC_ADDR_SPACE_GRC 0x1UL
10448 #define HCOMM_STATUS_FW_STATUS_LOC_ADDR_SPACE_BAR0 0x2UL
10449 #define HCOMM_STATUS_FW_STATUS_LOC_ADDR_SPACE_BAR1 0x3UL
10450 #define HCOMM_STATUS_FW_STATUS_LOC_ADDR_SPACE_LAST HCOMM_STATUS_FW_STATUS_LOC_ADDR_SPACE_BAR1
10451 #define HCOMM_STATUS_TRUE_OFFSET_MASK 0xfffffffcUL
10452 #define HCOMM_STATUS_TRUE_OFFSET_SFT 2
10454 #define HCOMM_STATUS_STRUCT_LOC 0x31001F0UL
10456 #endif /* _BNXT_HSI_H_ */