xref: /dpdk/drivers/net/thunderx/base/nicvf_hw_defs.h (revision d2869184ae39d2773df12d1f7a0b96e5fb2d4ed4)
1aaf4363eSJerin Jacob /* SPDX-License-Identifier: BSD-3-Clause
2aaf4363eSJerin Jacob  * Copyright(c) 2016 Cavium, Inc
3fec9ad3aSJerin Jacob  */
4fec9ad3aSJerin Jacob 
5fec9ad3aSJerin Jacob #ifndef _THUNDERX_NICVF_HW_DEFS_H
6fec9ad3aSJerin Jacob #define _THUNDERX_NICVF_HW_DEFS_H
7fec9ad3aSJerin Jacob 
8fec9ad3aSJerin Jacob #include <stdint.h>
9fec9ad3aSJerin Jacob #include <stdbool.h>
10fec9ad3aSJerin Jacob 
115ba41107SJerin Jacob #include "nicvf_plat.h"
125ba41107SJerin Jacob 
13fec9ad3aSJerin Jacob /* Virtual function register offsets */
14fec9ad3aSJerin Jacob 
15fec9ad3aSJerin Jacob #define NIC_VF_CFG                      (0x000020)
16fec9ad3aSJerin Jacob #define NIC_VF_PF_MAILBOX_0_1           (0x000130)
17fec9ad3aSJerin Jacob #define NIC_VF_INT                      (0x000200)
18fec9ad3aSJerin Jacob #define NIC_VF_INT_W1S                  (0x000220)
19fec9ad3aSJerin Jacob #define NIC_VF_ENA_W1C                  (0x000240)
20fec9ad3aSJerin Jacob #define NIC_VF_ENA_W1S                  (0x000260)
21fec9ad3aSJerin Jacob 
22fec9ad3aSJerin Jacob #define NIC_VNIC_RSS_CFG                (0x0020E0)
23fec9ad3aSJerin Jacob #define NIC_VNIC_RSS_KEY_0_4            (0x002200)
24fec9ad3aSJerin Jacob #define NIC_VNIC_TX_STAT_0_4            (0x004000)
25fec9ad3aSJerin Jacob #define NIC_VNIC_RX_STAT_0_13           (0x004100)
26fec9ad3aSJerin Jacob #define NIC_VNIC_RQ_GEN_CFG             (0x010010)
27fec9ad3aSJerin Jacob 
28fec9ad3aSJerin Jacob #define NIC_QSET_CQ_0_7_CFG             (0x010400)
29fec9ad3aSJerin Jacob #define NIC_QSET_CQ_0_7_CFG2            (0x010408)
30fec9ad3aSJerin Jacob #define NIC_QSET_CQ_0_7_THRESH          (0x010410)
31fec9ad3aSJerin Jacob #define NIC_QSET_CQ_0_7_BASE            (0x010420)
32fec9ad3aSJerin Jacob #define NIC_QSET_CQ_0_7_HEAD            (0x010428)
33fec9ad3aSJerin Jacob #define NIC_QSET_CQ_0_7_TAIL            (0x010430)
34fec9ad3aSJerin Jacob #define NIC_QSET_CQ_0_7_DOOR            (0x010438)
35fec9ad3aSJerin Jacob #define NIC_QSET_CQ_0_7_STATUS          (0x010440)
36fec9ad3aSJerin Jacob #define NIC_QSET_CQ_0_7_STATUS2         (0x010448)
37fec9ad3aSJerin Jacob #define NIC_QSET_CQ_0_7_DEBUG           (0x010450)
38fec9ad3aSJerin Jacob 
39fec9ad3aSJerin Jacob #define NIC_QSET_RQ_0_7_CFG             (0x010600)
40fec9ad3aSJerin Jacob #define NIC_QSET_RQ_0_7_STATUS0         (0x010700)
41fec9ad3aSJerin Jacob #define NIC_QSET_RQ_0_7_STATUS1         (0x010708)
42fec9ad3aSJerin Jacob 
43fec9ad3aSJerin Jacob #define NIC_QSET_SQ_0_7_CFG             (0x010800)
44fec9ad3aSJerin Jacob #define NIC_QSET_SQ_0_7_THRESH          (0x010810)
45fec9ad3aSJerin Jacob #define NIC_QSET_SQ_0_7_BASE            (0x010820)
46fec9ad3aSJerin Jacob #define NIC_QSET_SQ_0_7_HEAD            (0x010828)
47fec9ad3aSJerin Jacob #define NIC_QSET_SQ_0_7_TAIL            (0x010830)
48fec9ad3aSJerin Jacob #define NIC_QSET_SQ_0_7_DOOR            (0x010838)
49fec9ad3aSJerin Jacob #define NIC_QSET_SQ_0_7_STATUS          (0x010840)
50fec9ad3aSJerin Jacob #define NIC_QSET_SQ_0_7_DEBUG           (0x010848)
51fec9ad3aSJerin Jacob #define NIC_QSET_SQ_0_7_STATUS0         (0x010900)
52fec9ad3aSJerin Jacob #define NIC_QSET_SQ_0_7_STATUS1         (0x010908)
53fec9ad3aSJerin Jacob 
54fec9ad3aSJerin Jacob #define NIC_QSET_RBDR_0_1_CFG           (0x010C00)
55fec9ad3aSJerin Jacob #define NIC_QSET_RBDR_0_1_THRESH        (0x010C10)
56fec9ad3aSJerin Jacob #define NIC_QSET_RBDR_0_1_BASE          (0x010C20)
57fec9ad3aSJerin Jacob #define NIC_QSET_RBDR_0_1_HEAD          (0x010C28)
58fec9ad3aSJerin Jacob #define NIC_QSET_RBDR_0_1_TAIL          (0x010C30)
59fec9ad3aSJerin Jacob #define NIC_QSET_RBDR_0_1_DOOR          (0x010C38)
60fec9ad3aSJerin Jacob #define NIC_QSET_RBDR_0_1_STATUS0       (0x010C40)
61fec9ad3aSJerin Jacob #define NIC_QSET_RBDR_0_1_STATUS1       (0x010C48)
62fec9ad3aSJerin Jacob #define NIC_QSET_RBDR_0_1_PRFCH_STATUS  (0x010C50)
63fec9ad3aSJerin Jacob 
64fec9ad3aSJerin Jacob /* vNIC HW Constants */
65fec9ad3aSJerin Jacob 
66fec9ad3aSJerin Jacob #define NIC_Q_NUM_SHIFT                 18
67fec9ad3aSJerin Jacob 
68fec9ad3aSJerin Jacob #define MAX_QUEUE_SET                   128
69fec9ad3aSJerin Jacob #define MAX_RCV_QUEUES_PER_QS           8
70fec9ad3aSJerin Jacob #define MAX_RCV_BUF_DESC_RINGS_PER_QS   2
71fec9ad3aSJerin Jacob #define MAX_SND_QUEUES_PER_QS           8
72fec9ad3aSJerin Jacob #define MAX_CMP_QUEUES_PER_QS           8
73fec9ad3aSJerin Jacob 
74fec9ad3aSJerin Jacob #define NICVF_INTR_CQ_SHIFT             0
75fec9ad3aSJerin Jacob #define NICVF_INTR_SQ_SHIFT             8
76fec9ad3aSJerin Jacob #define NICVF_INTR_RBDR_SHIFT           16
77fec9ad3aSJerin Jacob #define NICVF_INTR_PKT_DROP_SHIFT       20
78fec9ad3aSJerin Jacob #define NICVF_INTR_TCP_TIMER_SHIFT      21
79fec9ad3aSJerin Jacob #define NICVF_INTR_MBOX_SHIFT           22
80fec9ad3aSJerin Jacob #define NICVF_INTR_QS_ERR_SHIFT         23
81fec9ad3aSJerin Jacob 
828a946db3SJerin Jacob #define NICVF_QS_RQ_DIS_APAD_SHIFT      22
838a946db3SJerin Jacob 
84fec9ad3aSJerin Jacob #define NICVF_INTR_CQ_MASK              (0xFF << NICVF_INTR_CQ_SHIFT)
85fec9ad3aSJerin Jacob #define NICVF_INTR_SQ_MASK              (0xFF << NICVF_INTR_SQ_SHIFT)
86fec9ad3aSJerin Jacob #define NICVF_INTR_RBDR_MASK            (0x03 << NICVF_INTR_RBDR_SHIFT)
87fec9ad3aSJerin Jacob #define NICVF_INTR_PKT_DROP_MASK        (1 << NICVF_INTR_PKT_DROP_SHIFT)
88fec9ad3aSJerin Jacob #define NICVF_INTR_TCP_TIMER_MASK       (1 << NICVF_INTR_TCP_TIMER_SHIFT)
89fec9ad3aSJerin Jacob #define NICVF_INTR_MBOX_MASK            (1 << NICVF_INTR_MBOX_SHIFT)
90fec9ad3aSJerin Jacob #define NICVF_INTR_QS_ERR_MASK          (1 << NICVF_INTR_QS_ERR_SHIFT)
91fec9ad3aSJerin Jacob #define NICVF_INTR_ALL_MASK             (0x7FFFFF)
92fec9ad3aSJerin Jacob 
93fec9ad3aSJerin Jacob #define NICVF_CQ_WR_FULL                (1ULL << 26)
94fec9ad3aSJerin Jacob #define NICVF_CQ_WR_DISABLE             (1ULL << 25)
95fec9ad3aSJerin Jacob #define NICVF_CQ_WR_FAULT               (1ULL << 24)
96fec9ad3aSJerin Jacob #define NICVF_CQ_ERR_MASK               (NICVF_CQ_WR_FULL |\
97fec9ad3aSJerin Jacob 					 NICVF_CQ_WR_DISABLE |\
98fec9ad3aSJerin Jacob 					 NICVF_CQ_WR_FAULT)
99fec9ad3aSJerin Jacob #define NICVF_CQ_CQE_COUNT_MASK         (0xFFFF)
100fec9ad3aSJerin Jacob 
101fec9ad3aSJerin Jacob #define NICVF_SQ_ERR_STOPPED            (1ULL << 21)
102fec9ad3aSJerin Jacob #define NICVF_SQ_ERR_SEND               (1ULL << 20)
103fec9ad3aSJerin Jacob #define NICVF_SQ_ERR_DPE                (1ULL << 19)
104fec9ad3aSJerin Jacob #define NICVF_SQ_ERR_MASK               (NICVF_SQ_ERR_STOPPED |\
105fec9ad3aSJerin Jacob 					 NICVF_SQ_ERR_SEND |\
106fec9ad3aSJerin Jacob 					 NICVF_SQ_ERR_DPE)
107fec9ad3aSJerin Jacob #define NICVF_SQ_STATUS_STOPPED_BIT     (21)
108fec9ad3aSJerin Jacob 
109fec9ad3aSJerin Jacob #define NICVF_RBDR_FIFO_STATE_SHIFT     (62)
110fec9ad3aSJerin Jacob #define NICVF_RBDR_FIFO_STATE_MASK      (3ULL << NICVF_RBDR_FIFO_STATE_SHIFT)
111fec9ad3aSJerin Jacob #define NICVF_RBDR_COUNT_MASK           (0x7FFFF)
112fec9ad3aSJerin Jacob 
113fec9ad3aSJerin Jacob /* Queue reset */
114fec9ad3aSJerin Jacob #define NICVF_CQ_RESET                  (1ULL << 41)
115fec9ad3aSJerin Jacob #define NICVF_SQ_RESET                  (1ULL << 17)
116fec9ad3aSJerin Jacob #define NICVF_RBDR_RESET                (1ULL << 43)
117fec9ad3aSJerin Jacob 
118fec9ad3aSJerin Jacob /* RSS constants */
119fec9ad3aSJerin Jacob #define NIC_MAX_RSS_HASH_BITS           (8)
120fec9ad3aSJerin Jacob #define NIC_MAX_RSS_IDR_TBL_SIZE        (1 << NIC_MAX_RSS_HASH_BITS)
121fec9ad3aSJerin Jacob #define RSS_HASH_KEY_SIZE               (5) /* 320 bit key */
122fec9ad3aSJerin Jacob #define RSS_HASH_KEY_BYTE_SIZE          (40) /* 320 bit key */
123fec9ad3aSJerin Jacob 
124fec9ad3aSJerin Jacob #define RSS_L2_EXTENDED_HASH_ENA        (1 << 0)
125fec9ad3aSJerin Jacob #define RSS_IP_ENA                      (1 << 1)
126fec9ad3aSJerin Jacob #define RSS_TCP_ENA                     (1 << 2)
127fec9ad3aSJerin Jacob #define RSS_TCP_SYN_ENA                 (1 << 3)
128fec9ad3aSJerin Jacob #define RSS_UDP_ENA                     (1 << 4)
129fec9ad3aSJerin Jacob #define RSS_L4_EXTENDED_ENA             (1 << 5)
130fec9ad3aSJerin Jacob #define RSS_L3_BI_DIRECTION_ENA         (1 << 7)
131fec9ad3aSJerin Jacob #define RSS_L4_BI_DIRECTION_ENA         (1 << 8)
132fec9ad3aSJerin Jacob #define RSS_TUN_VXLAN_ENA               (1 << 9)
133fec9ad3aSJerin Jacob #define RSS_TUN_GENEVE_ENA              (1 << 10)
134fec9ad3aSJerin Jacob #define RSS_TUN_NVGRE_ENA               (1 << 11)
135fec9ad3aSJerin Jacob 
136fec9ad3aSJerin Jacob #define RBDR_QUEUE_SZ_8K                (8 * 1024)
137fec9ad3aSJerin Jacob #define RBDR_QUEUE_SZ_16K               (16 * 1024)
138fec9ad3aSJerin Jacob #define RBDR_QUEUE_SZ_32K               (32 * 1024)
139fec9ad3aSJerin Jacob #define RBDR_QUEUE_SZ_64K               (64 * 1024)
140fec9ad3aSJerin Jacob #define RBDR_QUEUE_SZ_128K              (128 * 1024)
141fec9ad3aSJerin Jacob #define RBDR_QUEUE_SZ_256K              (256 * 1024)
142fec9ad3aSJerin Jacob #define RBDR_QUEUE_SZ_512K              (512 * 1024)
143d1d861efSKamil Rytarowski #define RBDR_QUEUE_SZ_MAX               RBDR_QUEUE_SZ_512K
144fec9ad3aSJerin Jacob 
145fec9ad3aSJerin Jacob #define RBDR_SIZE_SHIFT                 (13) /* 8k */
146fec9ad3aSJerin Jacob 
147fec9ad3aSJerin Jacob #define SND_QUEUE_SZ_1K                 (1 * 1024)
148fec9ad3aSJerin Jacob #define SND_QUEUE_SZ_2K                 (2 * 1024)
149fec9ad3aSJerin Jacob #define SND_QUEUE_SZ_4K                 (4 * 1024)
150fec9ad3aSJerin Jacob #define SND_QUEUE_SZ_8K                 (8 * 1024)
151fec9ad3aSJerin Jacob #define SND_QUEUE_SZ_16K                (16 * 1024)
152fec9ad3aSJerin Jacob #define SND_QUEUE_SZ_32K                (32 * 1024)
153fec9ad3aSJerin Jacob #define SND_QUEUE_SZ_64K                (64 * 1024)
154d1d861efSKamil Rytarowski #define SND_QUEUE_SZ_MAX                SND_QUEUE_SZ_64K
155fec9ad3aSJerin Jacob 
156fec9ad3aSJerin Jacob #define SND_QSIZE_SHIFT                 (10) /* 1k */
157fec9ad3aSJerin Jacob 
158fec9ad3aSJerin Jacob #define CMP_QUEUE_SZ_1K                 (1 * 1024)
159fec9ad3aSJerin Jacob #define CMP_QUEUE_SZ_2K                 (2 * 1024)
160fec9ad3aSJerin Jacob #define CMP_QUEUE_SZ_4K                 (4 * 1024)
161fec9ad3aSJerin Jacob #define CMP_QUEUE_SZ_8K                 (8 * 1024)
162fec9ad3aSJerin Jacob #define CMP_QUEUE_SZ_16K                (16 * 1024)
163fec9ad3aSJerin Jacob #define CMP_QUEUE_SZ_32K                (32 * 1024)
164fec9ad3aSJerin Jacob #define CMP_QUEUE_SZ_64K                (64 * 1024)
165d1d861efSKamil Rytarowski #define CMP_QUEUE_SZ_MAX                CMP_QUEUE_SZ_64K
166fec9ad3aSJerin Jacob 
167fec9ad3aSJerin Jacob #define CMP_QSIZE_SHIFT                 (10) /* 1k */
168fec9ad3aSJerin Jacob 
169fec9ad3aSJerin Jacob #define NICVF_QSIZE_MIN_VAL             (0)
170fec9ad3aSJerin Jacob #define NICVF_QSIZE_MAX_VAL             (6)
171fec9ad3aSJerin Jacob 
172fec9ad3aSJerin Jacob /* Min/Max packet size */
173fec9ad3aSJerin Jacob #define NIC_HW_MIN_FRS                  (64)
174c77875fbSNitin Saxena /* ETH_HLEN+ETH_FCS_LEN+2*VLAN_HLEN */
175c77875fbSNitin Saxena #define NIC_HW_L2_OVERHEAD              (26)
176c77875fbSNitin Saxena #define NIC_HW_MAX_MTU                  (9190)
177c77875fbSNitin Saxena #define NIC_HW_MAX_FRS                  (NIC_HW_MAX_MTU + NIC_HW_L2_OVERHEAD)
178fec9ad3aSJerin Jacob #define NIC_HW_MAX_SEGS                 (12)
179*d2869184SSteve Yang #define NIC_HW_L2_MAX_LEN		(RTE_ETHER_MTU + NIC_HW_L2_OVERHEAD)
180fec9ad3aSJerin Jacob 
181fec9ad3aSJerin Jacob /* Descriptor alignments */
182fec9ad3aSJerin Jacob #define NICVF_RBDR_BASE_ALIGN_BYTES     (128) /* 7 bits */
183fec9ad3aSJerin Jacob #define NICVF_CQ_BASE_ALIGN_BYTES       (512) /* 9 bits */
184fec9ad3aSJerin Jacob #define NICVF_SQ_BASE_ALIGN_BYTES       (128) /* 7 bits */
185fec9ad3aSJerin Jacob 
186fec9ad3aSJerin Jacob #define NICVF_CQE_RBPTR_WORD            (6)
187fec9ad3aSJerin Jacob #define NICVF_CQE_RX2_RBPTR_WORD        (7)
188fec9ad3aSJerin Jacob 
189fec9ad3aSJerin Jacob #define NICVF_STATIC_ASSERT(s) _Static_assert(s, #s)
19010b0e74fSKamil Rytarowski #define assert_primary(nic) assert((nic)->sqs_mode == 0)
191fec9ad3aSJerin Jacob 
192df6e0a06SSantosh Shukla typedef uint64_t nicvf_iova_addr_t;
193fec9ad3aSJerin Jacob 
194fec9ad3aSJerin Jacob /* vNIC HW Enumerations */
195fec9ad3aSJerin Jacob 
196fec9ad3aSJerin Jacob enum nic_send_ld_type_e {
197fec9ad3aSJerin Jacob 	NIC_SEND_LD_TYPE_E_LDD,
198fec9ad3aSJerin Jacob 	NIC_SEND_LD_TYPE_E_LDT,
199fec9ad3aSJerin Jacob 	NIC_SEND_LD_TYPE_E_LDWB,
200fec9ad3aSJerin Jacob 	NIC_SEND_LD_TYPE_E_ENUM_LAST,
201fec9ad3aSJerin Jacob };
202fec9ad3aSJerin Jacob 
203fec9ad3aSJerin Jacob enum ether_type_algorithm {
204fec9ad3aSJerin Jacob 	ETYPE_ALG_NONE,
205fec9ad3aSJerin Jacob 	ETYPE_ALG_SKIP,
206fec9ad3aSJerin Jacob 	ETYPE_ALG_ENDPARSE,
207fec9ad3aSJerin Jacob 	ETYPE_ALG_VLAN,
208fec9ad3aSJerin Jacob 	ETYPE_ALG_VLAN_STRIP,
209fec9ad3aSJerin Jacob };
210fec9ad3aSJerin Jacob 
211fec9ad3aSJerin Jacob enum layer3_type {
212fec9ad3aSJerin Jacob 	L3TYPE_NONE,
213fec9ad3aSJerin Jacob 	L3TYPE_GRH,
214fec9ad3aSJerin Jacob 	L3TYPE_IPV4 = 0x4,
215fec9ad3aSJerin Jacob 	L3TYPE_IPV4_OPTIONS = 0x5,
216fec9ad3aSJerin Jacob 	L3TYPE_IPV6 = 0x6,
217fec9ad3aSJerin Jacob 	L3TYPE_IPV6_OPTIONS = 0x7,
218fec9ad3aSJerin Jacob 	L3TYPE_ET_STOP = 0xD,
219fec9ad3aSJerin Jacob 	L3TYPE_OTHER = 0xE,
220fec9ad3aSJerin Jacob };
221fec9ad3aSJerin Jacob 
222fec9ad3aSJerin Jacob #define NICVF_L3TYPE_OPTIONS_MASK	((uint8_t)1)
223fec9ad3aSJerin Jacob #define NICVF_L3TYPE_IPVX_MASK		((uint8_t)0x06)
224fec9ad3aSJerin Jacob 
225fec9ad3aSJerin Jacob enum layer4_type {
226fec9ad3aSJerin Jacob 	L4TYPE_NONE,
227fec9ad3aSJerin Jacob 	L4TYPE_IPSEC_ESP,
228fec9ad3aSJerin Jacob 	L4TYPE_IPFRAG,
229fec9ad3aSJerin Jacob 	L4TYPE_IPCOMP,
230fec9ad3aSJerin Jacob 	L4TYPE_TCP,
231fec9ad3aSJerin Jacob 	L4TYPE_UDP,
232fec9ad3aSJerin Jacob 	L4TYPE_SCTP,
233fec9ad3aSJerin Jacob 	L4TYPE_GRE,
234fec9ad3aSJerin Jacob 	L4TYPE_ROCE_BTH,
235fec9ad3aSJerin Jacob 	L4TYPE_OTHER = 0xE,
236fec9ad3aSJerin Jacob };
237fec9ad3aSJerin Jacob 
238fec9ad3aSJerin Jacob /* CPI and RSSI configuration */
239fec9ad3aSJerin Jacob enum cpi_algorithm_type {
240fec9ad3aSJerin Jacob 	CPI_ALG_NONE,
241fec9ad3aSJerin Jacob 	CPI_ALG_VLAN,
242fec9ad3aSJerin Jacob 	CPI_ALG_VLAN16,
243fec9ad3aSJerin Jacob 	CPI_ALG_DIFF,
244fec9ad3aSJerin Jacob };
245fec9ad3aSJerin Jacob 
246fec9ad3aSJerin Jacob enum rss_algorithm_type {
247fec9ad3aSJerin Jacob 	RSS_ALG_NONE,
248fec9ad3aSJerin Jacob 	RSS_ALG_PORT,
249fec9ad3aSJerin Jacob 	RSS_ALG_IP,
250fec9ad3aSJerin Jacob 	RSS_ALG_TCP_IP,
251fec9ad3aSJerin Jacob 	RSS_ALG_UDP_IP,
252fec9ad3aSJerin Jacob 	RSS_ALG_SCTP_IP,
253fec9ad3aSJerin Jacob 	RSS_ALG_GRE_IP,
254fec9ad3aSJerin Jacob 	RSS_ALG_ROCE,
255fec9ad3aSJerin Jacob };
256fec9ad3aSJerin Jacob 
257fec9ad3aSJerin Jacob enum rss_hash_cfg {
258fec9ad3aSJerin Jacob 	RSS_HASH_L2ETC,
259fec9ad3aSJerin Jacob 	RSS_HASH_IP,
260fec9ad3aSJerin Jacob 	RSS_HASH_TCP,
261fec9ad3aSJerin Jacob 	RSS_HASH_TCP_SYN_DIS,
262fec9ad3aSJerin Jacob 	RSS_HASH_UDP,
263fec9ad3aSJerin Jacob 	RSS_HASH_L4ETC,
264fec9ad3aSJerin Jacob 	RSS_HASH_ROCE,
265fec9ad3aSJerin Jacob 	RSS_L3_BIDI,
266fec9ad3aSJerin Jacob 	RSS_L4_BIDI,
267fec9ad3aSJerin Jacob };
268fec9ad3aSJerin Jacob 
269fec9ad3aSJerin Jacob /* Completion queue entry types */
270fec9ad3aSJerin Jacob enum cqe_type {
271fec9ad3aSJerin Jacob 	CQE_TYPE_INVALID,
272fec9ad3aSJerin Jacob 	CQE_TYPE_RX = 0x2,
273fec9ad3aSJerin Jacob 	CQE_TYPE_RX_SPLIT = 0x3,
274fec9ad3aSJerin Jacob 	CQE_TYPE_RX_TCP = 0x4,
275fec9ad3aSJerin Jacob 	CQE_TYPE_SEND = 0x8,
276fec9ad3aSJerin Jacob 	CQE_TYPE_SEND_PTP = 0x9,
277fec9ad3aSJerin Jacob };
278fec9ad3aSJerin Jacob 
279fec9ad3aSJerin Jacob enum cqe_rx_tcp_status {
280fec9ad3aSJerin Jacob 	CQE_RX_STATUS_VALID_TCP_CNXT,
281fec9ad3aSJerin Jacob 	CQE_RX_STATUS_INVALID_TCP_CNXT = 0x0F,
282fec9ad3aSJerin Jacob };
283fec9ad3aSJerin Jacob 
284fec9ad3aSJerin Jacob enum cqe_send_status {
285fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_GOOD,
286fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_DESC_FAULT = 0x01,
287fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_HDR_CONS_ERR = 0x11,
288fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_SUBDESC_ERR = 0x12,
289fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_IMM_SIZE_OFLOW = 0x80,
290fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_CRC_SEQ_ERR = 0x81,
291fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_DATA_SEQ_ERR = 0x82,
292fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_MEM_SEQ_ERR = 0x83,
293fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_LOCK_VIOL = 0x84,
294fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_LOCK_UFLOW = 0x85,
295fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_DATA_FAULT = 0x86,
296fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_TSTMP_CONFLICT = 0x87,
297fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_TSTMP_TIMEOUT = 0x88,
298fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_MEM_FAULT = 0x89,
299fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_CSUM_OVERLAP = 0x8A,
300fec9ad3aSJerin Jacob 	CQE_SEND_STATUS_CSUM_OVERFLOW = 0x8B,
301fec9ad3aSJerin Jacob };
302fec9ad3aSJerin Jacob 
303fec9ad3aSJerin Jacob enum cqe_rx_tcp_end_reason {
304fec9ad3aSJerin Jacob 	CQE_RX_TCP_END_FIN_FLAG_DET,
305fec9ad3aSJerin Jacob 	CQE_RX_TCP_END_INVALID_FLAG,
306fec9ad3aSJerin Jacob 	CQE_RX_TCP_END_TIMEOUT,
307fec9ad3aSJerin Jacob 	CQE_RX_TCP_END_OUT_OF_SEQ,
308fec9ad3aSJerin Jacob 	CQE_RX_TCP_END_PKT_ERR,
309fec9ad3aSJerin Jacob 	CQE_RX_TCP_END_QS_DISABLED = 0x0F,
310fec9ad3aSJerin Jacob };
311fec9ad3aSJerin Jacob 
312fec9ad3aSJerin Jacob /* Packet protocol level error enumeration */
313fec9ad3aSJerin Jacob enum cqe_rx_err_level {
314fec9ad3aSJerin Jacob 	CQE_RX_ERRLVL_RE,
315fec9ad3aSJerin Jacob 	CQE_RX_ERRLVL_L2,
316fec9ad3aSJerin Jacob 	CQE_RX_ERRLVL_L3,
317fec9ad3aSJerin Jacob 	CQE_RX_ERRLVL_L4,
318fec9ad3aSJerin Jacob };
319fec9ad3aSJerin Jacob 
320fec9ad3aSJerin Jacob /* Packet protocol level error type enumeration */
321fec9ad3aSJerin Jacob enum cqe_rx_err_opcode {
322fec9ad3aSJerin Jacob 	CQE_RX_ERR_RE_NONE,
323fec9ad3aSJerin Jacob 	CQE_RX_ERR_RE_PARTIAL,
324fec9ad3aSJerin Jacob 	CQE_RX_ERR_RE_JABBER,
325fec9ad3aSJerin Jacob 	CQE_RX_ERR_RE_FCS = 0x7,
326fec9ad3aSJerin Jacob 	CQE_RX_ERR_RE_TERMINATE = 0x9,
327fec9ad3aSJerin Jacob 	CQE_RX_ERR_RE_RX_CTL = 0xb,
328fec9ad3aSJerin Jacob 	CQE_RX_ERR_PREL2_ERR = 0x1f,
329fec9ad3aSJerin Jacob 	CQE_RX_ERR_L2_FRAGMENT = 0x20,
330fec9ad3aSJerin Jacob 	CQE_RX_ERR_L2_OVERRUN = 0x21,
331fec9ad3aSJerin Jacob 	CQE_RX_ERR_L2_PFCS = 0x22,
332fec9ad3aSJerin Jacob 	CQE_RX_ERR_L2_PUNY = 0x23,
333fec9ad3aSJerin Jacob 	CQE_RX_ERR_L2_MAL = 0x24,
334fec9ad3aSJerin Jacob 	CQE_RX_ERR_L2_OVERSIZE = 0x25,
335fec9ad3aSJerin Jacob 	CQE_RX_ERR_L2_UNDERSIZE = 0x26,
336fec9ad3aSJerin Jacob 	CQE_RX_ERR_L2_LENMISM = 0x27,
337fec9ad3aSJerin Jacob 	CQE_RX_ERR_L2_PCLP = 0x28,
338fec9ad3aSJerin Jacob 	CQE_RX_ERR_IP_NOT = 0x41,
339fec9ad3aSJerin Jacob 	CQE_RX_ERR_IP_CHK = 0x42,
340fec9ad3aSJerin Jacob 	CQE_RX_ERR_IP_MAL = 0x43,
341fec9ad3aSJerin Jacob 	CQE_RX_ERR_IP_MALD = 0x44,
342fec9ad3aSJerin Jacob 	CQE_RX_ERR_IP_HOP = 0x45,
343fec9ad3aSJerin Jacob 	CQE_RX_ERR_L3_ICRC = 0x46,
344fec9ad3aSJerin Jacob 	CQE_RX_ERR_L3_PCLP = 0x47,
345fec9ad3aSJerin Jacob 	CQE_RX_ERR_L4_MAL = 0x61,
346fec9ad3aSJerin Jacob 	CQE_RX_ERR_L4_CHK = 0x62,
347fec9ad3aSJerin Jacob 	CQE_RX_ERR_UDP_LEN = 0x63,
348fec9ad3aSJerin Jacob 	CQE_RX_ERR_L4_PORT = 0x64,
349fec9ad3aSJerin Jacob 	CQE_RX_ERR_TCP_FLAG = 0x65,
350fec9ad3aSJerin Jacob 	CQE_RX_ERR_TCP_OFFSET = 0x66,
351fec9ad3aSJerin Jacob 	CQE_RX_ERR_L4_PCLP = 0x67,
352fec9ad3aSJerin Jacob 	CQE_RX_ERR_RBDR_TRUNC = 0x70,
353fec9ad3aSJerin Jacob };
354fec9ad3aSJerin Jacob 
355fec9ad3aSJerin Jacob enum send_l4_csum_type {
356fec9ad3aSJerin Jacob 	SEND_L4_CSUM_DISABLE,
357fec9ad3aSJerin Jacob 	SEND_L4_CSUM_UDP,
358fec9ad3aSJerin Jacob 	SEND_L4_CSUM_TCP,
359fec9ad3aSJerin Jacob };
360fec9ad3aSJerin Jacob 
361fec9ad3aSJerin Jacob enum send_crc_alg {
362fec9ad3aSJerin Jacob 	SEND_CRCALG_CRC32,
363fec9ad3aSJerin Jacob 	SEND_CRCALG_CRC32C,
364fec9ad3aSJerin Jacob 	SEND_CRCALG_ICRC,
365fec9ad3aSJerin Jacob };
366fec9ad3aSJerin Jacob 
367fec9ad3aSJerin Jacob enum send_load_type {
368fec9ad3aSJerin Jacob 	SEND_LD_TYPE_LDD,
369fec9ad3aSJerin Jacob 	SEND_LD_TYPE_LDT,
370fec9ad3aSJerin Jacob 	SEND_LD_TYPE_LDWB,
371fec9ad3aSJerin Jacob };
372fec9ad3aSJerin Jacob 
373fec9ad3aSJerin Jacob enum send_mem_alg_type {
374fec9ad3aSJerin Jacob 	SEND_MEMALG_SET,
375fec9ad3aSJerin Jacob 	SEND_MEMALG_ADD = 0x08,
376fec9ad3aSJerin Jacob 	SEND_MEMALG_SUB = 0x09,
377fec9ad3aSJerin Jacob 	SEND_MEMALG_ADDLEN = 0x0A,
378fec9ad3aSJerin Jacob 	SEND_MEMALG_SUBLEN = 0x0B,
379fec9ad3aSJerin Jacob };
380fec9ad3aSJerin Jacob 
381fec9ad3aSJerin Jacob enum send_mem_dsz_type {
382fec9ad3aSJerin Jacob 	SEND_MEMDSZ_B64,
383fec9ad3aSJerin Jacob 	SEND_MEMDSZ_B32,
384fec9ad3aSJerin Jacob 	SEND_MEMDSZ_B8 = 0x03,
385fec9ad3aSJerin Jacob };
386fec9ad3aSJerin Jacob 
387fec9ad3aSJerin Jacob enum sq_subdesc_type {
388fec9ad3aSJerin Jacob 	SQ_DESC_TYPE_INVALID,
389fec9ad3aSJerin Jacob 	SQ_DESC_TYPE_HEADER,
390fec9ad3aSJerin Jacob 	SQ_DESC_TYPE_CRC,
391fec9ad3aSJerin Jacob 	SQ_DESC_TYPE_IMMEDIATE,
392fec9ad3aSJerin Jacob 	SQ_DESC_TYPE_GATHER,
393fec9ad3aSJerin Jacob 	SQ_DESC_TYPE_MEMORY,
394fec9ad3aSJerin Jacob };
395fec9ad3aSJerin Jacob 
396fec9ad3aSJerin Jacob enum l3_type_t {
397fec9ad3aSJerin Jacob 	L3_NONE,
398fec9ad3aSJerin Jacob 	L3_IPV4		= 0x04,
399fec9ad3aSJerin Jacob 	L3_IPV4_OPT	= 0x05,
400fec9ad3aSJerin Jacob 	L3_IPV6		= 0x06,
401fec9ad3aSJerin Jacob 	L3_IPV6_OPT	= 0x07,
402fec9ad3aSJerin Jacob 	L3_ET_STOP	= 0x0D,
403fec9ad3aSJerin Jacob 	L3_OTHER	= 0x0E
404fec9ad3aSJerin Jacob };
405fec9ad3aSJerin Jacob 
406fec9ad3aSJerin Jacob enum l4_type_t {
407fec9ad3aSJerin Jacob 	L4_NONE,
408fec9ad3aSJerin Jacob 	L4_IPSEC_ESP	= 0x01,
409fec9ad3aSJerin Jacob 	L4_IPFRAG	= 0x02,
410fec9ad3aSJerin Jacob 	L4_IPCOMP	= 0x03,
411fec9ad3aSJerin Jacob 	L4_TCP		= 0x04,
412fec9ad3aSJerin Jacob 	L4_UDP_PASS1	= 0x05,
413fec9ad3aSJerin Jacob 	L4_GRE		= 0x07,
414fec9ad3aSJerin Jacob 	L4_UDP_PASS2	= 0x08,
415fec9ad3aSJerin Jacob 	L4_UDP_GENEVE	= 0x09,
416fec9ad3aSJerin Jacob 	L4_UDP_VXLAN	= 0x0A,
417fec9ad3aSJerin Jacob 	L4_NVGRE	= 0x0C,
418fec9ad3aSJerin Jacob 	L4_OTHER	= 0x0E
419fec9ad3aSJerin Jacob };
420fec9ad3aSJerin Jacob 
421fec9ad3aSJerin Jacob enum vlan_strip {
422fec9ad3aSJerin Jacob 	NO_STRIP,
423fec9ad3aSJerin Jacob 	STRIP_FIRST_VLAN,
424fec9ad3aSJerin Jacob 	STRIP_SECOND_VLAN,
425fec9ad3aSJerin Jacob 	STRIP_RESERV,
426fec9ad3aSJerin Jacob };
427fec9ad3aSJerin Jacob 
428fec9ad3aSJerin Jacob enum rbdr_state {
429fec9ad3aSJerin Jacob 	RBDR_FIFO_STATE_INACTIVE,
430fec9ad3aSJerin Jacob 	RBDR_FIFO_STATE_ACTIVE,
431fec9ad3aSJerin Jacob 	RBDR_FIFO_STATE_RESET,
432fec9ad3aSJerin Jacob 	RBDR_FIFO_STATE_FAIL,
433fec9ad3aSJerin Jacob };
434fec9ad3aSJerin Jacob 
435fec9ad3aSJerin Jacob enum rq_cache_allocation {
436fec9ad3aSJerin Jacob 	RQ_CACHE_ALLOC_OFF,
437fec9ad3aSJerin Jacob 	RQ_CACHE_ALLOC_ALL,
438fec9ad3aSJerin Jacob 	RQ_CACHE_ALLOC_FIRST,
439fec9ad3aSJerin Jacob 	RQ_CACHE_ALLOC_TWO,
440fec9ad3aSJerin Jacob };
441fec9ad3aSJerin Jacob 
442fec9ad3aSJerin Jacob enum cq_rx_errlvl_e {
443fec9ad3aSJerin Jacob 	CQ_ERRLVL_MAC,
444fec9ad3aSJerin Jacob 	CQ_ERRLVL_L2,
445fec9ad3aSJerin Jacob 	CQ_ERRLVL_L3,
446fec9ad3aSJerin Jacob 	CQ_ERRLVL_L4,
447fec9ad3aSJerin Jacob };
448fec9ad3aSJerin Jacob 
449fec9ad3aSJerin Jacob enum cq_rx_errop_e {
450fec9ad3aSJerin Jacob 	CQ_RX_ERROP_RE_NONE,
451fec9ad3aSJerin Jacob 	CQ_RX_ERROP_RE_PARTIAL = 0x1,
452fec9ad3aSJerin Jacob 	CQ_RX_ERROP_RE_JABBER = 0x2,
453fec9ad3aSJerin Jacob 	CQ_RX_ERROP_RE_FCS = 0x7,
454fec9ad3aSJerin Jacob 	CQ_RX_ERROP_RE_TERMINATE = 0x9,
455fec9ad3aSJerin Jacob 	CQ_RX_ERROP_RE_RX_CTL = 0xb,
456fec9ad3aSJerin Jacob 	CQ_RX_ERROP_PREL2_ERR = 0x1f,
457fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L2_FRAGMENT = 0x20,
458fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L2_OVERRUN = 0x21,
459fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L2_PFCS = 0x22,
460fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L2_PUNY = 0x23,
461fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L2_MAL = 0x24,
462fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L2_OVERSIZE = 0x25,
463fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L2_UNDERSIZE = 0x26,
464fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L2_LENMISM = 0x27,
465fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L2_PCLP = 0x28,
466fec9ad3aSJerin Jacob 	CQ_RX_ERROP_IP_NOT = 0x41,
467fec9ad3aSJerin Jacob 	CQ_RX_ERROP_IP_CSUM_ERR = 0x42,
468fec9ad3aSJerin Jacob 	CQ_RX_ERROP_IP_MAL = 0x43,
469fec9ad3aSJerin Jacob 	CQ_RX_ERROP_IP_MALD = 0x44,
470fec9ad3aSJerin Jacob 	CQ_RX_ERROP_IP_HOP = 0x45,
471fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L3_ICRC = 0x46,
472fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L3_PCLP = 0x47,
473fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L4_MAL = 0x61,
474fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L4_CHK = 0x62,
475fec9ad3aSJerin Jacob 	CQ_RX_ERROP_UDP_LEN = 0x63,
476fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L4_PORT = 0x64,
477fec9ad3aSJerin Jacob 	CQ_RX_ERROP_TCP_FLAG = 0x65,
478fec9ad3aSJerin Jacob 	CQ_RX_ERROP_TCP_OFFSET = 0x66,
479fec9ad3aSJerin Jacob 	CQ_RX_ERROP_L4_PCLP = 0x67,
480fec9ad3aSJerin Jacob 	CQ_RX_ERROP_RBDR_TRUNC = 0x70,
481fec9ad3aSJerin Jacob };
482fec9ad3aSJerin Jacob 
483fec9ad3aSJerin Jacob enum cq_tx_errop_e {
484fec9ad3aSJerin Jacob 	CQ_TX_ERROP_GOOD,
485fec9ad3aSJerin Jacob 	CQ_TX_ERROP_DESC_FAULT = 0x10,
486fec9ad3aSJerin Jacob 	CQ_TX_ERROP_HDR_CONS_ERR = 0x11,
487fec9ad3aSJerin Jacob 	CQ_TX_ERROP_SUBDC_ERR = 0x12,
488fec9ad3aSJerin Jacob 	CQ_TX_ERROP_IMM_SIZE_OFLOW = 0x80,
489fec9ad3aSJerin Jacob 	CQ_TX_ERROP_DATA_SEQUENCE_ERR = 0x81,
490fec9ad3aSJerin Jacob 	CQ_TX_ERROP_MEM_SEQUENCE_ERR = 0x82,
491fec9ad3aSJerin Jacob 	CQ_TX_ERROP_LOCK_VIOL = 0x83,
492fec9ad3aSJerin Jacob 	CQ_TX_ERROP_DATA_FAULT = 0x84,
493fec9ad3aSJerin Jacob 	CQ_TX_ERROP_TSTMP_CONFLICT = 0x85,
494fec9ad3aSJerin Jacob 	CQ_TX_ERROP_TSTMP_TIMEOUT = 0x86,
495fec9ad3aSJerin Jacob 	CQ_TX_ERROP_MEM_FAULT = 0x87,
496fec9ad3aSJerin Jacob 	CQ_TX_ERROP_CK_OVERLAP = 0x88,
497fec9ad3aSJerin Jacob 	CQ_TX_ERROP_CK_OFLOW = 0x89,
498fec9ad3aSJerin Jacob 	CQ_TX_ERROP_ENUM_LAST = 0x8a,
499fec9ad3aSJerin Jacob };
500fec9ad3aSJerin Jacob 
501fec9ad3aSJerin Jacob enum rq_sq_stats_reg_offset {
502fec9ad3aSJerin Jacob 	RQ_SQ_STATS_OCTS,
503fec9ad3aSJerin Jacob 	RQ_SQ_STATS_PKTS,
504fec9ad3aSJerin Jacob };
505fec9ad3aSJerin Jacob 
506fec9ad3aSJerin Jacob enum nic_stat_vnic_rx_e {
507fec9ad3aSJerin Jacob 	RX_OCTS,
508fec9ad3aSJerin Jacob 	RX_UCAST,
509fec9ad3aSJerin Jacob 	RX_BCAST,
510fec9ad3aSJerin Jacob 	RX_MCAST,
511fec9ad3aSJerin Jacob 	RX_RED,
512fec9ad3aSJerin Jacob 	RX_RED_OCTS,
513fec9ad3aSJerin Jacob 	RX_ORUN,
514fec9ad3aSJerin Jacob 	RX_ORUN_OCTS,
515fec9ad3aSJerin Jacob 	RX_FCS,
516fec9ad3aSJerin Jacob 	RX_L2ERR,
517fec9ad3aSJerin Jacob 	RX_DRP_BCAST,
518fec9ad3aSJerin Jacob 	RX_DRP_MCAST,
519fec9ad3aSJerin Jacob 	RX_DRP_L3BCAST,
520fec9ad3aSJerin Jacob 	RX_DRP_L3MCAST,
521fec9ad3aSJerin Jacob };
522fec9ad3aSJerin Jacob 
523fec9ad3aSJerin Jacob enum nic_stat_vnic_tx_e {
524fec9ad3aSJerin Jacob 	TX_OCTS,
525fec9ad3aSJerin Jacob 	TX_UCAST,
526fec9ad3aSJerin Jacob 	TX_BCAST,
527fec9ad3aSJerin Jacob 	TX_MCAST,
528fec9ad3aSJerin Jacob 	TX_DROP,
529fec9ad3aSJerin Jacob };
530fec9ad3aSJerin Jacob 
531262d43feSJerin Jacob /* vNIC HW Register structures */
532262d43feSJerin Jacob 
533262d43feSJerin Jacob typedef union {
534262d43feSJerin Jacob 	uint64_t u64;
535262d43feSJerin Jacob 	struct {
5365ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
537262d43feSJerin Jacob 		uint64_t cqe_type:4;
538262d43feSJerin Jacob 		uint64_t stdn_fault:1;
539262d43feSJerin Jacob 		uint64_t rsvd0:1;
540262d43feSJerin Jacob 		uint64_t rq_qs:7;
541262d43feSJerin Jacob 		uint64_t rq_idx:3;
542262d43feSJerin Jacob 		uint64_t rsvd1:12;
543262d43feSJerin Jacob 		uint64_t rss_alg:4;
544262d43feSJerin Jacob 		uint64_t rsvd2:4;
545262d43feSJerin Jacob 		uint64_t rb_cnt:4;
546262d43feSJerin Jacob 		uint64_t vlan_found:1;
547262d43feSJerin Jacob 		uint64_t vlan_stripped:1;
548262d43feSJerin Jacob 		uint64_t vlan2_found:1;
549262d43feSJerin Jacob 		uint64_t vlan2_stripped:1;
550262d43feSJerin Jacob 		uint64_t l4_type:4;
551262d43feSJerin Jacob 		uint64_t l3_type:4;
552262d43feSJerin Jacob 		uint64_t l2_present:1;
553262d43feSJerin Jacob 		uint64_t err_level:3;
554262d43feSJerin Jacob 		uint64_t err_opcode:8;
555262d43feSJerin Jacob #else
556262d43feSJerin Jacob 		uint64_t err_opcode:8;
557262d43feSJerin Jacob 		uint64_t err_level:3;
558262d43feSJerin Jacob 		uint64_t l2_present:1;
559262d43feSJerin Jacob 		uint64_t l3_type:4;
560262d43feSJerin Jacob 		uint64_t l4_type:4;
561262d43feSJerin Jacob 		uint64_t vlan2_stripped:1;
562262d43feSJerin Jacob 		uint64_t vlan2_found:1;
563262d43feSJerin Jacob 		uint64_t vlan_stripped:1;
564262d43feSJerin Jacob 		uint64_t vlan_found:1;
565262d43feSJerin Jacob 		uint64_t rb_cnt:4;
566262d43feSJerin Jacob 		uint64_t rsvd2:4;
567262d43feSJerin Jacob 		uint64_t rss_alg:4;
568262d43feSJerin Jacob 		uint64_t rsvd1:12;
569262d43feSJerin Jacob 		uint64_t rq_idx:3;
570262d43feSJerin Jacob 		uint64_t rq_qs:7;
571262d43feSJerin Jacob 		uint64_t rsvd0:1;
572262d43feSJerin Jacob 		uint64_t stdn_fault:1;
573262d43feSJerin Jacob 		uint64_t cqe_type:4;
574262d43feSJerin Jacob #endif
575262d43feSJerin Jacob 	};
576262d43feSJerin Jacob } cqe_rx_word0_t;
577262d43feSJerin Jacob 
578262d43feSJerin Jacob typedef union {
579262d43feSJerin Jacob 	uint64_t u64;
580262d43feSJerin Jacob 	struct {
5815ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
582262d43feSJerin Jacob 		uint64_t pkt_len:16;
583262d43feSJerin Jacob 		uint64_t l2_ptr:8;
584262d43feSJerin Jacob 		uint64_t l3_ptr:8;
585262d43feSJerin Jacob 		uint64_t l4_ptr:8;
586262d43feSJerin Jacob 		uint64_t cq_pkt_len:8;
587262d43feSJerin Jacob 		uint64_t align_pad:3;
588262d43feSJerin Jacob 		uint64_t rsvd3:1;
589262d43feSJerin Jacob 		uint64_t chan:12;
590262d43feSJerin Jacob #else
591262d43feSJerin Jacob 		uint64_t chan:12;
592262d43feSJerin Jacob 		uint64_t rsvd3:1;
593262d43feSJerin Jacob 		uint64_t align_pad:3;
594262d43feSJerin Jacob 		uint64_t cq_pkt_len:8;
595262d43feSJerin Jacob 		uint64_t l4_ptr:8;
596262d43feSJerin Jacob 		uint64_t l3_ptr:8;
597262d43feSJerin Jacob 		uint64_t l2_ptr:8;
598262d43feSJerin Jacob 		uint64_t pkt_len:16;
599262d43feSJerin Jacob #endif
600262d43feSJerin Jacob 	};
601262d43feSJerin Jacob } cqe_rx_word1_t;
602262d43feSJerin Jacob 
603262d43feSJerin Jacob typedef union {
604262d43feSJerin Jacob 	uint64_t u64;
605262d43feSJerin Jacob 	struct {
6065ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
607262d43feSJerin Jacob 		uint64_t rss_tag:32;
608262d43feSJerin Jacob 		uint64_t vlan_tci:16;
609262d43feSJerin Jacob 		uint64_t vlan_ptr:8;
610262d43feSJerin Jacob 		uint64_t vlan2_ptr:8;
611262d43feSJerin Jacob #else
612262d43feSJerin Jacob 		uint64_t vlan2_ptr:8;
613262d43feSJerin Jacob 		uint64_t vlan_ptr:8;
614262d43feSJerin Jacob 		uint64_t vlan_tci:16;
615262d43feSJerin Jacob 		uint64_t rss_tag:32;
616262d43feSJerin Jacob #endif
617262d43feSJerin Jacob 	};
618262d43feSJerin Jacob } cqe_rx_word2_t;
619262d43feSJerin Jacob 
620262d43feSJerin Jacob typedef union {
621262d43feSJerin Jacob 	uint64_t u64;
622262d43feSJerin Jacob 	struct {
6235ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
624262d43feSJerin Jacob 		uint16_t rb3_sz;
625262d43feSJerin Jacob 		uint16_t rb2_sz;
626262d43feSJerin Jacob 		uint16_t rb1_sz;
627262d43feSJerin Jacob 		uint16_t rb0_sz;
628262d43feSJerin Jacob #else
629262d43feSJerin Jacob 		uint16_t rb0_sz;
630262d43feSJerin Jacob 		uint16_t rb1_sz;
631262d43feSJerin Jacob 		uint16_t rb2_sz;
632262d43feSJerin Jacob 		uint16_t rb3_sz;
633262d43feSJerin Jacob #endif
634262d43feSJerin Jacob 	};
635262d43feSJerin Jacob } cqe_rx_word3_t;
636262d43feSJerin Jacob 
637262d43feSJerin Jacob typedef union {
638262d43feSJerin Jacob 	uint64_t u64;
639262d43feSJerin Jacob 	struct {
6405ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
641262d43feSJerin Jacob 		uint16_t rb7_sz;
642262d43feSJerin Jacob 		uint16_t rb6_sz;
643262d43feSJerin Jacob 		uint16_t rb5_sz;
644262d43feSJerin Jacob 		uint16_t rb4_sz;
645262d43feSJerin Jacob #else
646262d43feSJerin Jacob 		uint16_t rb4_sz;
647262d43feSJerin Jacob 		uint16_t rb5_sz;
648262d43feSJerin Jacob 		uint16_t rb6_sz;
649262d43feSJerin Jacob 		uint16_t rb7_sz;
650262d43feSJerin Jacob #endif
651262d43feSJerin Jacob 	};
652262d43feSJerin Jacob } cqe_rx_word4_t;
653262d43feSJerin Jacob 
654262d43feSJerin Jacob typedef union {
655262d43feSJerin Jacob 	uint64_t u64;
656262d43feSJerin Jacob 	struct {
6575ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
658262d43feSJerin Jacob 		uint16_t rb11_sz;
659262d43feSJerin Jacob 		uint16_t rb10_sz;
660262d43feSJerin Jacob 		uint16_t rb9_sz;
661262d43feSJerin Jacob 		uint16_t rb8_sz;
662262d43feSJerin Jacob #else
663262d43feSJerin Jacob 		uint16_t rb8_sz;
664262d43feSJerin Jacob 		uint16_t rb9_sz;
665262d43feSJerin Jacob 		uint16_t rb10_sz;
666262d43feSJerin Jacob 		uint16_t rb11_sz;
667262d43feSJerin Jacob #endif
668262d43feSJerin Jacob 	};
669262d43feSJerin Jacob } cqe_rx_word5_t;
670262d43feSJerin Jacob 
671262d43feSJerin Jacob typedef union {
672262d43feSJerin Jacob 	uint64_t u64;
673262d43feSJerin Jacob 	struct {
6745ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
675262d43feSJerin Jacob 		uint64_t vlan_found:1;
676262d43feSJerin Jacob 		uint64_t vlan_stripped:1;
677262d43feSJerin Jacob 		uint64_t vlan2_found:1;
678262d43feSJerin Jacob 		uint64_t vlan2_stripped:1;
679262d43feSJerin Jacob 		uint64_t rsvd2:3;
680262d43feSJerin Jacob 		uint64_t inner_l2:1;
681262d43feSJerin Jacob 		uint64_t inner_l4type:4;
682262d43feSJerin Jacob 		uint64_t inner_l3type:4;
683262d43feSJerin Jacob 		uint64_t vlan_ptr:8;
684262d43feSJerin Jacob 		uint64_t vlan2_ptr:8;
685262d43feSJerin Jacob 		uint64_t rsvd1:8;
686262d43feSJerin Jacob 		uint64_t rsvd0:8;
687262d43feSJerin Jacob 		uint64_t inner_l3ptr:8;
688262d43feSJerin Jacob 		uint64_t inner_l4ptr:8;
689262d43feSJerin Jacob #else
690262d43feSJerin Jacob 		uint64_t inner_l4ptr:8;
691262d43feSJerin Jacob 		uint64_t inner_l3ptr:8;
692262d43feSJerin Jacob 		uint64_t rsvd0:8;
693262d43feSJerin Jacob 		uint64_t rsvd1:8;
694262d43feSJerin Jacob 		uint64_t vlan2_ptr:8;
695262d43feSJerin Jacob 		uint64_t vlan_ptr:8;
696262d43feSJerin Jacob 		uint64_t inner_l3type:4;
697262d43feSJerin Jacob 		uint64_t inner_l4type:4;
698262d43feSJerin Jacob 		uint64_t inner_l2:1;
699262d43feSJerin Jacob 		uint64_t rsvd2:3;
700262d43feSJerin Jacob 		uint64_t vlan2_stripped:1;
701262d43feSJerin Jacob 		uint64_t vlan2_found:1;
702262d43feSJerin Jacob 		uint64_t vlan_stripped:1;
703262d43feSJerin Jacob 		uint64_t vlan_found:1;
704262d43feSJerin Jacob #endif
705262d43feSJerin Jacob 	};
706262d43feSJerin Jacob } cqe_rx2_word6_t;
707262d43feSJerin Jacob 
708262d43feSJerin Jacob struct cqe_rx_t {
709262d43feSJerin Jacob 	cqe_rx_word0_t word0;
710262d43feSJerin Jacob 	cqe_rx_word1_t word1;
711262d43feSJerin Jacob 	cqe_rx_word2_t word2;
712262d43feSJerin Jacob 	cqe_rx_word3_t word3;
713262d43feSJerin Jacob 	cqe_rx_word4_t word4;
714262d43feSJerin Jacob 	cqe_rx_word5_t word5;
715262d43feSJerin Jacob 	cqe_rx2_word6_t word6; /* if NIC_PF_RX_CFG[CQE_RX2_ENA] set */
716262d43feSJerin Jacob };
717262d43feSJerin Jacob 
718262d43feSJerin Jacob struct cqe_rx_tcp_err_t {
7195ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
720262d43feSJerin Jacob 	uint64_t   cqe_type:4; /* W0 */
721262d43feSJerin Jacob 	uint64_t   rsvd0:60;
722262d43feSJerin Jacob 
723262d43feSJerin Jacob 	uint64_t   rsvd1:4; /* W1 */
724262d43feSJerin Jacob 	uint64_t   partial_first:1;
725262d43feSJerin Jacob 	uint64_t   rsvd2:27;
726262d43feSJerin Jacob 	uint64_t   rbdr_bytes:8;
727262d43feSJerin Jacob 	uint64_t   rsvd3:24;
728262d43feSJerin Jacob #else
729262d43feSJerin Jacob 	uint64_t   rsvd0:60;
730262d43feSJerin Jacob 	uint64_t   cqe_type:4;
731262d43feSJerin Jacob 
732262d43feSJerin Jacob 	uint64_t   rsvd3:24;
733262d43feSJerin Jacob 	uint64_t   rbdr_bytes:8;
734262d43feSJerin Jacob 	uint64_t   rsvd2:27;
735262d43feSJerin Jacob 	uint64_t   partial_first:1;
736262d43feSJerin Jacob 	uint64_t   rsvd1:4;
737262d43feSJerin Jacob #endif
738262d43feSJerin Jacob };
739262d43feSJerin Jacob 
740262d43feSJerin Jacob struct cqe_rx_tcp_t {
7415ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
742262d43feSJerin Jacob 	uint64_t   cqe_type:4; /* W0 */
743262d43feSJerin Jacob 	uint64_t   rsvd0:52;
744262d43feSJerin Jacob 	uint64_t   cq_tcp_status:8;
745262d43feSJerin Jacob 
746262d43feSJerin Jacob 	uint64_t   rsvd1:32; /* W1 */
747262d43feSJerin Jacob 	uint64_t   tcp_cntx_bytes:8;
748262d43feSJerin Jacob 	uint64_t   rsvd2:8;
749262d43feSJerin Jacob 	uint64_t   tcp_err_bytes:16;
750262d43feSJerin Jacob #else
751262d43feSJerin Jacob 	uint64_t   cq_tcp_status:8;
752262d43feSJerin Jacob 	uint64_t   rsvd0:52;
753262d43feSJerin Jacob 	uint64_t   cqe_type:4; /* W0 */
754262d43feSJerin Jacob 
755262d43feSJerin Jacob 	uint64_t   tcp_err_bytes:16;
756262d43feSJerin Jacob 	uint64_t   rsvd2:8;
757262d43feSJerin Jacob 	uint64_t   tcp_cntx_bytes:8;
758262d43feSJerin Jacob 	uint64_t   rsvd1:32; /* W1 */
759262d43feSJerin Jacob #endif
760262d43feSJerin Jacob };
761262d43feSJerin Jacob 
762262d43feSJerin Jacob struct cqe_send_t {
7635ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
764262d43feSJerin Jacob 	uint64_t   cqe_type:4; /* W0 */
765262d43feSJerin Jacob 	uint64_t   rsvd0:4;
766262d43feSJerin Jacob 	uint64_t   sqe_ptr:16;
767262d43feSJerin Jacob 	uint64_t   rsvd1:4;
768262d43feSJerin Jacob 	uint64_t   rsvd2:10;
769262d43feSJerin Jacob 	uint64_t   sq_qs:7;
770262d43feSJerin Jacob 	uint64_t   sq_idx:3;
771262d43feSJerin Jacob 	uint64_t   rsvd3:8;
772262d43feSJerin Jacob 	uint64_t   send_status:8;
773262d43feSJerin Jacob 
774262d43feSJerin Jacob 	uint64_t   ptp_timestamp:64; /* W1 */
7755ba41107SJerin Jacob #elif NICVF_BYTE_ORDER == NICVF_LITTLE_ENDIAN
776262d43feSJerin Jacob 	uint64_t   send_status:8;
777262d43feSJerin Jacob 	uint64_t   rsvd3:8;
778262d43feSJerin Jacob 	uint64_t   sq_idx:3;
779262d43feSJerin Jacob 	uint64_t   sq_qs:7;
780262d43feSJerin Jacob 	uint64_t   rsvd2:10;
781262d43feSJerin Jacob 	uint64_t   rsvd1:4;
782262d43feSJerin Jacob 	uint64_t   sqe_ptr:16;
783262d43feSJerin Jacob 	uint64_t   rsvd0:4;
784262d43feSJerin Jacob 	uint64_t   cqe_type:4; /* W0 */
785262d43feSJerin Jacob 
786262d43feSJerin Jacob 	uint64_t   ptp_timestamp:64;
787262d43feSJerin Jacob #endif
788262d43feSJerin Jacob };
789262d43feSJerin Jacob 
790262d43feSJerin Jacob struct cq_entry_type_t {
7915ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
792262d43feSJerin Jacob 	uint64_t cqe_type:4;
793262d43feSJerin Jacob 	uint64_t __pad:60;
794262d43feSJerin Jacob #else
795262d43feSJerin Jacob 	uint64_t __pad:60;
796262d43feSJerin Jacob 	uint64_t cqe_type:4;
797262d43feSJerin Jacob #endif
798262d43feSJerin Jacob };
799262d43feSJerin Jacob 
800262d43feSJerin Jacob union cq_entry_t {
801262d43feSJerin Jacob 	uint64_t u[64];
802262d43feSJerin Jacob 	struct cq_entry_type_t type;
803262d43feSJerin Jacob 	struct cqe_rx_t rx_hdr;
804262d43feSJerin Jacob 	struct cqe_rx_tcp_t rx_tcp_hdr;
805262d43feSJerin Jacob 	struct cqe_rx_tcp_err_t rx_tcp_err_hdr;
806262d43feSJerin Jacob 	struct cqe_send_t cqe_send;
807262d43feSJerin Jacob };
808262d43feSJerin Jacob 
809262d43feSJerin Jacob NICVF_STATIC_ASSERT(sizeof(union cq_entry_t) == 512);
810262d43feSJerin Jacob 
811262d43feSJerin Jacob struct rbdr_entry_t {
8125ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
813262d43feSJerin Jacob 	union {
814262d43feSJerin Jacob 		struct {
815262d43feSJerin Jacob 			uint64_t   rsvd0:15;
816262d43feSJerin Jacob 			uint64_t   buf_addr:42;
817262d43feSJerin Jacob 			uint64_t   cache_align:7;
818262d43feSJerin Jacob 		};
819df6e0a06SSantosh Shukla 		nicvf_iova_addr_t full_addr;
820262d43feSJerin Jacob 	};
821262d43feSJerin Jacob #else
822262d43feSJerin Jacob 	union {
823262d43feSJerin Jacob 		struct {
824262d43feSJerin Jacob 			uint64_t   cache_align:7;
825262d43feSJerin Jacob 			uint64_t   buf_addr:42;
826262d43feSJerin Jacob 			uint64_t   rsvd0:15;
827262d43feSJerin Jacob 		};
828df6e0a06SSantosh Shukla 		nicvf_iova_addr_t full_addr;
829262d43feSJerin Jacob 	};
830262d43feSJerin Jacob #endif
831262d43feSJerin Jacob };
832262d43feSJerin Jacob 
833262d43feSJerin Jacob NICVF_STATIC_ASSERT(sizeof(struct rbdr_entry_t) == sizeof(uint64_t));
834262d43feSJerin Jacob 
835262d43feSJerin Jacob /* TCP reassembly context */
836262d43feSJerin Jacob struct rbe_tcp_cnxt_t {
8375ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
838262d43feSJerin Jacob 	uint64_t   tcp_pkt_cnt:12;
839262d43feSJerin Jacob 	uint64_t   rsvd1:4;
840262d43feSJerin Jacob 	uint64_t   align_hdr_bytes:4;
841262d43feSJerin Jacob 	uint64_t   align_ptr_bytes:4;
842262d43feSJerin Jacob 	uint64_t   ptr_bytes:16;
843262d43feSJerin Jacob 	uint64_t   rsvd2:24;
844262d43feSJerin Jacob 	uint64_t   cqe_type:4;
845262d43feSJerin Jacob 	uint64_t   rsvd0:54;
846262d43feSJerin Jacob 	uint64_t   tcp_end_reason:2;
847262d43feSJerin Jacob 	uint64_t   tcp_status:4;
848262d43feSJerin Jacob #else
849262d43feSJerin Jacob 	uint64_t   tcp_status:4;
850262d43feSJerin Jacob 	uint64_t   tcp_end_reason:2;
851262d43feSJerin Jacob 	uint64_t   rsvd0:54;
852262d43feSJerin Jacob 	uint64_t   cqe_type:4;
853262d43feSJerin Jacob 	uint64_t   rsvd2:24;
854262d43feSJerin Jacob 	uint64_t   ptr_bytes:16;
855262d43feSJerin Jacob 	uint64_t   align_ptr_bytes:4;
856262d43feSJerin Jacob 	uint64_t   align_hdr_bytes:4;
857262d43feSJerin Jacob 	uint64_t   rsvd1:4;
858262d43feSJerin Jacob 	uint64_t   tcp_pkt_cnt:12;
859262d43feSJerin Jacob #endif
860262d43feSJerin Jacob };
861262d43feSJerin Jacob 
862262d43feSJerin Jacob /* Always Big endian */
863262d43feSJerin Jacob struct rx_hdr_t {
864262d43feSJerin Jacob 	uint64_t   opaque:32;
865262d43feSJerin Jacob 	uint64_t   rss_flow:8;
866262d43feSJerin Jacob 	uint64_t   skip_length:6;
867262d43feSJerin Jacob 	uint64_t   disable_rss:1;
868262d43feSJerin Jacob 	uint64_t   disable_tcp_reassembly:1;
869262d43feSJerin Jacob 	uint64_t   nodrop:1;
870262d43feSJerin Jacob 	uint64_t   dest_alg:2;
871262d43feSJerin Jacob 	uint64_t   rsvd0:2;
872262d43feSJerin Jacob 	uint64_t   dest_rq:11;
873262d43feSJerin Jacob };
874262d43feSJerin Jacob 
875262d43feSJerin Jacob struct sq_crc_subdesc {
8765ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
877262d43feSJerin Jacob 	uint64_t    rsvd1:32;
878262d43feSJerin Jacob 	uint64_t    crc_ival:32;
879262d43feSJerin Jacob 	uint64_t    subdesc_type:4;
880262d43feSJerin Jacob 	uint64_t    crc_alg:2;
881262d43feSJerin Jacob 	uint64_t    rsvd0:10;
882262d43feSJerin Jacob 	uint64_t    crc_insert_pos:16;
883262d43feSJerin Jacob 	uint64_t    hdr_start:16;
884262d43feSJerin Jacob 	uint64_t    crc_len:16;
885262d43feSJerin Jacob #else
886262d43feSJerin Jacob 	uint64_t    crc_len:16;
887262d43feSJerin Jacob 	uint64_t    hdr_start:16;
888262d43feSJerin Jacob 	uint64_t    crc_insert_pos:16;
889262d43feSJerin Jacob 	uint64_t    rsvd0:10;
890262d43feSJerin Jacob 	uint64_t    crc_alg:2;
891262d43feSJerin Jacob 	uint64_t    subdesc_type:4;
892262d43feSJerin Jacob 	uint64_t    crc_ival:32;
893262d43feSJerin Jacob 	uint64_t    rsvd1:32;
894262d43feSJerin Jacob #endif
895262d43feSJerin Jacob };
896262d43feSJerin Jacob 
897262d43feSJerin Jacob struct sq_gather_subdesc {
8985ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
899262d43feSJerin Jacob 	uint64_t    subdesc_type:4; /* W0 */
900262d43feSJerin Jacob 	uint64_t    ld_type:2;
901262d43feSJerin Jacob 	uint64_t    rsvd0:42;
902262d43feSJerin Jacob 	uint64_t    size:16;
903262d43feSJerin Jacob 
904262d43feSJerin Jacob 	uint64_t    rsvd1:15; /* W1 */
905262d43feSJerin Jacob 	uint64_t    addr:49;
906262d43feSJerin Jacob #else
907262d43feSJerin Jacob 	uint64_t    size:16;
908262d43feSJerin Jacob 	uint64_t    rsvd0:42;
909262d43feSJerin Jacob 	uint64_t    ld_type:2;
910262d43feSJerin Jacob 	uint64_t    subdesc_type:4; /* W0 */
911262d43feSJerin Jacob 
912262d43feSJerin Jacob 	uint64_t    addr:49;
913262d43feSJerin Jacob 	uint64_t    rsvd1:15; /* W1 */
914262d43feSJerin Jacob #endif
915262d43feSJerin Jacob };
916262d43feSJerin Jacob 
917262d43feSJerin Jacob /* SQ immediate subdescriptor */
918262d43feSJerin Jacob struct sq_imm_subdesc {
9195ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
920262d43feSJerin Jacob 	uint64_t    subdesc_type:4; /* W0 */
921262d43feSJerin Jacob 	uint64_t    rsvd0:46;
922262d43feSJerin Jacob 	uint64_t    len:14;
923262d43feSJerin Jacob 
924262d43feSJerin Jacob 	uint64_t    data:64; /* W1 */
925262d43feSJerin Jacob #else
926262d43feSJerin Jacob 	uint64_t    len:14;
927262d43feSJerin Jacob 	uint64_t    rsvd0:46;
928262d43feSJerin Jacob 	uint64_t    subdesc_type:4; /* W0 */
929262d43feSJerin Jacob 
930262d43feSJerin Jacob 	uint64_t    data:64; /* W1 */
931262d43feSJerin Jacob #endif
932262d43feSJerin Jacob };
933262d43feSJerin Jacob 
934262d43feSJerin Jacob struct sq_mem_subdesc {
9355ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
936262d43feSJerin Jacob 	uint64_t    subdesc_type:4; /* W0 */
937262d43feSJerin Jacob 	uint64_t    mem_alg:4;
938262d43feSJerin Jacob 	uint64_t    mem_dsz:2;
939262d43feSJerin Jacob 	uint64_t    wmem:1;
940262d43feSJerin Jacob 	uint64_t    rsvd0:21;
941262d43feSJerin Jacob 	uint64_t    offset:32;
942262d43feSJerin Jacob 
943262d43feSJerin Jacob 	uint64_t    rsvd1:15; /* W1 */
944262d43feSJerin Jacob 	uint64_t    addr:49;
945262d43feSJerin Jacob #else
946262d43feSJerin Jacob 	uint64_t    offset:32;
947262d43feSJerin Jacob 	uint64_t    rsvd0:21;
948262d43feSJerin Jacob 	uint64_t    wmem:1;
949262d43feSJerin Jacob 	uint64_t    mem_dsz:2;
950262d43feSJerin Jacob 	uint64_t    mem_alg:4;
951262d43feSJerin Jacob 	uint64_t    subdesc_type:4; /* W0 */
952262d43feSJerin Jacob 
953262d43feSJerin Jacob 	uint64_t    addr:49;
954262d43feSJerin Jacob 	uint64_t    rsvd1:15; /* W1 */
955262d43feSJerin Jacob #endif
956262d43feSJerin Jacob };
957262d43feSJerin Jacob 
958262d43feSJerin Jacob struct sq_hdr_subdesc {
9595ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
960262d43feSJerin Jacob 	uint64_t    subdesc_type:4;
961262d43feSJerin Jacob 	uint64_t    tso:1;
962262d43feSJerin Jacob 	uint64_t    post_cqe:1; /* Post CQE on no error also */
963262d43feSJerin Jacob 	uint64_t    dont_send:1;
964262d43feSJerin Jacob 	uint64_t    tstmp:1;
965262d43feSJerin Jacob 	uint64_t    subdesc_cnt:8;
966262d43feSJerin Jacob 	uint64_t    csum_l4:2;
967262d43feSJerin Jacob 	uint64_t    csum_l3:1;
968262d43feSJerin Jacob 	uint64_t    csum_inner_l4:2;
969262d43feSJerin Jacob 	uint64_t    csum_inner_l3:1;
970262d43feSJerin Jacob 	uint64_t    rsvd0:2;
971262d43feSJerin Jacob 	uint64_t    l4_offset:8;
972262d43feSJerin Jacob 	uint64_t    l3_offset:8;
973262d43feSJerin Jacob 	uint64_t    rsvd1:4;
974262d43feSJerin Jacob 	uint64_t    tot_len:20; /* W0 */
975262d43feSJerin Jacob 
976262d43feSJerin Jacob 	uint64_t    rsvd2:24;
977262d43feSJerin Jacob 	uint64_t    inner_l4_offset:8;
978262d43feSJerin Jacob 	uint64_t    inner_l3_offset:8;
979262d43feSJerin Jacob 	uint64_t    tso_start:8;
980262d43feSJerin Jacob 	uint64_t    rsvd3:2;
981262d43feSJerin Jacob 	uint64_t    tso_max_paysize:14; /* W1 */
982262d43feSJerin Jacob #else
983262d43feSJerin Jacob 	uint64_t    tot_len:20;
984262d43feSJerin Jacob 	uint64_t    rsvd1:4;
985262d43feSJerin Jacob 	uint64_t    l3_offset:8;
986262d43feSJerin Jacob 	uint64_t    l4_offset:8;
987262d43feSJerin Jacob 	uint64_t    rsvd0:2;
988262d43feSJerin Jacob 	uint64_t    csum_inner_l3:1;
989262d43feSJerin Jacob 	uint64_t    csum_inner_l4:2;
990262d43feSJerin Jacob 	uint64_t    csum_l3:1;
991262d43feSJerin Jacob 	uint64_t    csum_l4:2;
992262d43feSJerin Jacob 	uint64_t    subdesc_cnt:8;
993262d43feSJerin Jacob 	uint64_t    tstmp:1;
994262d43feSJerin Jacob 	uint64_t    dont_send:1;
995262d43feSJerin Jacob 	uint64_t    post_cqe:1; /* Post CQE on no error also */
996262d43feSJerin Jacob 	uint64_t    tso:1;
997262d43feSJerin Jacob 	uint64_t    subdesc_type:4; /* W0 */
998262d43feSJerin Jacob 
999262d43feSJerin Jacob 	uint64_t    tso_max_paysize:14;
1000262d43feSJerin Jacob 	uint64_t    rsvd3:2;
1001262d43feSJerin Jacob 	uint64_t    tso_start:8;
1002262d43feSJerin Jacob 	uint64_t    inner_l3_offset:8;
1003262d43feSJerin Jacob 	uint64_t    inner_l4_offset:8;
1004262d43feSJerin Jacob 	uint64_t    rsvd2:24; /* W1 */
1005262d43feSJerin Jacob #endif
1006262d43feSJerin Jacob };
1007262d43feSJerin Jacob 
1008262d43feSJerin Jacob /* Each sq entry is 128 bits wide */
1009262d43feSJerin Jacob union sq_entry_t {
1010262d43feSJerin Jacob 	uint64_t buff[2];
1011262d43feSJerin Jacob 	struct sq_hdr_subdesc hdr;
1012262d43feSJerin Jacob 	struct sq_imm_subdesc imm;
1013262d43feSJerin Jacob 	struct sq_gather_subdesc gather;
1014262d43feSJerin Jacob 	struct sq_crc_subdesc crc;
1015262d43feSJerin Jacob 	struct sq_mem_subdesc mem;
1016262d43feSJerin Jacob };
1017262d43feSJerin Jacob 
1018262d43feSJerin Jacob NICVF_STATIC_ASSERT(sizeof(union sq_entry_t) == 16);
1019262d43feSJerin Jacob 
1020262d43feSJerin Jacob /* Queue config register formats */
1021262d43feSJerin Jacob struct rq_cfg { union { struct {
10225ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
1023262d43feSJerin Jacob 	uint64_t reserved_2_63:62;
1024262d43feSJerin Jacob 	uint64_t ena:1;
1025262d43feSJerin Jacob 	uint64_t reserved_0:1;
1026262d43feSJerin Jacob #else
1027262d43feSJerin Jacob 	uint64_t reserved_0:1;
1028262d43feSJerin Jacob 	uint64_t ena:1;
1029262d43feSJerin Jacob 	uint64_t reserved_2_63:62;
1030262d43feSJerin Jacob #endif
1031262d43feSJerin Jacob 	};
1032262d43feSJerin Jacob 	uint64_t value;
1033262d43feSJerin Jacob }; };
1034262d43feSJerin Jacob 
1035262d43feSJerin Jacob struct cq_cfg { union { struct {
10365ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
1037262d43feSJerin Jacob 	uint64_t reserved_43_63:21;
1038262d43feSJerin Jacob 	uint64_t ena:1;
1039262d43feSJerin Jacob 	uint64_t reset:1;
1040262d43feSJerin Jacob 	uint64_t caching:1;
1041262d43feSJerin Jacob 	uint64_t reserved_35_39:5;
1042262d43feSJerin Jacob 	uint64_t qsize:3;
1043262d43feSJerin Jacob 	uint64_t reserved_25_31:7;
1044262d43feSJerin Jacob 	uint64_t avg_con:9;
1045262d43feSJerin Jacob 	uint64_t reserved_0_15:16;
1046262d43feSJerin Jacob #else
1047262d43feSJerin Jacob 	uint64_t reserved_0_15:16;
1048262d43feSJerin Jacob 	uint64_t avg_con:9;
1049262d43feSJerin Jacob 	uint64_t reserved_25_31:7;
1050262d43feSJerin Jacob 	uint64_t qsize:3;
1051262d43feSJerin Jacob 	uint64_t reserved_35_39:5;
1052262d43feSJerin Jacob 	uint64_t caching:1;
1053262d43feSJerin Jacob 	uint64_t reset:1;
1054262d43feSJerin Jacob 	uint64_t ena:1;
1055262d43feSJerin Jacob 	uint64_t reserved_43_63:21;
1056262d43feSJerin Jacob #endif
1057262d43feSJerin Jacob 	};
1058262d43feSJerin Jacob 	uint64_t value;
1059262d43feSJerin Jacob }; };
1060262d43feSJerin Jacob 
1061262d43feSJerin Jacob struct sq_cfg { union { struct {
10625ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
106359ab9bf0SJerin Jacob 	uint64_t reserved_32_63:32;
106459ab9bf0SJerin Jacob 	uint64_t cq_limit:8;
1065262d43feSJerin Jacob 	uint64_t ena:1;
1066262d43feSJerin Jacob 	uint64_t reserved_18_18:1;
1067262d43feSJerin Jacob 	uint64_t reset:1;
1068262d43feSJerin Jacob 	uint64_t ldwb:1;
1069262d43feSJerin Jacob 	uint64_t reserved_11_15:5;
1070262d43feSJerin Jacob 	uint64_t qsize:3;
1071262d43feSJerin Jacob 	uint64_t reserved_3_7:5;
1072262d43feSJerin Jacob 	uint64_t tstmp_bgx_intf:3;
1073262d43feSJerin Jacob #else
1074262d43feSJerin Jacob 	uint64_t tstmp_bgx_intf:3;
1075262d43feSJerin Jacob 	uint64_t reserved_3_7:5;
1076262d43feSJerin Jacob 	uint64_t qsize:3;
1077262d43feSJerin Jacob 	uint64_t reserved_11_15:5;
1078262d43feSJerin Jacob 	uint64_t ldwb:1;
1079262d43feSJerin Jacob 	uint64_t reset:1;
1080262d43feSJerin Jacob 	uint64_t reserved_18_18:1;
1081262d43feSJerin Jacob 	uint64_t ena:1;
108259ab9bf0SJerin Jacob 	uint64_t cq_limit:8;
108359ab9bf0SJerin Jacob 	uint64_t reserved_32_63:32;
1084262d43feSJerin Jacob #endif
1085262d43feSJerin Jacob 	};
1086262d43feSJerin Jacob 	uint64_t value;
1087262d43feSJerin Jacob }; };
1088262d43feSJerin Jacob 
1089262d43feSJerin Jacob struct rbdr_cfg { union { struct {
10905ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
1091262d43feSJerin Jacob 	uint64_t reserved_45_63:19;
1092262d43feSJerin Jacob 	uint64_t ena:1;
1093262d43feSJerin Jacob 	uint64_t reset:1;
1094262d43feSJerin Jacob 	uint64_t ldwb:1;
1095262d43feSJerin Jacob 	uint64_t reserved_36_41:6;
1096262d43feSJerin Jacob 	uint64_t qsize:4;
1097262d43feSJerin Jacob 	uint64_t reserved_25_31:7;
1098262d43feSJerin Jacob 	uint64_t avg_con:9;
1099262d43feSJerin Jacob 	uint64_t reserved_12_15:4;
1100262d43feSJerin Jacob 	uint64_t lines:12;
1101262d43feSJerin Jacob #else
1102262d43feSJerin Jacob 	uint64_t lines:12;
1103262d43feSJerin Jacob 	uint64_t reserved_12_15:4;
1104262d43feSJerin Jacob 	uint64_t avg_con:9;
1105262d43feSJerin Jacob 	uint64_t reserved_25_31:7;
1106262d43feSJerin Jacob 	uint64_t qsize:4;
1107262d43feSJerin Jacob 	uint64_t reserved_36_41:6;
1108262d43feSJerin Jacob 	uint64_t ldwb:1;
1109262d43feSJerin Jacob 	uint64_t reset:1;
1110262d43feSJerin Jacob 	uint64_t ena: 1;
1111262d43feSJerin Jacob 	uint64_t reserved_45_63:19;
1112262d43feSJerin Jacob #endif
1113262d43feSJerin Jacob 	};
1114262d43feSJerin Jacob 	uint64_t value;
1115262d43feSJerin Jacob }; };
1116262d43feSJerin Jacob 
1117262d43feSJerin Jacob struct pf_qs_cfg { union { struct {
11185ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
1119262d43feSJerin Jacob 	uint64_t reserved_32_63:32;
1120262d43feSJerin Jacob 	uint64_t ena:1;
1121262d43feSJerin Jacob 	uint64_t reserved_27_30:4;
1122262d43feSJerin Jacob 	uint64_t sq_ins_ena:1;
1123262d43feSJerin Jacob 	uint64_t sq_ins_pos:6;
1124262d43feSJerin Jacob 	uint64_t lock_ena:1;
1125262d43feSJerin Jacob 	uint64_t lock_viol_cqe_ena:1;
1126262d43feSJerin Jacob 	uint64_t send_tstmp_ena:1;
1127262d43feSJerin Jacob 	uint64_t be:1;
1128262d43feSJerin Jacob 	uint64_t reserved_7_15:9;
1129262d43feSJerin Jacob 	uint64_t vnic:7;
1130262d43feSJerin Jacob #else
1131262d43feSJerin Jacob 	uint64_t vnic:7;
1132262d43feSJerin Jacob 	uint64_t reserved_7_15:9;
1133262d43feSJerin Jacob 	uint64_t be:1;
1134262d43feSJerin Jacob 	uint64_t send_tstmp_ena:1;
1135262d43feSJerin Jacob 	uint64_t lock_viol_cqe_ena:1;
1136262d43feSJerin Jacob 	uint64_t lock_ena:1;
1137262d43feSJerin Jacob 	uint64_t sq_ins_pos:6;
1138262d43feSJerin Jacob 	uint64_t sq_ins_ena:1;
1139262d43feSJerin Jacob 	uint64_t reserved_27_30:4;
1140262d43feSJerin Jacob 	uint64_t ena:1;
1141262d43feSJerin Jacob 	uint64_t reserved_32_63:32;
1142262d43feSJerin Jacob #endif
1143262d43feSJerin Jacob 	};
1144262d43feSJerin Jacob 	uint64_t value;
1145262d43feSJerin Jacob }; };
1146262d43feSJerin Jacob 
1147262d43feSJerin Jacob struct pf_rq_cfg { union { struct {
11485ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
1149262d43feSJerin Jacob 	uint64_t reserved1:1;
1150262d43feSJerin Jacob 	uint64_t reserved0:34;
1151262d43feSJerin Jacob 	uint64_t strip_pre_l2:1;
1152262d43feSJerin Jacob 	uint64_t caching:2;
1153262d43feSJerin Jacob 	uint64_t cq_qs:7;
1154262d43feSJerin Jacob 	uint64_t cq_idx:3;
1155262d43feSJerin Jacob 	uint64_t rbdr_cont_qs:7;
1156262d43feSJerin Jacob 	uint64_t rbdr_cont_idx:1;
1157262d43feSJerin Jacob 	uint64_t rbdr_strt_qs:7;
1158262d43feSJerin Jacob 	uint64_t rbdr_strt_idx:1;
1159262d43feSJerin Jacob #else
1160262d43feSJerin Jacob 	uint64_t rbdr_strt_idx:1;
1161262d43feSJerin Jacob 	uint64_t rbdr_strt_qs:7;
1162262d43feSJerin Jacob 	uint64_t rbdr_cont_idx:1;
1163262d43feSJerin Jacob 	uint64_t rbdr_cont_qs:7;
1164262d43feSJerin Jacob 	uint64_t cq_idx:3;
1165262d43feSJerin Jacob 	uint64_t cq_qs:7;
1166262d43feSJerin Jacob 	uint64_t caching:2;
1167262d43feSJerin Jacob 	uint64_t strip_pre_l2:1;
1168262d43feSJerin Jacob 	uint64_t reserved0:34;
1169262d43feSJerin Jacob 	uint64_t reserved1:1;
1170262d43feSJerin Jacob #endif
1171262d43feSJerin Jacob 	};
1172262d43feSJerin Jacob 	uint64_t value;
1173262d43feSJerin Jacob }; };
1174262d43feSJerin Jacob 
1175262d43feSJerin Jacob struct pf_rq_drop_cfg { union { struct {
11765ba41107SJerin Jacob #if NICVF_BYTE_ORDER == NICVF_BIG_ENDIAN
1177262d43feSJerin Jacob 	uint64_t rbdr_red:1;
1178262d43feSJerin Jacob 	uint64_t cq_red:1;
1179262d43feSJerin Jacob 	uint64_t reserved3:14;
1180262d43feSJerin Jacob 	uint64_t rbdr_pass:8;
1181262d43feSJerin Jacob 	uint64_t rbdr_drop:8;
1182262d43feSJerin Jacob 	uint64_t reserved2:8;
1183262d43feSJerin Jacob 	uint64_t cq_pass:8;
1184262d43feSJerin Jacob 	uint64_t cq_drop:8;
1185262d43feSJerin Jacob 	uint64_t reserved1:8;
1186262d43feSJerin Jacob #else
1187262d43feSJerin Jacob 	uint64_t reserved1:8;
1188262d43feSJerin Jacob 	uint64_t cq_drop:8;
1189262d43feSJerin Jacob 	uint64_t cq_pass:8;
1190262d43feSJerin Jacob 	uint64_t reserved2:8;
1191262d43feSJerin Jacob 	uint64_t rbdr_drop:8;
1192262d43feSJerin Jacob 	uint64_t rbdr_pass:8;
1193262d43feSJerin Jacob 	uint64_t reserved3:14;
1194262d43feSJerin Jacob 	uint64_t cq_red:1;
1195262d43feSJerin Jacob 	uint64_t rbdr_red:1;
1196262d43feSJerin Jacob #endif
1197262d43feSJerin Jacob 	};
1198262d43feSJerin Jacob 	uint64_t value;
1199262d43feSJerin Jacob }; };
1200262d43feSJerin Jacob 
1201fec9ad3aSJerin Jacob #endif /* _THUNDERX_NICVF_HW_DEFS_H */
1202