bus: mhi: core: Add helper API to return number of free TREs
[linux-2.6-microblaze.git] / drivers / net / ethernet / marvell / octeontx2 / af / rvu_struct.h
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*  Marvell OcteonTx2 RVU Admin Function driver
3  *
4  * Copyright (C) 2018 Marvell International Ltd.
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 as
8  * published by the Free Software Foundation.
9  */
10
11 #ifndef RVU_STRUCT_H
12 #define RVU_STRUCT_H
13
14 /* RVU Block revision IDs */
15 #define RVU_BLK_RVUM_REVID              0x01
16
17 #define RVU_MULTI_BLK_VER               0x7ULL
18
19 /* RVU Block Address Enumeration */
20 enum rvu_block_addr_e {
21         BLKADDR_RVUM            = 0x0ULL,
22         BLKADDR_LMT             = 0x1ULL,
23         BLKADDR_MSIX            = 0x2ULL,
24         BLKADDR_NPA             = 0x3ULL,
25         BLKADDR_NIX0            = 0x4ULL,
26         BLKADDR_NIX1            = 0x5ULL,
27         BLKADDR_NPC             = 0x6ULL,
28         BLKADDR_SSO             = 0x7ULL,
29         BLKADDR_SSOW            = 0x8ULL,
30         BLKADDR_TIM             = 0x9ULL,
31         BLKADDR_CPT0            = 0xaULL,
32         BLKADDR_CPT1            = 0xbULL,
33         BLKADDR_NDC_NIX0_RX     = 0xcULL,
34         BLKADDR_NDC_NIX0_TX     = 0xdULL,
35         BLKADDR_NDC_NPA0        = 0xeULL,
36         BLKADDR_NDC_NIX1_RX     = 0x10ULL,
37         BLKADDR_NDC_NIX1_TX     = 0x11ULL,
38         BLK_COUNT               = 0x12ULL,
39 };
40
41 /* RVU Block Type Enumeration */
42 enum rvu_block_type_e {
43         BLKTYPE_RVUM = 0x0,
44         BLKTYPE_MSIX = 0x1,
45         BLKTYPE_LMT  = 0x2,
46         BLKTYPE_NIX  = 0x3,
47         BLKTYPE_NPA  = 0x4,
48         BLKTYPE_NPC  = 0x5,
49         BLKTYPE_SSO  = 0x6,
50         BLKTYPE_SSOW = 0x7,
51         BLKTYPE_TIM  = 0x8,
52         BLKTYPE_CPT  = 0x9,
53         BLKTYPE_NDC  = 0xa,
54         BLKTYPE_MAX  = 0xa,
55 };
56
57 /* RVU Admin function Interrupt Vector Enumeration */
58 enum rvu_af_int_vec_e {
59         RVU_AF_INT_VEC_POISON = 0x0,
60         RVU_AF_INT_VEC_PFFLR  = 0x1,
61         RVU_AF_INT_VEC_PFME   = 0x2,
62         RVU_AF_INT_VEC_GEN    = 0x3,
63         RVU_AF_INT_VEC_MBOX   = 0x4,
64         RVU_AF_INT_VEC_CNT    = 0x5,
65 };
66
67 /* NPA Admin function Interrupt Vector Enumeration */
68 enum npa_af_int_vec_e {
69         NPA_AF_INT_VEC_RVU      = 0x0,
70         NPA_AF_INT_VEC_GEN      = 0x1,
71         NPA_AF_INT_VEC_AQ_DONE  = 0x2,
72         NPA_AF_INT_VEC_AF_ERR   = 0x3,
73         NPA_AF_INT_VEC_POISON   = 0x4,
74         NPA_AF_INT_VEC_CNT      = 0x5,
75 };
76
77 /**
78  * RVU PF Interrupt Vector Enumeration
79  */
80 enum rvu_pf_int_vec_e {
81         RVU_PF_INT_VEC_VFFLR0     = 0x0,
82         RVU_PF_INT_VEC_VFFLR1     = 0x1,
83         RVU_PF_INT_VEC_VFME0      = 0x2,
84         RVU_PF_INT_VEC_VFME1      = 0x3,
85         RVU_PF_INT_VEC_VFPF_MBOX0 = 0x4,
86         RVU_PF_INT_VEC_VFPF_MBOX1 = 0x5,
87         RVU_PF_INT_VEC_AFPF_MBOX  = 0x6,
88         RVU_PF_INT_VEC_CNT        = 0x7,
89 };
90
91 /* NPA admin queue completion enumeration */
92 enum npa_aq_comp {
93         NPA_AQ_COMP_NOTDONE    = 0x0,
94         NPA_AQ_COMP_GOOD       = 0x1,
95         NPA_AQ_COMP_SWERR      = 0x2,
96         NPA_AQ_COMP_CTX_POISON = 0x3,
97         NPA_AQ_COMP_CTX_FAULT  = 0x4,
98         NPA_AQ_COMP_LOCKERR    = 0x5,
99 };
100
101 /* NPA admin queue context types */
102 enum npa_aq_ctype {
103         NPA_AQ_CTYPE_AURA = 0x0,
104         NPA_AQ_CTYPE_POOL = 0x1,
105 };
106
107 /* NPA admin queue instruction opcodes */
108 enum npa_aq_instop {
109         NPA_AQ_INSTOP_NOP    = 0x0,
110         NPA_AQ_INSTOP_INIT   = 0x1,
111         NPA_AQ_INSTOP_WRITE  = 0x2,
112         NPA_AQ_INSTOP_READ   = 0x3,
113         NPA_AQ_INSTOP_LOCK   = 0x4,
114         NPA_AQ_INSTOP_UNLOCK = 0x5,
115 };
116
117 /* ALLOC/FREE input queues Enumeration from coprocessors */
118 enum npa_inpq {
119         NPA_INPQ_NIX0_RX       = 0x0,
120         NPA_INPQ_NIX0_TX       = 0x1,
121         NPA_INPQ_NIX1_RX       = 0x2,
122         NPA_INPQ_NIX1_TX       = 0x3,
123         NPA_INPQ_SSO           = 0x4,
124         NPA_INPQ_TIM           = 0x5,
125         NPA_INPQ_DPI           = 0x6,
126         NPA_INPQ_AURA_OP       = 0xe,
127         NPA_INPQ_INTERNAL_RSV  = 0xf,
128 };
129
130 /* NPA admin queue instruction structure */
131 struct npa_aq_inst_s {
132 #if defined(__BIG_ENDIAN_BITFIELD)
133         u64 doneint               : 1;  /* W0 */
134         u64 reserved_44_62        : 19;
135         u64 cindex                : 20;
136         u64 reserved_17_23        : 7;
137         u64 lf                    : 9;
138         u64 ctype                 : 4;
139         u64 op                    : 4;
140 #else
141         u64 op                    : 4;
142         u64 ctype                 : 4;
143         u64 lf                    : 9;
144         u64 reserved_17_23        : 7;
145         u64 cindex                : 20;
146         u64 reserved_44_62        : 19;
147         u64 doneint               : 1;
148 #endif
149         u64 res_addr;                   /* W1 */
150 };
151
152 /* NPA admin queue result structure */
153 struct npa_aq_res_s {
154 #if defined(__BIG_ENDIAN_BITFIELD)
155         u64 reserved_17_63        : 47; /* W0 */
156         u64 doneint               : 1;
157         u64 compcode              : 8;
158         u64 ctype                 : 4;
159         u64 op                    : 4;
160 #else
161         u64 op                    : 4;
162         u64 ctype                 : 4;
163         u64 compcode              : 8;
164         u64 doneint               : 1;
165         u64 reserved_17_63        : 47;
166 #endif
167         u64 reserved_64_127;            /* W1 */
168 };
169
170 struct npa_aura_s {
171         u64 pool_addr;                  /* W0 */
172 #if defined(__BIG_ENDIAN_BITFIELD)      /* W1 */
173         u64 avg_level             : 8;
174         u64 reserved_118_119      : 2;
175         u64 shift                 : 6;
176         u64 aura_drop             : 8;
177         u64 reserved_98_103       : 6;
178         u64 bp_ena                : 2;
179         u64 aura_drop_ena         : 1;
180         u64 pool_drop_ena         : 1;
181         u64 reserved_93           : 1;
182         u64 avg_con               : 9;
183         u64 pool_way_mask         : 16;
184         u64 pool_caching          : 1;
185         u64 reserved_65           : 2;
186         u64 ena                   : 1;
187 #else
188         u64 ena                   : 1;
189         u64 reserved_65           : 2;
190         u64 pool_caching          : 1;
191         u64 pool_way_mask         : 16;
192         u64 avg_con               : 9;
193         u64 reserved_93           : 1;
194         u64 pool_drop_ena         : 1;
195         u64 aura_drop_ena         : 1;
196         u64 bp_ena                : 2;
197         u64 reserved_98_103       : 6;
198         u64 aura_drop             : 8;
199         u64 shift                 : 6;
200         u64 reserved_118_119      : 2;
201         u64 avg_level             : 8;
202 #endif
203 #if defined(__BIG_ENDIAN_BITFIELD)      /* W2 */
204         u64 reserved_189_191      : 3;
205         u64 nix1_bpid             : 9;
206         u64 reserved_177_179      : 3;
207         u64 nix0_bpid             : 9;
208         u64 reserved_164_167      : 4;
209         u64 count                 : 36;
210 #else
211         u64 count                 : 36;
212         u64 reserved_164_167      : 4;
213         u64 nix0_bpid             : 9;
214         u64 reserved_177_179      : 3;
215         u64 nix1_bpid             : 9;
216         u64 reserved_189_191      : 3;
217 #endif
218 #if defined(__BIG_ENDIAN_BITFIELD)      /* W3 */
219         u64 reserved_252_255      : 4;
220         u64 fc_hyst_bits          : 4;
221         u64 fc_stype              : 2;
222         u64 fc_up_crossing        : 1;
223         u64 fc_ena                : 1;
224         u64 reserved_240_243      : 4;
225         u64 bp                    : 8;
226         u64 reserved_228_231      : 4;
227         u64 limit                 : 36;
228 #else
229         u64 limit                 : 36;
230         u64 reserved_228_231      : 4;
231         u64 bp                    : 8;
232         u64 reserved_240_243      : 4;
233         u64 fc_ena                : 1;
234         u64 fc_up_crossing        : 1;
235         u64 fc_stype              : 2;
236         u64 fc_hyst_bits          : 4;
237         u64 reserved_252_255      : 4;
238 #endif
239         u64 fc_addr;                    /* W4 */
240 #if defined(__BIG_ENDIAN_BITFIELD)      /* W5 */
241         u64 reserved_379_383      : 5;
242         u64 err_qint_idx          : 7;
243         u64 reserved_371          : 1;
244         u64 thresh_qint_idx       : 7;
245         u64 reserved_363          : 1;
246         u64 thresh_up             : 1;
247         u64 thresh_int_ena        : 1;
248         u64 thresh_int            : 1;
249         u64 err_int_ena           : 8;
250         u64 err_int               : 8;
251         u64 update_time           : 16;
252         u64 pool_drop             : 8;
253 #else
254         u64 pool_drop             : 8;
255         u64 update_time           : 16;
256         u64 err_int               : 8;
257         u64 err_int_ena           : 8;
258         u64 thresh_int            : 1;
259         u64 thresh_int_ena        : 1;
260         u64 thresh_up             : 1;
261         u64 reserved_363          : 1;
262         u64 thresh_qint_idx       : 7;
263         u64 reserved_371          : 1;
264         u64 err_qint_idx          : 7;
265         u64 reserved_379_383      : 5;
266 #endif
267 #if defined(__BIG_ENDIAN_BITFIELD)      /* W6 */
268         u64 reserved_420_447      : 28;
269         u64 thresh                : 36;
270 #else
271         u64 thresh                : 36;
272         u64 reserved_420_447      : 28;
273 #endif
274         u64 reserved_448_511;           /* W7 */
275 };
276
277 struct npa_pool_s {
278         u64 stack_base;                 /* W0 */
279 #if defined(__BIG_ENDIAN_BITFIELD)      /* W1 */
280         u64 reserved_115_127      : 13;
281         u64 buf_size              : 11;
282         u64 reserved_100_103      : 4;
283         u64 buf_offset            : 12;
284         u64 stack_way_mask        : 16;
285         u64 reserved_70_71        : 3;
286         u64 stack_caching         : 1;
287         u64 reserved_66_67        : 2;
288         u64 nat_align             : 1;
289         u64 ena                   : 1;
290 #else
291         u64 ena                   : 1;
292         u64 nat_align             : 1;
293         u64 reserved_66_67        : 2;
294         u64 stack_caching         : 1;
295         u64 reserved_70_71        : 3;
296         u64 stack_way_mask        : 16;
297         u64 buf_offset            : 12;
298         u64 reserved_100_103      : 4;
299         u64 buf_size              : 11;
300         u64 reserved_115_127      : 13;
301 #endif
302 #if defined(__BIG_ENDIAN_BITFIELD)      /* W2 */
303         u64 stack_pages           : 32;
304         u64 stack_max_pages       : 32;
305 #else
306         u64 stack_max_pages       : 32;
307         u64 stack_pages           : 32;
308 #endif
309 #if defined(__BIG_ENDIAN_BITFIELD)      /* W3 */
310         u64 reserved_240_255      : 16;
311         u64 op_pc                 : 48;
312 #else
313         u64 op_pc                 : 48;
314         u64 reserved_240_255      : 16;
315 #endif
316 #if defined(__BIG_ENDIAN_BITFIELD)      /* W4 */
317         u64 reserved_316_319      : 4;
318         u64 update_time           : 16;
319         u64 reserved_297_299      : 3;
320         u64 fc_up_crossing        : 1;
321         u64 fc_hyst_bits          : 4;
322         u64 fc_stype              : 2;
323         u64 fc_ena                : 1;
324         u64 avg_con               : 9;
325         u64 avg_level             : 8;
326         u64 reserved_270_271      : 2;
327         u64 shift                 : 6;
328         u64 reserved_260_263      : 4;
329         u64 stack_offset          : 4;
330 #else
331         u64 stack_offset          : 4;
332         u64 reserved_260_263      : 4;
333         u64 shift                 : 6;
334         u64 reserved_270_271      : 2;
335         u64 avg_level             : 8;
336         u64 avg_con               : 9;
337         u64 fc_ena                : 1;
338         u64 fc_stype              : 2;
339         u64 fc_hyst_bits          : 4;
340         u64 fc_up_crossing        : 1;
341         u64 reserved_297_299      : 3;
342         u64 update_time           : 16;
343         u64 reserved_316_319      : 4;
344 #endif
345         u64 fc_addr;                    /* W5 */
346         u64 ptr_start;                  /* W6 */
347         u64 ptr_end;                    /* W7 */
348 #if defined(__BIG_ENDIAN_BITFIELD)      /* W8 */
349         u64 reserved_571_575      : 5;
350         u64 err_qint_idx          : 7;
351         u64 reserved_563          : 1;
352         u64 thresh_qint_idx       : 7;
353         u64 reserved_555          : 1;
354         u64 thresh_up             : 1;
355         u64 thresh_int_ena        : 1;
356         u64 thresh_int            : 1;
357         u64 err_int_ena           : 8;
358         u64 err_int               : 8;
359         u64 reserved_512_535      : 24;
360 #else
361         u64 reserved_512_535      : 24;
362         u64 err_int               : 8;
363         u64 err_int_ena           : 8;
364         u64 thresh_int            : 1;
365         u64 thresh_int_ena        : 1;
366         u64 thresh_up             : 1;
367         u64 reserved_555          : 1;
368         u64 thresh_qint_idx       : 7;
369         u64 reserved_563          : 1;
370         u64 err_qint_idx          : 7;
371         u64 reserved_571_575      : 5;
372 #endif
373 #if defined(__BIG_ENDIAN_BITFIELD)      /* W9 */
374         u64 reserved_612_639      : 28;
375         u64 thresh                : 36;
376 #else
377         u64 thresh                : 36;
378         u64 reserved_612_639      : 28;
379 #endif
380         u64 reserved_640_703;           /* W10 */
381         u64 reserved_704_767;           /* W11 */
382         u64 reserved_768_831;           /* W12 */
383         u64 reserved_832_895;           /* W13 */
384         u64 reserved_896_959;           /* W14 */
385         u64 reserved_960_1023;          /* W15 */
386 };
387
388 /* NIX admin queue completion status */
389 enum nix_aq_comp {
390         NIX_AQ_COMP_NOTDONE        = 0x0,
391         NIX_AQ_COMP_GOOD           = 0x1,
392         NIX_AQ_COMP_SWERR          = 0x2,
393         NIX_AQ_COMP_CTX_POISON     = 0x3,
394         NIX_AQ_COMP_CTX_FAULT      = 0x4,
395         NIX_AQ_COMP_LOCKERR        = 0x5,
396         NIX_AQ_COMP_SQB_ALLOC_FAIL = 0x6,
397 };
398
399 /* NIX admin queue context types */
400 enum nix_aq_ctype {
401         NIX_AQ_CTYPE_RQ   = 0x0,
402         NIX_AQ_CTYPE_SQ   = 0x1,
403         NIX_AQ_CTYPE_CQ   = 0x2,
404         NIX_AQ_CTYPE_MCE  = 0x3,
405         NIX_AQ_CTYPE_RSS  = 0x4,
406         NIX_AQ_CTYPE_DYNO = 0x5,
407 };
408
409 /* NIX admin queue instruction opcodes */
410 enum nix_aq_instop {
411         NIX_AQ_INSTOP_NOP    = 0x0,
412         NIX_AQ_INSTOP_INIT   = 0x1,
413         NIX_AQ_INSTOP_WRITE  = 0x2,
414         NIX_AQ_INSTOP_READ   = 0x3,
415         NIX_AQ_INSTOP_LOCK   = 0x4,
416         NIX_AQ_INSTOP_UNLOCK = 0x5,
417 };
418
419 /* NIX admin queue instruction structure */
420 struct nix_aq_inst_s {
421 #if defined(__BIG_ENDIAN_BITFIELD)
422         u64 doneint             : 1;    /* W0 */
423         u64 reserved_44_62      : 19;
424         u64 cindex              : 20;
425         u64 reserved_15_23      : 9;
426         u64 lf                  : 7;
427         u64 ctype               : 4;
428         u64 op                  : 4;
429 #else
430         u64 op                  : 4;
431         u64 ctype               : 4;
432         u64 lf                  : 7;
433         u64 reserved_15_23      : 9;
434         u64 cindex              : 20;
435         u64 reserved_44_62      : 19;
436         u64 doneint             : 1;
437 #endif
438         u64 res_addr;                   /* W1 */
439 };
440
441 /* NIX admin queue result structure */
442 struct nix_aq_res_s {
443 #if defined(__BIG_ENDIAN_BITFIELD)
444         u64 reserved_17_63      : 47;   /* W0 */
445         u64 doneint             : 1;
446         u64 compcode            : 8;
447         u64 ctype               : 4;
448         u64 op                  : 4;
449 #else
450         u64 op                  : 4;
451         u64 ctype               : 4;
452         u64 compcode            : 8;
453         u64 doneint             : 1;
454         u64 reserved_17_63      : 47;
455 #endif
456         u64 reserved_64_127;            /* W1 */
457 };
458
459 /* NIX Completion queue context structure */
460 struct nix_cq_ctx_s {
461         u64 base;
462 #if defined(__BIG_ENDIAN_BITFIELD)      /* W1 */
463         u64 wrptr               : 20;
464         u64 avg_con             : 9;
465         u64 cint_idx            : 7;
466         u64 cq_err              : 1;
467         u64 qint_idx            : 7;
468         u64 rsvd_81_83          : 3;
469         u64 bpid                : 9;
470         u64 rsvd_69_71          : 3;
471         u64 bp_ena              : 1;
472         u64 rsvd_64_67          : 4;
473 #else
474         u64 rsvd_64_67          : 4;
475         u64 bp_ena              : 1;
476         u64 rsvd_69_71          : 3;
477         u64 bpid                : 9;
478         u64 rsvd_81_83          : 3;
479         u64 qint_idx            : 7;
480         u64 cq_err              : 1;
481         u64 cint_idx            : 7;
482         u64 avg_con             : 9;
483         u64 wrptr               : 20;
484 #endif
485 #if defined(__BIG_ENDIAN_BITFIELD)  /* W2 */
486         u64 update_time         : 16;
487         u64 avg_level           : 8;
488         u64 head                : 20;
489         u64 tail                : 20;
490 #else
491         u64 tail                : 20;
492         u64 head                : 20;
493         u64 avg_level           : 8;
494         u64 update_time         : 16;
495 #endif
496 #if defined(__BIG_ENDIAN_BITFIELD)  /* W3 */
497         u64 cq_err_int_ena      : 8;
498         u64 cq_err_int          : 8;
499         u64 qsize               : 4;
500         u64 rsvd_233_235        : 3;
501         u64 caching             : 1;
502         u64 substream           : 20;
503         u64 rsvd_210_211        : 2;
504         u64 ena                 : 1;
505         u64 drop_ena            : 1;
506         u64 drop                : 8;
507         u64 bp                  : 8;
508 #else
509         u64 bp                  : 8;
510         u64 drop                : 8;
511         u64 drop_ena            : 1;
512         u64 ena                 : 1;
513         u64 rsvd_210_211        : 2;
514         u64 substream           : 20;
515         u64 caching             : 1;
516         u64 rsvd_233_235        : 3;
517         u64 qsize               : 4;
518         u64 cq_err_int          : 8;
519         u64 cq_err_int_ena      : 8;
520 #endif
521 };
522
523 /* NIX Receive queue context structure */
524 struct nix_rq_ctx_s {
525 #if defined(__BIG_ENDIAN_BITFIELD)  /* W0 */
526         u64 wqe_aura      : 20;
527         u64 substream     : 20;
528         u64 cq            : 20;
529         u64 ena_wqwd      : 1;
530         u64 ipsech_ena    : 1;
531         u64 sso_ena       : 1;
532         u64 ena           : 1;
533 #else
534         u64 ena           : 1;
535         u64 sso_ena       : 1;
536         u64 ipsech_ena    : 1;
537         u64 ena_wqwd      : 1;
538         u64 cq            : 20;
539         u64 substream     : 20;
540         u64 wqe_aura      : 20;
541 #endif
542 #if defined(__BIG_ENDIAN_BITFIELD)  /* W1 */
543         u64 rsvd_127_122  : 6;
544         u64 lpb_drop_ena  : 1;
545         u64 spb_drop_ena  : 1;
546         u64 xqe_drop_ena  : 1;
547         u64 wqe_caching   : 1;
548         u64 pb_caching    : 2;
549         u64 sso_tt        : 2;
550         u64 sso_grp       : 10;
551         u64 lpb_aura      : 20;
552         u64 spb_aura      : 20;
553 #else
554         u64 spb_aura      : 20;
555         u64 lpb_aura      : 20;
556         u64 sso_grp       : 10;
557         u64 sso_tt        : 2;
558         u64 pb_caching    : 2;
559         u64 wqe_caching   : 1;
560         u64 xqe_drop_ena  : 1;
561         u64 spb_drop_ena  : 1;
562         u64 lpb_drop_ena  : 1;
563         u64 rsvd_127_122  : 6;
564 #endif
565 #if defined(__BIG_ENDIAN_BITFIELD)  /* W2 */
566         u64 xqe_hdr_split : 1;
567         u64 xqe_imm_copy  : 1;
568         u64 rsvd_189_184  : 6;
569         u64 xqe_imm_size  : 6;
570         u64 later_skip    : 6;
571         u64 rsvd_171      : 1;
572         u64 first_skip    : 7;
573         u64 lpb_sizem1    : 12;
574         u64 spb_ena       : 1;
575         u64 rsvd_150_148  : 3;
576         u64 wqe_skip      : 2;
577         u64 spb_sizem1    : 6;
578         u64 rsvd_139_128  : 12;
579 #else
580         u64 rsvd_139_128  : 12;
581         u64 spb_sizem1    : 6;
582         u64 wqe_skip      : 2;
583         u64 rsvd_150_148  : 3;
584         u64 spb_ena       : 1;
585         u64 lpb_sizem1    : 12;
586         u64 first_skip    : 7;
587         u64 rsvd_171      : 1;
588         u64 later_skip    : 6;
589         u64 xqe_imm_size  : 6;
590         u64 rsvd_189_184  : 6;
591         u64 xqe_imm_copy  : 1;
592         u64 xqe_hdr_split : 1;
593 #endif
594 #if defined(__BIG_ENDIAN_BITFIELD)  /* W3 */
595         u64 spb_pool_pass : 8;
596         u64 spb_pool_drop : 8;
597         u64 spb_aura_pass : 8;
598         u64 spb_aura_drop : 8;
599         u64 wqe_pool_pass : 8;
600         u64 wqe_pool_drop : 8;
601         u64 xqe_pass      : 8;
602         u64 xqe_drop      : 8;
603 #else
604         u64 xqe_drop      : 8;
605         u64 xqe_pass      : 8;
606         u64 wqe_pool_drop : 8;
607         u64 wqe_pool_pass : 8;
608         u64 spb_aura_drop : 8;
609         u64 spb_aura_pass : 8;
610         u64 spb_pool_drop : 8;
611         u64 spb_pool_pass : 8;
612 #endif
613 #if defined(__BIG_ENDIAN_BITFIELD)  /* W4 */
614         u64 rsvd_319_315  : 5;
615         u64 qint_idx      : 7;
616         u64 rq_int_ena    : 8;
617         u64 rq_int        : 8;
618         u64 rsvd_291_288  : 4;
619         u64 lpb_pool_pass : 8;
620         u64 lpb_pool_drop : 8;
621         u64 lpb_aura_pass : 8;
622         u64 lpb_aura_drop : 8;
623 #else
624         u64 lpb_aura_drop : 8;
625         u64 lpb_aura_pass : 8;
626         u64 lpb_pool_drop : 8;
627         u64 lpb_pool_pass : 8;
628         u64 rsvd_291_288  : 4;
629         u64 rq_int        : 8;
630         u64 rq_int_ena    : 8;
631         u64 qint_idx      : 7;
632         u64 rsvd_319_315  : 5;
633 #endif
634 #if defined(__BIG_ENDIAN_BITFIELD)  /* W5 */
635         u64 rsvd_383_366  : 18;
636         u64 flow_tagw     : 6;
637         u64 bad_utag      : 8;
638         u64 good_utag     : 8;
639         u64 ltag          : 24;
640 #else
641         u64 ltag          : 24;
642         u64 good_utag     : 8;
643         u64 bad_utag      : 8;
644         u64 flow_tagw     : 6;
645         u64 rsvd_383_366  : 18;
646 #endif
647 #if defined(__BIG_ENDIAN_BITFIELD)  /* W6 */
648         u64 rsvd_447_432  : 16;
649         u64 octs          : 48;
650 #else
651         u64 octs          : 48;
652         u64 rsvd_447_432  : 16;
653 #endif
654 #if defined(__BIG_ENDIAN_BITFIELD)  /* W7 */
655         u64 rsvd_511_496  : 16;
656         u64 pkts          : 48;
657 #else
658         u64 pkts          : 48;
659         u64 rsvd_511_496  : 16;
660 #endif
661 #if defined(__BIG_ENDIAN_BITFIELD)  /* W8 */
662         u64 rsvd_575_560  : 16;
663         u64 drop_octs     : 48;
664 #else
665         u64 drop_octs     : 48;
666         u64 rsvd_575_560  : 16;
667 #endif
668 #if defined(__BIG_ENDIAN_BITFIELD)      /* W9 */
669         u64 rsvd_639_624  : 16;
670         u64 drop_pkts     : 48;
671 #else
672         u64 drop_pkts     : 48;
673         u64 rsvd_639_624  : 16;
674 #endif
675 #if defined(__BIG_ENDIAN_BITFIELD)      /* W10 */
676         u64 rsvd_703_688  : 16;
677         u64 re_pkts       : 48;
678 #else
679         u64 re_pkts       : 48;
680         u64 rsvd_703_688  : 16;
681 #endif
682         u64 rsvd_767_704;               /* W11 */
683         u64 rsvd_831_768;               /* W12 */
684         u64 rsvd_895_832;               /* W13 */
685         u64 rsvd_959_896;               /* W14 */
686         u64 rsvd_1023_960;              /* W15 */
687 };
688
689 /* NIX sqe sizes */
690 enum nix_maxsqesz {
691         NIX_MAXSQESZ_W16 = 0x0,
692         NIX_MAXSQESZ_W8  = 0x1,
693 };
694
695 /* NIX SQB caching type */
696 enum nix_stype {
697         NIX_STYPE_STF = 0x0,
698         NIX_STYPE_STT = 0x1,
699         NIX_STYPE_STP = 0x2,
700 };
701
702 /* NIX Send queue context structure */
703 struct nix_sq_ctx_s {
704 #if defined(__BIG_ENDIAN_BITFIELD)  /* W0 */
705         u64 sqe_way_mask          : 16;
706         u64 cq                    : 20;
707         u64 sdp_mcast             : 1;
708         u64 substream             : 20;
709         u64 qint_idx              : 6;
710         u64 ena                   : 1;
711 #else
712         u64 ena                   : 1;
713         u64 qint_idx              : 6;
714         u64 substream             : 20;
715         u64 sdp_mcast             : 1;
716         u64 cq                    : 20;
717         u64 sqe_way_mask          : 16;
718 #endif
719 #if defined(__BIG_ENDIAN_BITFIELD)  /* W1 */
720         u64 sqb_count             : 16;
721         u64 default_chan          : 12;
722         u64 smq_rr_quantum        : 24;
723         u64 sso_ena               : 1;
724         u64 xoff                  : 1;
725         u64 cq_ena                : 1;
726         u64 smq                   : 9;
727 #else
728         u64 smq                   : 9;
729         u64 cq_ena                : 1;
730         u64 xoff                  : 1;
731         u64 sso_ena               : 1;
732         u64 smq_rr_quantum        : 24;
733         u64 default_chan          : 12;
734         u64 sqb_count             : 16;
735 #endif
736 #if defined(__BIG_ENDIAN_BITFIELD)  /* W2 */
737         u64 rsvd_191              : 1;
738         u64 sqe_stype             : 2;
739         u64 sq_int_ena            : 8;
740         u64 sq_int                : 8;
741         u64 sqb_aura              : 20;
742         u64 smq_rr_count          : 25;
743 #else
744         u64 smq_rr_count          : 25;
745         u64 sqb_aura              : 20;
746         u64 sq_int                : 8;
747         u64 sq_int_ena            : 8;
748         u64 sqe_stype             : 2;
749         u64 rsvd_191              : 1;
750 #endif
751 #if defined(__BIG_ENDIAN_BITFIELD)  /* W3 */
752         u64 rsvd_255_253          : 3;
753         u64 smq_next_sq_vld       : 1;
754         u64 smq_pend              : 1;
755         u64 smenq_next_sqb_vld    : 1;
756         u64 head_offset           : 6;
757         u64 smenq_offset          : 6;
758         u64 tail_offset           : 6;
759         u64 smq_lso_segnum        : 8;
760         u64 smq_next_sq           : 20;
761         u64 mnq_dis               : 1;
762         u64 lmt_dis               : 1;
763         u64 cq_limit              : 8;
764         u64 max_sqe_size          : 2;
765 #else
766         u64 max_sqe_size          : 2;
767         u64 cq_limit              : 8;
768         u64 lmt_dis               : 1;
769         u64 mnq_dis               : 1;
770         u64 smq_next_sq           : 20;
771         u64 smq_lso_segnum        : 8;
772         u64 tail_offset           : 6;
773         u64 smenq_offset          : 6;
774         u64 head_offset           : 6;
775         u64 smenq_next_sqb_vld    : 1;
776         u64 smq_pend              : 1;
777         u64 smq_next_sq_vld       : 1;
778         u64 rsvd_255_253          : 3;
779 #endif
780         u64 next_sqb              : 64;/* W4 */
781         u64 tail_sqb              : 64;/* W5 */
782         u64 smenq_sqb             : 64;/* W6 */
783         u64 smenq_next_sqb        : 64;/* W7 */
784         u64 head_sqb              : 64;/* W8 */
785 #if defined(__BIG_ENDIAN_BITFIELD)  /* W9 */
786         u64 rsvd_639_630          : 10;
787         u64 vfi_lso_vld           : 1;
788         u64 vfi_lso_vlan1_ins_ena : 1;
789         u64 vfi_lso_vlan0_ins_ena : 1;
790         u64 vfi_lso_mps           : 14;
791         u64 vfi_lso_sb            : 8;
792         u64 vfi_lso_sizem1        : 3;
793         u64 vfi_lso_total         : 18;
794         u64 rsvd_583_576          : 8;
795 #else
796         u64 rsvd_583_576          : 8;
797         u64 vfi_lso_total         : 18;
798         u64 vfi_lso_sizem1        : 3;
799         u64 vfi_lso_sb            : 8;
800         u64 vfi_lso_mps           : 14;
801         u64 vfi_lso_vlan0_ins_ena : 1;
802         u64 vfi_lso_vlan1_ins_ena : 1;
803         u64 vfi_lso_vld           : 1;
804         u64 rsvd_639_630          : 10;
805 #endif
806 #if defined(__BIG_ENDIAN_BITFIELD) /* W10 */
807         u64 rsvd_703_658          : 46;
808         u64 scm_lso_rem           : 18;
809 #else
810         u64 scm_lso_rem           : 18;
811         u64 rsvd_703_658          : 46;
812 #endif
813 #if defined(__BIG_ENDIAN_BITFIELD) /* W11 */
814         u64 rsvd_767_752          : 16;
815         u64 octs                  : 48;
816 #else
817         u64 octs                  : 48;
818         u64 rsvd_767_752          : 16;
819 #endif
820 #if defined(__BIG_ENDIAN_BITFIELD) /* W12 */
821         u64 rsvd_831_816          : 16;
822         u64 pkts                  : 48;
823 #else
824         u64 pkts                  : 48;
825         u64 rsvd_831_816          : 16;
826 #endif
827         u64 rsvd_895_832          : 64;/* W13 */
828 #if defined(__BIG_ENDIAN_BITFIELD) /* W14 */
829         u64 rsvd_959_944          : 16;
830         u64 dropped_octs          : 48;
831 #else
832         u64 dropped_octs          : 48;
833         u64 rsvd_959_944          : 16;
834 #endif
835 #if defined(__BIG_ENDIAN_BITFIELD) /* W15 */
836         u64 rsvd_1023_1008        : 16;
837         u64 dropped_pkts          : 48;
838 #else
839         u64 dropped_pkts          : 48;
840         u64 rsvd_1023_1008        : 16;
841 #endif
842 };
843
844 /* NIX Receive side scaling entry structure*/
845 struct nix_rsse_s {
846 #if defined(__BIG_ENDIAN_BITFIELD)
847         uint32_t reserved_20_31         : 12;
848         uint32_t rq                     : 20;
849 #else
850         uint32_t rq                     : 20;
851         uint32_t reserved_20_31         : 12;
852
853 #endif
854 };
855
856 /* NIX receive multicast/mirror entry structure */
857 struct nix_rx_mce_s {
858 #if defined(__BIG_ENDIAN_BITFIELD)  /* W0 */
859         uint64_t next       : 16;
860         uint64_t pf_func    : 16;
861         uint64_t rsvd_31_24 : 8;
862         uint64_t index      : 20;
863         uint64_t eol        : 1;
864         uint64_t rsvd_2     : 1;
865         uint64_t op         : 2;
866 #else
867         uint64_t op         : 2;
868         uint64_t rsvd_2     : 1;
869         uint64_t eol        : 1;
870         uint64_t index      : 20;
871         uint64_t rsvd_31_24 : 8;
872         uint64_t pf_func    : 16;
873         uint64_t next       : 16;
874 #endif
875 };
876
877 enum nix_lsoalg {
878         NIX_LSOALG_NOP,
879         NIX_LSOALG_ADD_SEGNUM,
880         NIX_LSOALG_ADD_PAYLEN,
881         NIX_LSOALG_ADD_OFFSET,
882         NIX_LSOALG_TCP_FLAGS,
883 };
884
885 enum nix_txlayer {
886         NIX_TXLAYER_OL3,
887         NIX_TXLAYER_OL4,
888         NIX_TXLAYER_IL3,
889         NIX_TXLAYER_IL4,
890 };
891
892 struct nix_lso_format {
893 #if defined(__BIG_ENDIAN_BITFIELD)
894         u64 rsvd_19_63          : 45;
895         u64 alg                 : 3;
896         u64 rsvd_14_15          : 2;
897         u64 sizem1              : 2;
898         u64 rsvd_10_11          : 2;
899         u64 layer               : 2;
900         u64 offset              : 8;
901 #else
902         u64 offset              : 8;
903         u64 layer               : 2;
904         u64 rsvd_10_11          : 2;
905         u64 sizem1              : 2;
906         u64 rsvd_14_15          : 2;
907         u64 alg                 : 3;
908         u64 rsvd_19_63          : 45;
909 #endif
910 };
911
912 struct nix_rx_flowkey_alg {
913 #if defined(__BIG_ENDIAN_BITFIELD)
914         u64 reserved_35_63      :29;
915         u64 ltype_match         :4;
916         u64 ltype_mask          :4;
917         u64 sel_chan            :1;
918         u64 ena                 :1;
919         u64 reserved_24_24      :1;
920         u64 lid                 :3;
921         u64 bytesm1             :5;
922         u64 hdr_offset          :8;
923         u64 fn_mask             :1;
924         u64 ln_mask             :1;
925         u64 key_offset          :6;
926 #else
927         u64 key_offset          :6;
928         u64 ln_mask             :1;
929         u64 fn_mask             :1;
930         u64 hdr_offset          :8;
931         u64 bytesm1             :5;
932         u64 lid                 :3;
933         u64 reserved_24_24      :1;
934         u64 ena                 :1;
935         u64 sel_chan            :1;
936         u64 ltype_mask          :4;
937         u64 ltype_match         :4;
938         u64 reserved_35_63      :29;
939 #endif
940 };
941
942 /* NIX VTAG size */
943 enum nix_vtag_size {
944         VTAGSIZE_T4   = 0x0,
945         VTAGSIZE_T8   = 0x1,
946 };
947
948 enum nix_tx_vtag_op {
949         NOP             = 0x0,
950         VTAG_INSERT     = 0x1,
951         VTAG_REPLACE    = 0x2,
952 };
953
954 /* NIX RX VTAG actions */
955 #define VTAG_STRIP      BIT_ULL(4)
956 #define VTAG_CAPTURE    BIT_ULL(5)
957
958 #endif /* RVU_STRUCT_H */