diff options
author | Glenn Elliott <gelliott@cs.unc.edu> | 2012-03-04 19:47:13 -0500 |
---|---|---|
committer | Glenn Elliott <gelliott@cs.unc.edu> | 2012-03-04 19:47:13 -0500 |
commit | c71c03bda1e86c9d5198c5d83f712e695c4f2a1e (patch) | |
tree | ecb166cb3e2b7e2adb3b5e292245fefd23381ac8 /drivers/net/bnx2x/bnx2x_reg.h | |
parent | ea53c912f8a86a8567697115b6a0d8152beee5c8 (diff) | |
parent | 6a00f206debf8a5c8899055726ad127dbeeed098 (diff) |
Merge branch 'mpi-master' into wip-k-fmlpwip-k-fmlp
Conflicts:
litmus/sched_cedf.c
Diffstat (limited to 'drivers/net/bnx2x/bnx2x_reg.h')
-rw-r--r-- | drivers/net/bnx2x/bnx2x_reg.h | 1111 |
1 files changed, 1072 insertions, 39 deletions
diff --git a/drivers/net/bnx2x/bnx2x_reg.h b/drivers/net/bnx2x/bnx2x_reg.h index a1f3bf0cd630..86bba25d2d3f 100644 --- a/drivers/net/bnx2x/bnx2x_reg.h +++ b/drivers/net/bnx2x/bnx2x_reg.h | |||
@@ -1,6 +1,6 @@ | |||
1 | /* bnx2x_reg.h: Broadcom Everest network driver. | 1 | /* bnx2x_reg.h: Broadcom Everest network driver. |
2 | * | 2 | * |
3 | * Copyright (c) 2007-2009 Broadcom Corporation | 3 | * Copyright (c) 2007-2011 Broadcom Corporation |
4 | * | 4 | * |
5 | * This program is free software; you can redistribute it and/or modify | 5 | * This program is free software; you can redistribute it and/or modify |
6 | * it under the terms of the GNU General Public License as published by | 6 | * it under the terms of the GNU General Public License as published by |
@@ -18,18 +18,57 @@ | |||
18 | * WR - Write Clear (write 1 to clear the bit) | 18 | * WR - Write Clear (write 1 to clear the bit) |
19 | * | 19 | * |
20 | */ | 20 | */ |
21 | #ifndef BNX2X_REG_H | ||
22 | #define BNX2X_REG_H | ||
21 | 23 | ||
22 | 24 | #define ATC_ATC_INT_STS_REG_ADDRESS_ERROR (0x1<<0) | |
25 | #define ATC_ATC_INT_STS_REG_ATC_GPA_MULTIPLE_HITS (0x1<<2) | ||
26 | #define ATC_ATC_INT_STS_REG_ATC_IREQ_LESS_THAN_STU (0x1<<5) | ||
27 | #define ATC_ATC_INT_STS_REG_ATC_RCPL_TO_EMPTY_CNT (0x1<<3) | ||
28 | #define ATC_ATC_INT_STS_REG_ATC_TCPL_ERROR (0x1<<4) | ||
29 | #define ATC_ATC_INT_STS_REG_ATC_TCPL_TO_NOT_PEND (0x1<<1) | ||
30 | /* [RW 1] Initiate the ATC array - reset all the valid bits */ | ||
31 | #define ATC_REG_ATC_INIT_ARRAY 0x1100b8 | ||
32 | /* [R 1] ATC initalization done */ | ||
33 | #define ATC_REG_ATC_INIT_DONE 0x1100bc | ||
34 | /* [RC 6] Interrupt register #0 read clear */ | ||
35 | #define ATC_REG_ATC_INT_STS_CLR 0x1101c0 | ||
36 | /* [RW 19] Interrupt mask register #0 read/write */ | ||
37 | #define BRB1_REG_BRB1_INT_MASK 0x60128 | ||
23 | /* [R 19] Interrupt register #0 read */ | 38 | /* [R 19] Interrupt register #0 read */ |
24 | #define BRB1_REG_BRB1_INT_STS 0x6011c | 39 | #define BRB1_REG_BRB1_INT_STS 0x6011c |
25 | /* [RW 4] Parity mask register #0 read/write */ | 40 | /* [RW 4] Parity mask register #0 read/write */ |
26 | #define BRB1_REG_BRB1_PRTY_MASK 0x60138 | 41 | #define BRB1_REG_BRB1_PRTY_MASK 0x60138 |
27 | /* [R 4] Parity register #0 read */ | 42 | /* [R 4] Parity register #0 read */ |
28 | #define BRB1_REG_BRB1_PRTY_STS 0x6012c | 43 | #define BRB1_REG_BRB1_PRTY_STS 0x6012c |
44 | /* [RC 4] Parity register #0 read clear */ | ||
45 | #define BRB1_REG_BRB1_PRTY_STS_CLR 0x60130 | ||
29 | /* [RW 10] At address BRB1_IND_FREE_LIST_PRS_CRDT initialize free head. At | 46 | /* [RW 10] At address BRB1_IND_FREE_LIST_PRS_CRDT initialize free head. At |
30 | address BRB1_IND_FREE_LIST_PRS_CRDT+1 initialize free tail. At address | 47 | * address BRB1_IND_FREE_LIST_PRS_CRDT+1 initialize free tail. At address |
31 | BRB1_IND_FREE_LIST_PRS_CRDT+2 initialize parser initial credit. */ | 48 | * BRB1_IND_FREE_LIST_PRS_CRDT+2 initialize parser initial credit. Warning - |
49 | * following reset the first rbc access to this reg must be write; there can | ||
50 | * be no more rbc writes after the first one; there can be any number of rbc | ||
51 | * read following the first write; rbc access not following these rules will | ||
52 | * result in hang condition. */ | ||
32 | #define BRB1_REG_FREE_LIST_PRS_CRDT 0x60200 | 53 | #define BRB1_REG_FREE_LIST_PRS_CRDT 0x60200 |
54 | /* [RW 10] The number of free blocks below which the full signal to class 0 | ||
55 | * is asserted */ | ||
56 | #define BRB1_REG_FULL_0_XOFF_THRESHOLD_0 0x601d0 | ||
57 | /* [RW 10] The number of free blocks above which the full signal to class 0 | ||
58 | * is de-asserted */ | ||
59 | #define BRB1_REG_FULL_0_XON_THRESHOLD_0 0x601d4 | ||
60 | /* [RW 10] The number of free blocks below which the full signal to class 1 | ||
61 | * is asserted */ | ||
62 | #define BRB1_REG_FULL_1_XOFF_THRESHOLD_0 0x601d8 | ||
63 | /* [RW 10] The number of free blocks above which the full signal to class 1 | ||
64 | * is de-asserted */ | ||
65 | #define BRB1_REG_FULL_1_XON_THRESHOLD_0 0x601dc | ||
66 | /* [RW 10] The number of free blocks below which the full signal to the LB | ||
67 | * port is asserted */ | ||
68 | #define BRB1_REG_FULL_LB_XOFF_THRESHOLD 0x601e0 | ||
69 | /* [RW 10] The number of free blocks above which the full signal to the LB | ||
70 | * port is de-asserted */ | ||
71 | #define BRB1_REG_FULL_LB_XON_THRESHOLD 0x601e4 | ||
33 | /* [RW 10] The number of free blocks above which the High_llfc signal to | 72 | /* [RW 10] The number of free blocks above which the High_llfc signal to |
34 | interface #n is de-asserted. */ | 73 | interface #n is de-asserted. */ |
35 | #define BRB1_REG_HIGH_LLFC_HIGH_THRESHOLD_0 0x6014c | 74 | #define BRB1_REG_HIGH_LLFC_HIGH_THRESHOLD_0 0x6014c |
@@ -44,6 +83,9 @@ | |||
44 | /* [RW 10] The number of free blocks below which the Low_llfc signal to | 83 | /* [RW 10] The number of free blocks below which the Low_llfc signal to |
45 | interface #n is asserted. */ | 84 | interface #n is asserted. */ |
46 | #define BRB1_REG_LOW_LLFC_LOW_THRESHOLD_0 0x6015c | 85 | #define BRB1_REG_LOW_LLFC_LOW_THRESHOLD_0 0x6015c |
86 | /* [RW 10] The number of blocks guarantied for the MAC port */ | ||
87 | #define BRB1_REG_MAC_GUARANTIED_0 0x601e8 | ||
88 | #define BRB1_REG_MAC_GUARANTIED_1 0x60240 | ||
47 | /* [R 24] The number of full blocks. */ | 89 | /* [R 24] The number of full blocks. */ |
48 | #define BRB1_REG_NUM_OF_FULL_BLOCKS 0x60090 | 90 | #define BRB1_REG_NUM_OF_FULL_BLOCKS 0x60090 |
49 | /* [ST 32] The number of cycles that the write_full signal towards MAC #0 | 91 | /* [ST 32] The number of cycles that the write_full signal towards MAC #0 |
@@ -55,7 +97,19 @@ | |||
55 | asserted. */ | 97 | asserted. */ |
56 | #define BRB1_REG_NUM_OF_PAUSE_CYCLES_0 0x600b8 | 98 | #define BRB1_REG_NUM_OF_PAUSE_CYCLES_0 0x600b8 |
57 | #define BRB1_REG_NUM_OF_PAUSE_CYCLES_1 0x600bc | 99 | #define BRB1_REG_NUM_OF_PAUSE_CYCLES_1 0x600bc |
58 | /* [RW 10] Write client 0: De-assert pause threshold. */ | 100 | /* [RW 10] The number of free blocks below which the pause signal to class 0 |
101 | * is asserted */ | ||
102 | #define BRB1_REG_PAUSE_0_XOFF_THRESHOLD_0 0x601c0 | ||
103 | /* [RW 10] The number of free blocks above which the pause signal to class 0 | ||
104 | * is de-asserted */ | ||
105 | #define BRB1_REG_PAUSE_0_XON_THRESHOLD_0 0x601c4 | ||
106 | /* [RW 10] The number of free blocks below which the pause signal to class 1 | ||
107 | * is asserted */ | ||
108 | #define BRB1_REG_PAUSE_1_XOFF_THRESHOLD_0 0x601c8 | ||
109 | /* [RW 10] The number of free blocks above which the pause signal to class 1 | ||
110 | * is de-asserted */ | ||
111 | #define BRB1_REG_PAUSE_1_XON_THRESHOLD_0 0x601cc | ||
112 | /* [RW 10] Write client 0: De-assert pause threshold. Not Functional */ | ||
59 | #define BRB1_REG_PAUSE_HIGH_THRESHOLD_0 0x60078 | 113 | #define BRB1_REG_PAUSE_HIGH_THRESHOLD_0 0x60078 |
60 | #define BRB1_REG_PAUSE_HIGH_THRESHOLD_1 0x6007c | 114 | #define BRB1_REG_PAUSE_HIGH_THRESHOLD_1 0x6007c |
61 | /* [RW 10] Write client 0: Assert pause threshold. */ | 115 | /* [RW 10] Write client 0: Assert pause threshold. */ |
@@ -82,8 +136,12 @@ | |||
82 | #define CCM_REG_CCM_INT_MASK 0xd01e4 | 136 | #define CCM_REG_CCM_INT_MASK 0xd01e4 |
83 | /* [R 11] Interrupt register #0 read */ | 137 | /* [R 11] Interrupt register #0 read */ |
84 | #define CCM_REG_CCM_INT_STS 0xd01d8 | 138 | #define CCM_REG_CCM_INT_STS 0xd01d8 |
139 | /* [RW 27] Parity mask register #0 read/write */ | ||
140 | #define CCM_REG_CCM_PRTY_MASK 0xd01f4 | ||
85 | /* [R 27] Parity register #0 read */ | 141 | /* [R 27] Parity register #0 read */ |
86 | #define CCM_REG_CCM_PRTY_STS 0xd01e8 | 142 | #define CCM_REG_CCM_PRTY_STS 0xd01e8 |
143 | /* [RC 27] Parity register #0 read clear */ | ||
144 | #define CCM_REG_CCM_PRTY_STS_CLR 0xd01ec | ||
87 | /* [RW 3] The size of AG context region 0 in REG-pairs. Designates the MS | 145 | /* [RW 3] The size of AG context region 0 in REG-pairs. Designates the MS |
88 | REG-pair number (e.g. if region 0 is 6 REG-pairs; the value should be 5). | 146 | REG-pair number (e.g. if region 0 is 6 REG-pairs; the value should be 5). |
89 | Is used to determine the number of the AG context REG-pairs written back; | 147 | Is used to determine the number of the AG context REG-pairs written back; |
@@ -117,9 +175,9 @@ | |||
117 | the initial credit value; read returns the current value of the credit | 175 | the initial credit value; read returns the current value of the credit |
118 | counter. Must be initialized to 1 at start-up. */ | 176 | counter. Must be initialized to 1 at start-up. */ |
119 | #define CCM_REG_CFC_INIT_CRD 0xd0204 | 177 | #define CCM_REG_CFC_INIT_CRD 0xd0204 |
120 | /* [RW 2] Auxillary counter flag Q number 1. */ | 178 | /* [RW 2] Auxiliary counter flag Q number 1. */ |
121 | #define CCM_REG_CNT_AUX1_Q 0xd00c8 | 179 | #define CCM_REG_CNT_AUX1_Q 0xd00c8 |
122 | /* [RW 2] Auxillary counter flag Q number 2. */ | 180 | /* [RW 2] Auxiliary counter flag Q number 2. */ |
123 | #define CCM_REG_CNT_AUX2_Q 0xd00cc | 181 | #define CCM_REG_CNT_AUX2_Q 0xd00cc |
124 | /* [RW 28] The CM header value for QM request (primary). */ | 182 | /* [RW 28] The CM header value for QM request (primary). */ |
125 | #define CCM_REG_CQM_CCM_HDR_P 0xd008c | 183 | #define CCM_REG_CQM_CCM_HDR_P 0xd008c |
@@ -300,6 +358,8 @@ | |||
300 | #define CDU_REG_CDU_PRTY_MASK 0x10104c | 358 | #define CDU_REG_CDU_PRTY_MASK 0x10104c |
301 | /* [R 5] Parity register #0 read */ | 359 | /* [R 5] Parity register #0 read */ |
302 | #define CDU_REG_CDU_PRTY_STS 0x101040 | 360 | #define CDU_REG_CDU_PRTY_STS 0x101040 |
361 | /* [RC 5] Parity register #0 read clear */ | ||
362 | #define CDU_REG_CDU_PRTY_STS_CLR 0x101044 | ||
303 | /* [RC 32] logging of error data in case of a CDU load error: | 363 | /* [RC 32] logging of error data in case of a CDU load error: |
304 | {expected_cid[15:0]; xpected_type[2:0]; xpected_region[2:0]; ctive_error; | 364 | {expected_cid[15:0]; xpected_type[2:0]; xpected_region[2:0]; ctive_error; |
305 | ype_error; ctual_active; ctual_compressed_context}; */ | 365 | ype_error; ctual_active; ctual_compressed_context}; */ |
@@ -331,6 +391,8 @@ | |||
331 | #define CFC_REG_CFC_PRTY_MASK 0x104118 | 391 | #define CFC_REG_CFC_PRTY_MASK 0x104118 |
332 | /* [R 4] Parity register #0 read */ | 392 | /* [R 4] Parity register #0 read */ |
333 | #define CFC_REG_CFC_PRTY_STS 0x10410c | 393 | #define CFC_REG_CFC_PRTY_STS 0x10410c |
394 | /* [RC 4] Parity register #0 read clear */ | ||
395 | #define CFC_REG_CFC_PRTY_STS_CLR 0x104110 | ||
334 | /* [RW 21] CID cam access (21:1 - Data; alid - 0) */ | 396 | /* [RW 21] CID cam access (21:1 - Data; alid - 0) */ |
335 | #define CFC_REG_CID_CAM 0x104800 | 397 | #define CFC_REG_CID_CAM 0x104800 |
336 | #define CFC_REG_CONTROL0 0x104028 | 398 | #define CFC_REG_CONTROL0 0x104028 |
@@ -362,6 +424,7 @@ | |||
362 | #define CFC_REG_NUM_LCIDS_ARRIVING 0x104004 | 424 | #define CFC_REG_NUM_LCIDS_ARRIVING 0x104004 |
363 | /* [R 9] Number of Leaving LCIDs in Link List Block */ | 425 | /* [R 9] Number of Leaving LCIDs in Link List Block */ |
364 | #define CFC_REG_NUM_LCIDS_LEAVING 0x104018 | 426 | #define CFC_REG_NUM_LCIDS_LEAVING 0x104018 |
427 | #define CFC_REG_WEAK_ENABLE_PF 0x104124 | ||
365 | /* [RW 8] The event id for aggregated interrupt 0 */ | 428 | /* [RW 8] The event id for aggregated interrupt 0 */ |
366 | #define CSDM_REG_AGG_INT_EVENT_0 0xc2038 | 429 | #define CSDM_REG_AGG_INT_EVENT_0 0xc2038 |
367 | #define CSDM_REG_AGG_INT_EVENT_10 0xc2060 | 430 | #define CSDM_REG_AGG_INT_EVENT_10 0xc2060 |
@@ -394,13 +457,13 @@ | |||
394 | #define CSDM_REG_AGG_INT_MODE_9 0xc21dc | 457 | #define CSDM_REG_AGG_INT_MODE_9 0xc21dc |
395 | /* [RW 13] The start address in the internal RAM for the cfc_rsp lcid */ | 458 | /* [RW 13] The start address in the internal RAM for the cfc_rsp lcid */ |
396 | #define CSDM_REG_CFC_RSP_START_ADDR 0xc2008 | 459 | #define CSDM_REG_CFC_RSP_START_ADDR 0xc2008 |
397 | /* [RW 16] The maximum value of the competion counter #0 */ | 460 | /* [RW 16] The maximum value of the completion counter #0 */ |
398 | #define CSDM_REG_CMP_COUNTER_MAX0 0xc201c | 461 | #define CSDM_REG_CMP_COUNTER_MAX0 0xc201c |
399 | /* [RW 16] The maximum value of the competion counter #1 */ | 462 | /* [RW 16] The maximum value of the completion counter #1 */ |
400 | #define CSDM_REG_CMP_COUNTER_MAX1 0xc2020 | 463 | #define CSDM_REG_CMP_COUNTER_MAX1 0xc2020 |
401 | /* [RW 16] The maximum value of the competion counter #2 */ | 464 | /* [RW 16] The maximum value of the completion counter #2 */ |
402 | #define CSDM_REG_CMP_COUNTER_MAX2 0xc2024 | 465 | #define CSDM_REG_CMP_COUNTER_MAX2 0xc2024 |
403 | /* [RW 16] The maximum value of the competion counter #3 */ | 466 | /* [RW 16] The maximum value of the completion counter #3 */ |
404 | #define CSDM_REG_CMP_COUNTER_MAX3 0xc2028 | 467 | #define CSDM_REG_CMP_COUNTER_MAX3 0xc2028 |
405 | /* [RW 13] The start address in the internal RAM for the completion | 468 | /* [RW 13] The start address in the internal RAM for the completion |
406 | counters. */ | 469 | counters. */ |
@@ -415,6 +478,8 @@ | |||
415 | #define CSDM_REG_CSDM_PRTY_MASK 0xc22bc | 478 | #define CSDM_REG_CSDM_PRTY_MASK 0xc22bc |
416 | /* [R 11] Parity register #0 read */ | 479 | /* [R 11] Parity register #0 read */ |
417 | #define CSDM_REG_CSDM_PRTY_STS 0xc22b0 | 480 | #define CSDM_REG_CSDM_PRTY_STS 0xc22b0 |
481 | /* [RC 11] Parity register #0 read clear */ | ||
482 | #define CSDM_REG_CSDM_PRTY_STS_CLR 0xc22b4 | ||
418 | #define CSDM_REG_ENABLE_IN1 0xc2238 | 483 | #define CSDM_REG_ENABLE_IN1 0xc2238 |
419 | #define CSDM_REG_ENABLE_IN2 0xc223c | 484 | #define CSDM_REG_ENABLE_IN2 0xc223c |
420 | #define CSDM_REG_ENABLE_OUT1 0xc2240 | 485 | #define CSDM_REG_ENABLE_OUT1 0xc2240 |
@@ -505,6 +570,9 @@ | |||
505 | /* [R 32] Parity register #0 read */ | 570 | /* [R 32] Parity register #0 read */ |
506 | #define CSEM_REG_CSEM_PRTY_STS_0 0x200124 | 571 | #define CSEM_REG_CSEM_PRTY_STS_0 0x200124 |
507 | #define CSEM_REG_CSEM_PRTY_STS_1 0x200134 | 572 | #define CSEM_REG_CSEM_PRTY_STS_1 0x200134 |
573 | /* [RC 32] Parity register #0 read clear */ | ||
574 | #define CSEM_REG_CSEM_PRTY_STS_CLR_0 0x200128 | ||
575 | #define CSEM_REG_CSEM_PRTY_STS_CLR_1 0x200138 | ||
508 | #define CSEM_REG_ENABLE_IN 0x2000a4 | 576 | #define CSEM_REG_ENABLE_IN 0x2000a4 |
509 | #define CSEM_REG_ENABLE_OUT 0x2000a8 | 577 | #define CSEM_REG_ENABLE_OUT 0x2000a8 |
510 | /* [RW 32] This address space contains all registers and memories that are | 578 | /* [RW 32] This address space contains all registers and memories that are |
@@ -590,10 +658,19 @@ | |||
590 | #define CSEM_REG_TS_8_AS 0x200058 | 658 | #define CSEM_REG_TS_8_AS 0x200058 |
591 | /* [RW 3] The arbitration scheme of time_slot 9 */ | 659 | /* [RW 3] The arbitration scheme of time_slot 9 */ |
592 | #define CSEM_REG_TS_9_AS 0x20005c | 660 | #define CSEM_REG_TS_9_AS 0x20005c |
661 | /* [W 7] VF or PF ID for reset error bit. Values 0-63 reset error bit for 64 | ||
662 | * VF; values 64-67 reset error for 4 PF; values 68-127 are not valid. */ | ||
663 | #define CSEM_REG_VFPF_ERR_NUM 0x200380 | ||
593 | /* [RW 1] Parity mask register #0 read/write */ | 664 | /* [RW 1] Parity mask register #0 read/write */ |
594 | #define DBG_REG_DBG_PRTY_MASK 0xc0a8 | 665 | #define DBG_REG_DBG_PRTY_MASK 0xc0a8 |
595 | /* [R 1] Parity register #0 read */ | 666 | /* [R 1] Parity register #0 read */ |
596 | #define DBG_REG_DBG_PRTY_STS 0xc09c | 667 | #define DBG_REG_DBG_PRTY_STS 0xc09c |
668 | /* [RC 1] Parity register #0 read clear */ | ||
669 | #define DBG_REG_DBG_PRTY_STS_CLR 0xc0a0 | ||
670 | /* [RW 1] When set the DMAE will process the commands as in E1.5. 1.The | ||
671 | * function that is used is always SRC-PCI; 2.VF_Valid = 0; 3.VFID=0; | ||
672 | * 4.Completion function=0; 5.Error handling=0 */ | ||
673 | #define DMAE_REG_BACKWARD_COMP_EN 0x10207c | ||
597 | /* [RW 32] Commands memory. The address to command X; row Y is to calculated | 674 | /* [RW 32] Commands memory. The address to command X; row Y is to calculated |
598 | as 14*X+Y. */ | 675 | as 14*X+Y. */ |
599 | #define DMAE_REG_CMD_MEM 0x102400 | 676 | #define DMAE_REG_CMD_MEM 0x102400 |
@@ -610,6 +687,8 @@ | |||
610 | #define DMAE_REG_DMAE_PRTY_MASK 0x102064 | 687 | #define DMAE_REG_DMAE_PRTY_MASK 0x102064 |
611 | /* [R 4] Parity register #0 read */ | 688 | /* [R 4] Parity register #0 read */ |
612 | #define DMAE_REG_DMAE_PRTY_STS 0x102058 | 689 | #define DMAE_REG_DMAE_PRTY_STS 0x102058 |
690 | /* [RC 4] Parity register #0 read clear */ | ||
691 | #define DMAE_REG_DMAE_PRTY_STS_CLR 0x10205c | ||
613 | /* [RW 1] Command 0 go. */ | 692 | /* [RW 1] Command 0 go. */ |
614 | #define DMAE_REG_GO_C0 0x102080 | 693 | #define DMAE_REG_GO_C0 0x102080 |
615 | /* [RW 1] Command 1 go. */ | 694 | /* [RW 1] Command 1 go. */ |
@@ -676,6 +755,8 @@ | |||
676 | #define DORQ_REG_DORQ_PRTY_MASK 0x170190 | 755 | #define DORQ_REG_DORQ_PRTY_MASK 0x170190 |
677 | /* [R 2] Parity register #0 read */ | 756 | /* [R 2] Parity register #0 read */ |
678 | #define DORQ_REG_DORQ_PRTY_STS 0x170184 | 757 | #define DORQ_REG_DORQ_PRTY_STS 0x170184 |
758 | /* [RC 2] Parity register #0 read clear */ | ||
759 | #define DORQ_REG_DORQ_PRTY_STS_CLR 0x170188 | ||
679 | /* [RW 8] The address to write the DPM CID to STORM. */ | 760 | /* [RW 8] The address to write the DPM CID to STORM. */ |
680 | #define DORQ_REG_DPM_CID_ADDR 0x170044 | 761 | #define DORQ_REG_DPM_CID_ADDR 0x170044 |
681 | /* [RW 5] The DPM mode CID extraction offset. */ | 762 | /* [RW 5] The DPM mode CID extraction offset. */ |
@@ -742,9 +823,13 @@ | |||
742 | #define HC_REG_HC_PRTY_MASK 0x1080a0 | 823 | #define HC_REG_HC_PRTY_MASK 0x1080a0 |
743 | /* [R 3] Parity register #0 read */ | 824 | /* [R 3] Parity register #0 read */ |
744 | #define HC_REG_HC_PRTY_STS 0x108094 | 825 | #define HC_REG_HC_PRTY_STS 0x108094 |
745 | #define HC_REG_INT_MASK 0x108108 | 826 | /* [RC 3] Parity register #0 read clear */ |
827 | #define HC_REG_HC_PRTY_STS_CLR 0x108098 | ||
828 | #define HC_REG_INT_MASK 0x108108 | ||
746 | #define HC_REG_LEADING_EDGE_0 0x108040 | 829 | #define HC_REG_LEADING_EDGE_0 0x108040 |
747 | #define HC_REG_LEADING_EDGE_1 0x108048 | 830 | #define HC_REG_LEADING_EDGE_1 0x108048 |
831 | #define HC_REG_MAIN_MEMORY 0x108800 | ||
832 | #define HC_REG_MAIN_MEMORY_SIZE 152 | ||
748 | #define HC_REG_P0_PROD_CONS 0x108200 | 833 | #define HC_REG_P0_PROD_CONS 0x108200 |
749 | #define HC_REG_P1_PROD_CONS 0x108400 | 834 | #define HC_REG_P1_PROD_CONS 0x108400 |
750 | #define HC_REG_PBA_COMMAND 0x108140 | 835 | #define HC_REG_PBA_COMMAND 0x108140 |
@@ -758,6 +843,96 @@ | |||
758 | #define HC_REG_USTORM_ADDR_FOR_COALESCE 0x108068 | 843 | #define HC_REG_USTORM_ADDR_FOR_COALESCE 0x108068 |
759 | #define HC_REG_VQID_0 0x108008 | 844 | #define HC_REG_VQID_0 0x108008 |
760 | #define HC_REG_VQID_1 0x10800c | 845 | #define HC_REG_VQID_1 0x10800c |
846 | #define IGU_BLOCK_CONFIGURATION_REG_BACKWARD_COMP_EN (0x1<<1) | ||
847 | #define IGU_REG_ATTENTION_ACK_BITS 0x130108 | ||
848 | /* [R 4] Debug: attn_fsm */ | ||
849 | #define IGU_REG_ATTN_FSM 0x130054 | ||
850 | #define IGU_REG_ATTN_MSG_ADDR_H 0x13011c | ||
851 | #define IGU_REG_ATTN_MSG_ADDR_L 0x130120 | ||
852 | /* [R 4] Debug: [3] - attention write done message is pending (0-no pending; | ||
853 | * 1-pending). [2:0] = PFID. Pending means attention message was sent; but | ||
854 | * write done didn't receive. */ | ||
855 | #define IGU_REG_ATTN_WRITE_DONE_PENDING 0x130030 | ||
856 | #define IGU_REG_BLOCK_CONFIGURATION 0x130000 | ||
857 | #define IGU_REG_COMMAND_REG_32LSB_DATA 0x130124 | ||
858 | #define IGU_REG_COMMAND_REG_CTRL 0x13012c | ||
859 | /* [WB_R 32] Cleanup bit status per SB. 1 = cleanup is set. 0 = cleanup bit | ||
860 | * is clear. The bits in this registers are set and clear via the producer | ||
861 | * command. Data valid only in addresses 0-4. all the rest are zero. */ | ||
862 | #define IGU_REG_CSTORM_TYPE_0_SB_CLEANUP 0x130200 | ||
863 | /* [R 5] Debug: ctrl_fsm */ | ||
864 | #define IGU_REG_CTRL_FSM 0x130064 | ||
865 | /* [R 1] data available for error memory. If this bit is clear do not red | ||
866 | * from error_handling_memory. */ | ||
867 | #define IGU_REG_ERROR_HANDLING_DATA_VALID 0x130130 | ||
868 | /* [RW 11] Parity mask register #0 read/write */ | ||
869 | #define IGU_REG_IGU_PRTY_MASK 0x1300a8 | ||
870 | /* [R 11] Parity register #0 read */ | ||
871 | #define IGU_REG_IGU_PRTY_STS 0x13009c | ||
872 | /* [RC 11] Parity register #0 read clear */ | ||
873 | #define IGU_REG_IGU_PRTY_STS_CLR 0x1300a0 | ||
874 | /* [R 4] Debug: int_handle_fsm */ | ||
875 | #define IGU_REG_INT_HANDLE_FSM 0x130050 | ||
876 | #define IGU_REG_LEADING_EDGE_LATCH 0x130134 | ||
877 | /* [RW 14] mapping CAM; relevant for E2 operating mode only. [0] - valid. | ||
878 | * [6:1] - vector number; [13:7] - FID (if VF - [13] = 0; [12:7] = VF | ||
879 | * number; if PF - [13] = 1; [12:10] = 0; [9:7] = PF number); */ | ||
880 | #define IGU_REG_MAPPING_MEMORY 0x131000 | ||
881 | #define IGU_REG_MAPPING_MEMORY_SIZE 136 | ||
882 | #define IGU_REG_PBA_STATUS_LSB 0x130138 | ||
883 | #define IGU_REG_PBA_STATUS_MSB 0x13013c | ||
884 | #define IGU_REG_PCI_PF_MSI_EN 0x130140 | ||
885 | #define IGU_REG_PCI_PF_MSIX_EN 0x130144 | ||
886 | #define IGU_REG_PCI_PF_MSIX_FUNC_MASK 0x130148 | ||
887 | /* [WB_R 32] Each bit represent the pending bits status for that SB. 0 = no | ||
888 | * pending; 1 = pending. Pendings means interrupt was asserted; and write | ||
889 | * done was not received. Data valid only in addresses 0-4. all the rest are | ||
890 | * zero. */ | ||
891 | #define IGU_REG_PENDING_BITS_STATUS 0x130300 | ||
892 | #define IGU_REG_PF_CONFIGURATION 0x130154 | ||
893 | /* [RW 20] producers only. E2 mode: address 0-135 match to the mapping | ||
894 | * memory; 136 - PF0 default prod; 137 PF1 default prod; 138 - PF2 default | ||
895 | * prod; 139 PF3 default prod; 140 - PF0 - ATTN prod; 141 - PF1 - ATTN prod; | ||
896 | * 142 - PF2 - ATTN prod; 143 - PF3 - ATTN prod; 144-147 reserved. E1.5 mode | ||
897 | * - In backward compatible mode; for non default SB; each even line in the | ||
898 | * memory holds the U producer and each odd line hold the C producer. The | ||
899 | * first 128 producer are for NDSB (PF0 - 0-31; PF1 - 32-63 and so on). The | ||
900 | * last 20 producers are for the DSB for each PF. each PF has five segments | ||
901 | * (the order inside each segment is PF0; PF1; PF2; PF3) - 128-131 U prods; | ||
902 | * 132-135 C prods; 136-139 X prods; 140-143 T prods; 144-147 ATTN prods; */ | ||
903 | #define IGU_REG_PROD_CONS_MEMORY 0x132000 | ||
904 | /* [R 3] Debug: pxp_arb_fsm */ | ||
905 | #define IGU_REG_PXP_ARB_FSM 0x130068 | ||
906 | /* [RW 6] Write one for each bit will reset the appropriate memory. When the | ||
907 | * memory reset finished the appropriate bit will be clear. Bit 0 - mapping | ||
908 | * memory; Bit 1 - SB memory; Bit 2 - SB interrupt and mask register; Bit 3 | ||
909 | * - MSIX memory; Bit 4 - PBA memory; Bit 5 - statistics; */ | ||
910 | #define IGU_REG_RESET_MEMORIES 0x130158 | ||
911 | /* [R 4] Debug: sb_ctrl_fsm */ | ||
912 | #define IGU_REG_SB_CTRL_FSM 0x13004c | ||
913 | #define IGU_REG_SB_INT_BEFORE_MASK_LSB 0x13015c | ||
914 | #define IGU_REG_SB_INT_BEFORE_MASK_MSB 0x130160 | ||
915 | #define IGU_REG_SB_MASK_LSB 0x130164 | ||
916 | #define IGU_REG_SB_MASK_MSB 0x130168 | ||
917 | /* [RW 16] Number of command that were dropped without causing an interrupt | ||
918 | * due to: read access for WO BAR address; or write access for RO BAR | ||
919 | * address or any access for reserved address or PCI function error is set | ||
920 | * and address is not MSIX; PBA or cleanup */ | ||
921 | #define IGU_REG_SILENT_DROP 0x13016c | ||
922 | /* [RW 10] Number of MSI/MSIX/ATTN messages sent for the function: 0-63 - | ||
923 | * number of MSIX messages per VF; 64-67 - number of MSI/MSIX messages per | ||
924 | * PF; 68-71 number of ATTN messages per PF */ | ||
925 | #define IGU_REG_STATISTIC_NUM_MESSAGE_SENT 0x130800 | ||
926 | /* [RW 32] Number of cycles the timer mask masking the IGU interrupt when a | ||
927 | * timer mask command arrives. Value must be bigger than 100. */ | ||
928 | #define IGU_REG_TIMER_MASKING_VALUE 0x13003c | ||
929 | #define IGU_REG_TRAILING_EDGE_LATCH 0x130104 | ||
930 | #define IGU_REG_VF_CONFIGURATION 0x130170 | ||
931 | /* [WB_R 32] Each bit represent write done pending bits status for that SB | ||
932 | * (MSI/MSIX message was sent and write done was not received yet). 0 = | ||
933 | * clear; 1 = set. Data valid only in addresses 0-4. all the rest are zero. */ | ||
934 | #define IGU_REG_WRITE_DONE_PENDING 0x130480 | ||
935 | #define MCP_A_REG_MCPR_SCRATCH 0x3a0000 | ||
761 | #define MCP_REG_MCPR_NVM_ACCESS_ENABLE 0x86424 | 936 | #define MCP_REG_MCPR_NVM_ACCESS_ENABLE 0x86424 |
762 | #define MCP_REG_MCPR_NVM_ADDR 0x8640c | 937 | #define MCP_REG_MCPR_NVM_ADDR 0x8640c |
763 | #define MCP_REG_MCPR_NVM_CFG4 0x8642c | 938 | #define MCP_REG_MCPR_NVM_CFG4 0x8642c |
@@ -880,6 +1055,11 @@ | |||
880 | rom_parity; [29] MCP Latched ump_rx_parity; [30] MCP Latched | 1055 | rom_parity; [29] MCP Latched ump_rx_parity; [30] MCP Latched |
881 | ump_tx_parity; [31] MCP Latched scpad_parity; */ | 1056 | ump_tx_parity; [31] MCP Latched scpad_parity; */ |
882 | #define MISC_REG_AEU_AFTER_INVERT_4_MCP 0xa458 | 1057 | #define MISC_REG_AEU_AFTER_INVERT_4_MCP 0xa458 |
1058 | /* [R 32] Read fifth 32 bit after inversion of function 0. Mapped as | ||
1059 | * follows: [0] PGLUE config_space; [1] PGLUE misc_flr; [2] PGLUE B RBC | ||
1060 | * attention [3] PGLUE B RBC parity; [4] ATC attention; [5] ATC parity; [6] | ||
1061 | * CNIG attention (reserved); [7] CNIG parity (reserved); [31-8] Reserved; */ | ||
1062 | #define MISC_REG_AEU_AFTER_INVERT_5_FUNC_0 0xa700 | ||
883 | /* [W 14] write to this register results with the clear of the latched | 1063 | /* [W 14] write to this register results with the clear of the latched |
884 | signals; one in d0 clears RBCR latch; one in d1 clears RBCT latch; one in | 1064 | signals; one in d0 clears RBCR latch; one in d1 clears RBCT latch; one in |
885 | d2 clears RBCN latch; one in d3 clears RBCU latch; one in d4 clears RBCP | 1065 | d2 clears RBCN latch; one in d3 clears RBCU latch; one in d4 clears RBCP |
@@ -1251,6 +1431,7 @@ | |||
1251 | #define MISC_REG_E1HMF_MODE 0xa5f8 | 1431 | #define MISC_REG_E1HMF_MODE 0xa5f8 |
1252 | /* [RW 32] Debug only: spare RW register reset by core reset */ | 1432 | /* [RW 32] Debug only: spare RW register reset by core reset */ |
1253 | #define MISC_REG_GENERIC_CR_0 0xa460 | 1433 | #define MISC_REG_GENERIC_CR_0 0xa460 |
1434 | #define MISC_REG_GENERIC_CR_1 0xa464 | ||
1254 | /* [RW 32] Debug only: spare RW register reset by por reset */ | 1435 | /* [RW 32] Debug only: spare RW register reset by por reset */ |
1255 | #define MISC_REG_GENERIC_POR_1 0xa474 | 1436 | #define MISC_REG_GENERIC_POR_1 0xa474 |
1256 | /* [RW 32] GPIO. [31-28] FLOAT port 0; [27-24] FLOAT port 0; When any of | 1437 | /* [RW 32] GPIO. [31-28] FLOAT port 0; [27-24] FLOAT port 0; When any of |
@@ -1347,6 +1528,8 @@ | |||
1347 | #define MISC_REG_MISC_PRTY_MASK 0xa398 | 1528 | #define MISC_REG_MISC_PRTY_MASK 0xa398 |
1348 | /* [R 1] Parity register #0 read */ | 1529 | /* [R 1] Parity register #0 read */ |
1349 | #define MISC_REG_MISC_PRTY_STS 0xa38c | 1530 | #define MISC_REG_MISC_PRTY_STS 0xa38c |
1531 | /* [RC 1] Parity register #0 read clear */ | ||
1532 | #define MISC_REG_MISC_PRTY_STS_CLR 0xa390 | ||
1350 | #define MISC_REG_NIG_WOL_P0 0xa270 | 1533 | #define MISC_REG_NIG_WOL_P0 0xa270 |
1351 | #define MISC_REG_NIG_WOL_P1 0xa274 | 1534 | #define MISC_REG_NIG_WOL_P1 0xa274 |
1352 | /* [R 1] If set indicate that the pcie_rst_b was asserted without perst | 1535 | /* [R 1] If set indicate that the pcie_rst_b was asserted without perst |
@@ -1373,6 +1556,14 @@ | |||
1373 | #define MISC_REG_PLL_STORM_CTRL_2 0xa298 | 1556 | #define MISC_REG_PLL_STORM_CTRL_2 0xa298 |
1374 | #define MISC_REG_PLL_STORM_CTRL_3 0xa29c | 1557 | #define MISC_REG_PLL_STORM_CTRL_3 0xa29c |
1375 | #define MISC_REG_PLL_STORM_CTRL_4 0xa2a0 | 1558 | #define MISC_REG_PLL_STORM_CTRL_4 0xa2a0 |
1559 | /* [R 1] Status of 4 port mode enable input pin. */ | ||
1560 | #define MISC_REG_PORT4MODE_EN 0xa750 | ||
1561 | /* [RW 2] 4 port mode enable overwrite.[0] - Overwrite control; if it is 0 - | ||
1562 | * the port4mode_en output is equal to 4 port mode input pin; if it is 1 - | ||
1563 | * the port4mode_en output is equal to bit[1] of this register; [1] - | ||
1564 | * Overwrite value. If bit[0] of this register is 1 this is the value that | ||
1565 | * receives the port4mode_en output . */ | ||
1566 | #define MISC_REG_PORT4MODE_EN_OVWR 0xa720 | ||
1376 | /* [RW 32] reset reg#2; rite/read one = the specific block is out of reset; | 1567 | /* [RW 32] reset reg#2; rite/read one = the specific block is out of reset; |
1377 | write/read zero = the specific block is in reset; addr 0-wr- the write | 1568 | write/read zero = the specific block is in reset; addr 0-wr- the write |
1378 | value will be written to the register; addr 1-set - one will be written | 1569 | value will be written to the register; addr 1-set - one will be written |
@@ -1442,7 +1633,7 @@ | |||
1442 | (~misc_registers_sw_timer_cfg_4.sw_timer_cfg_4[1] ) is set */ | 1633 | (~misc_registers_sw_timer_cfg_4.sw_timer_cfg_4[1] ) is set */ |
1443 | #define MISC_REG_SW_TIMER_RELOAD_VAL_4 0xa2fc | 1634 | #define MISC_REG_SW_TIMER_RELOAD_VAL_4 0xa2fc |
1444 | /* [RW 32] the value of the counter for sw timers1-8. there are 8 addresses | 1635 | /* [RW 32] the value of the counter for sw timers1-8. there are 8 addresses |
1445 | in this register. addres 0 - timer 1; address 1 - timer 2, ... address 7 - | 1636 | in this register. address 0 - timer 1; address 1 - timer 2, ... address 7 - |
1446 | timer 8 */ | 1637 | timer 8 */ |
1447 | #define MISC_REG_SW_TIMER_VAL 0xa5c0 | 1638 | #define MISC_REG_SW_TIMER_VAL 0xa5c0 |
1448 | /* [RW 1] Set by the MCP to remember if one or more of the drivers is/are | 1639 | /* [RW 1] Set by the MCP to remember if one or more of the drivers is/are |
@@ -1453,6 +1644,8 @@ | |||
1453 | #define NIG_LLH0_BRB1_DRV_MASK_REG_LLH0_BRB1_DRV_MASK_NO_VLAN (0x1<<4) | 1644 | #define NIG_LLH0_BRB1_DRV_MASK_REG_LLH0_BRB1_DRV_MASK_NO_VLAN (0x1<<4) |
1454 | #define NIG_LLH0_BRB1_DRV_MASK_REG_LLH0_BRB1_DRV_MASK_UNCST (0x1<<2) | 1645 | #define NIG_LLH0_BRB1_DRV_MASK_REG_LLH0_BRB1_DRV_MASK_UNCST (0x1<<2) |
1455 | #define NIG_LLH0_BRB1_DRV_MASK_REG_LLH0_BRB1_DRV_MASK_VLAN (0x1<<3) | 1646 | #define NIG_LLH0_BRB1_DRV_MASK_REG_LLH0_BRB1_DRV_MASK_VLAN (0x1<<3) |
1647 | #define NIG_LLH0_XCM_MASK_REG_LLH0_XCM_MASK_BCN (0x1<<0) | ||
1648 | #define NIG_LLH1_XCM_MASK_REG_LLH1_XCM_MASK_BCN (0x1<<0) | ||
1456 | #define NIG_MASK_INTERRUPT_PORT0_REG_MASK_EMAC0_MISC_MI_INT (0x1<<0) | 1649 | #define NIG_MASK_INTERRUPT_PORT0_REG_MASK_EMAC0_MISC_MI_INT (0x1<<0) |
1457 | #define NIG_MASK_INTERRUPT_PORT0_REG_MASK_SERDES0_LINK_STATUS (0x1<<9) | 1650 | #define NIG_MASK_INTERRUPT_PORT0_REG_MASK_SERDES0_LINK_STATUS (0x1<<9) |
1458 | #define NIG_MASK_INTERRUPT_PORT0_REG_MASK_XGXS0_LINK10G (0x1<<15) | 1651 | #define NIG_MASK_INTERRUPT_PORT0_REG_MASK_XGXS0_LINK10G (0x1<<15) |
@@ -1582,12 +1775,16 @@ | |||
1582 | ~ppp_enable.ppp_enable = 0 and pause_enable.pause_enable =0 for the same | 1775 | ~ppp_enable.ppp_enable = 0 and pause_enable.pause_enable =0 for the same |
1583 | port */ | 1776 | port */ |
1584 | #define NIG_REG_LLFC_ENABLE_0 0x16208 | 1777 | #define NIG_REG_LLFC_ENABLE_0 0x16208 |
1778 | #define NIG_REG_LLFC_ENABLE_1 0x1620c | ||
1585 | /* [RW 16] classes are high-priority for port0 */ | 1779 | /* [RW 16] classes are high-priority for port0 */ |
1586 | #define NIG_REG_LLFC_HIGH_PRIORITY_CLASSES_0 0x16058 | 1780 | #define NIG_REG_LLFC_HIGH_PRIORITY_CLASSES_0 0x16058 |
1781 | #define NIG_REG_LLFC_HIGH_PRIORITY_CLASSES_1 0x1605c | ||
1587 | /* [RW 16] classes are low-priority for port0 */ | 1782 | /* [RW 16] classes are low-priority for port0 */ |
1588 | #define NIG_REG_LLFC_LOW_PRIORITY_CLASSES_0 0x16060 | 1783 | #define NIG_REG_LLFC_LOW_PRIORITY_CLASSES_0 0x16060 |
1784 | #define NIG_REG_LLFC_LOW_PRIORITY_CLASSES_1 0x16064 | ||
1589 | /* [RW 1] Output enable of message to LLFC BMAC IF for port0 */ | 1785 | /* [RW 1] Output enable of message to LLFC BMAC IF for port0 */ |
1590 | #define NIG_REG_LLFC_OUT_EN_0 0x160c8 | 1786 | #define NIG_REG_LLFC_OUT_EN_0 0x160c8 |
1787 | #define NIG_REG_LLFC_OUT_EN_1 0x160cc | ||
1591 | #define NIG_REG_LLH0_ACPI_PAT_0_CRC 0x1015c | 1788 | #define NIG_REG_LLH0_ACPI_PAT_0_CRC 0x1015c |
1592 | #define NIG_REG_LLH0_ACPI_PAT_6_LEN 0x10154 | 1789 | #define NIG_REG_LLH0_ACPI_PAT_6_LEN 0x10154 |
1593 | #define NIG_REG_LLH0_BRB1_DRV_MASK 0x10244 | 1790 | #define NIG_REG_LLH0_BRB1_DRV_MASK 0x10244 |
@@ -1612,6 +1809,8 @@ | |||
1612 | /* [RW 8] event id for llh0 */ | 1809 | /* [RW 8] event id for llh0 */ |
1613 | #define NIG_REG_LLH0_EVENT_ID 0x10084 | 1810 | #define NIG_REG_LLH0_EVENT_ID 0x10084 |
1614 | #define NIG_REG_LLH0_FUNC_EN 0x160fc | 1811 | #define NIG_REG_LLH0_FUNC_EN 0x160fc |
1812 | #define NIG_REG_LLH0_FUNC_MEM 0x16180 | ||
1813 | #define NIG_REG_LLH0_FUNC_MEM_ENABLE 0x16140 | ||
1615 | #define NIG_REG_LLH0_FUNC_VLAN_ID 0x16100 | 1814 | #define NIG_REG_LLH0_FUNC_VLAN_ID 0x16100 |
1616 | /* [RW 1] Determine the IP version to look for in | 1815 | /* [RW 1] Determine the IP version to look for in |
1617 | ~nig_registers_llh0_dest_ip_0.llh0_dest_ip_0. 0 - IPv6; 1-IPv4 */ | 1816 | ~nig_registers_llh0_dest_ip_0.llh0_dest_ip_0. 0 - IPv6; 1-IPv4 */ |
@@ -1635,6 +1834,9 @@ | |||
1635 | #define NIG_REG_LLH1_ERROR_MASK 0x10090 | 1834 | #define NIG_REG_LLH1_ERROR_MASK 0x10090 |
1636 | /* [RW 8] event id for llh1 */ | 1835 | /* [RW 8] event id for llh1 */ |
1637 | #define NIG_REG_LLH1_EVENT_ID 0x10088 | 1836 | #define NIG_REG_LLH1_EVENT_ID 0x10088 |
1837 | #define NIG_REG_LLH1_FUNC_MEM 0x161c0 | ||
1838 | #define NIG_REG_LLH1_FUNC_MEM_ENABLE 0x16160 | ||
1839 | #define NIG_REG_LLH1_FUNC_MEM_SIZE 16 | ||
1638 | /* [RW 8] init credit counter for port1 in LLH */ | 1840 | /* [RW 8] init credit counter for port1 in LLH */ |
1639 | #define NIG_REG_LLH1_XCM_INIT_CREDIT 0x10564 | 1841 | #define NIG_REG_LLH1_XCM_INIT_CREDIT 0x10564 |
1640 | #define NIG_REG_LLH1_XCM_MASK 0x10134 | 1842 | #define NIG_REG_LLH1_XCM_MASK 0x10134 |
@@ -1656,17 +1858,106 @@ | |||
1656 | /* [R 32] Interrupt register #0 read */ | 1858 | /* [R 32] Interrupt register #0 read */ |
1657 | #define NIG_REG_NIG_INT_STS_0 0x103b0 | 1859 | #define NIG_REG_NIG_INT_STS_0 0x103b0 |
1658 | #define NIG_REG_NIG_INT_STS_1 0x103c0 | 1860 | #define NIG_REG_NIG_INT_STS_1 0x103c0 |
1659 | /* [R 32] Parity register #0 read */ | 1861 | /* [R 32] Legacy E1 and E1H location for parity error status register. */ |
1660 | #define NIG_REG_NIG_PRTY_STS 0x103d0 | 1862 | #define NIG_REG_NIG_PRTY_STS 0x103d0 |
1863 | /* [R 32] Parity register #0 read */ | ||
1864 | #define NIG_REG_NIG_PRTY_STS_0 0x183bc | ||
1865 | #define NIG_REG_NIG_PRTY_STS_1 0x183cc | ||
1866 | /* [RW 6] Bit-map indicating which L2 hdrs may appear after the basic | ||
1867 | * Ethernet header. */ | ||
1868 | #define NIG_REG_P0_HDRS_AFTER_BASIC 0x18038 | ||
1869 | /* [RW 1] HW PFC enable bit. Set this bit to enable the PFC functionality in | ||
1870 | * the NIG. Other flow control modes such as PAUSE and SAFC/LLFC should be | ||
1871 | * disabled when this bit is set. */ | ||
1872 | #define NIG_REG_P0_HWPFC_ENABLE 0x18078 | ||
1873 | #define NIG_REG_P0_LLH_FUNC_MEM2 0x18480 | ||
1874 | #define NIG_REG_P0_LLH_FUNC_MEM2_ENABLE 0x18440 | ||
1875 | /* [RW 32] Eight 4-bit configurations for specifying which COS (0-15 for | ||
1876 | * future expansion) each priorty is to be mapped to. Bits 3:0 specify the | ||
1877 | * COS for priority 0. Bits 31:28 specify the COS for priority 7. The 3-bit | ||
1878 | * priority field is extracted from the outer-most VLAN in receive packet. | ||
1879 | * Only COS 0 and COS 1 are supported in E2. */ | ||
1880 | #define NIG_REG_P0_PKT_PRIORITY_TO_COS 0x18054 | ||
1881 | /* [RW 16] Bit-map indicating which SAFC/PFC priorities to map to COS 0. A | ||
1882 | * priority is mapped to COS 0 when the corresponding mask bit is 1. More | ||
1883 | * than one bit may be set; allowing multiple priorities to be mapped to one | ||
1884 | * COS. */ | ||
1885 | #define NIG_REG_P0_RX_COS0_PRIORITY_MASK 0x18058 | ||
1886 | /* [RW 16] Bit-map indicating which SAFC/PFC priorities to map to COS 1. A | ||
1887 | * priority is mapped to COS 1 when the corresponding mask bit is 1. More | ||
1888 | * than one bit may be set; allowing multiple priorities to be mapped to one | ||
1889 | * COS. */ | ||
1890 | #define NIG_REG_P0_RX_COS1_PRIORITY_MASK 0x1805c | ||
1891 | /* [RW 15] Specify which of the credit registers the client is to be mapped | ||
1892 | * to. Bits[2:0] are for client 0; bits [14:12] are for client 4. For | ||
1893 | * clients that are not subject to WFQ credit blocking - their | ||
1894 | * specifications here are not used. */ | ||
1895 | #define NIG_REG_P0_TX_ARB_CLIENT_CREDIT_MAP 0x180f0 | ||
1896 | /* [RW 5] Specify whether the client competes directly in the strict | ||
1897 | * priority arbiter. The bits are mapped according to client ID (client IDs | ||
1898 | * are defined in tx_arb_priority_client). Default value is set to enable | ||
1899 | * strict priorities for clients 0-2 -- management and debug traffic. */ | ||
1900 | #define NIG_REG_P0_TX_ARB_CLIENT_IS_STRICT 0x180e8 | ||
1901 | /* [RW 5] Specify whether the client is subject to WFQ credit blocking. The | ||
1902 | * bits are mapped according to client ID (client IDs are defined in | ||
1903 | * tx_arb_priority_client). Default value is 0 for not using WFQ credit | ||
1904 | * blocking. */ | ||
1905 | #define NIG_REG_P0_TX_ARB_CLIENT_IS_SUBJECT2WFQ 0x180ec | ||
1906 | /* [RW 32] Specify the upper bound that credit register 0 is allowed to | ||
1907 | * reach. */ | ||
1908 | #define NIG_REG_P0_TX_ARB_CREDIT_UPPER_BOUND_0 0x1810c | ||
1909 | #define NIG_REG_P0_TX_ARB_CREDIT_UPPER_BOUND_1 0x18110 | ||
1910 | /* [RW 32] Specify the weight (in bytes) to be added to credit register 0 | ||
1911 | * when it is time to increment. */ | ||
1912 | #define NIG_REG_P0_TX_ARB_CREDIT_WEIGHT_0 0x180f8 | ||
1913 | #define NIG_REG_P0_TX_ARB_CREDIT_WEIGHT_1 0x180fc | ||
1914 | /* [RW 12] Specify the number of strict priority arbitration slots between | ||
1915 | * two round-robin arbitration slots to avoid starvation. A value of 0 means | ||
1916 | * no strict priority cycles - the strict priority with anti-starvation | ||
1917 | * arbiter becomes a round-robin arbiter. */ | ||
1918 | #define NIG_REG_P0_TX_ARB_NUM_STRICT_ARB_SLOTS 0x180f4 | ||
1919 | /* [RW 15] Specify the client number to be assigned to each priority of the | ||
1920 | * strict priority arbiter. Priority 0 is the highest priority. Bits [2:0] | ||
1921 | * are for priority 0 client; bits [14:12] are for priority 4 client. The | ||
1922 | * clients are assigned the following IDs: 0-management; 1-debug traffic | ||
1923 | * from this port; 2-debug traffic from other port; 3-COS0 traffic; 4-COS1 | ||
1924 | * traffic. The reset value[14:0] is set to 0x4688 (15'b100_011_010_001_000) | ||
1925 | * for management at priority 0; debug traffic at priorities 1 and 2; COS0 | ||
1926 | * traffic at priority 3; and COS1 traffic at priority 4. */ | ||
1927 | #define NIG_REG_P0_TX_ARB_PRIORITY_CLIENT 0x180e4 | ||
1928 | #define NIG_REG_P1_LLH_FUNC_MEM2 0x184c0 | ||
1929 | #define NIG_REG_P1_LLH_FUNC_MEM2_ENABLE 0x18460 | ||
1930 | /* [RW 32] Eight 4-bit configurations for specifying which COS (0-15 for | ||
1931 | * future expansion) each priorty is to be mapped to. Bits 3:0 specify the | ||
1932 | * COS for priority 0. Bits 31:28 specify the COS for priority 7. The 3-bit | ||
1933 | * priority field is extracted from the outer-most VLAN in receive packet. | ||
1934 | * Only COS 0 and COS 1 are supported in E2. */ | ||
1935 | #define NIG_REG_P1_PKT_PRIORITY_TO_COS 0x181a8 | ||
1936 | /* [RW 16] Bit-map indicating which SAFC/PFC priorities to map to COS 0. A | ||
1937 | * priority is mapped to COS 0 when the corresponding mask bit is 1. More | ||
1938 | * than one bit may be set; allowing multiple priorities to be mapped to one | ||
1939 | * COS. */ | ||
1940 | #define NIG_REG_P1_RX_COS0_PRIORITY_MASK 0x181ac | ||
1941 | /* [RW 16] Bit-map indicating which SAFC/PFC priorities to map to COS 1. A | ||
1942 | * priority is mapped to COS 1 when the corresponding mask bit is 1. More | ||
1943 | * than one bit may be set; allowing multiple priorities to be mapped to one | ||
1944 | * COS. */ | ||
1945 | #define NIG_REG_P1_RX_COS1_PRIORITY_MASK 0x181b0 | ||
1661 | /* [RW 1] Pause enable for port0. This register may get 1 only when | 1946 | /* [RW 1] Pause enable for port0. This register may get 1 only when |
1662 | ~safc_enable.safc_enable = 0 and ppp_enable.ppp_enable =0 for the same | 1947 | ~safc_enable.safc_enable = 0 and ppp_enable.ppp_enable =0 for the same |
1663 | port */ | 1948 | port */ |
1664 | #define NIG_REG_PAUSE_ENABLE_0 0x160c0 | 1949 | #define NIG_REG_PAUSE_ENABLE_0 0x160c0 |
1950 | #define NIG_REG_PAUSE_ENABLE_1 0x160c4 | ||
1665 | /* [RW 1] Input enable for RX PBF LP IF */ | 1951 | /* [RW 1] Input enable for RX PBF LP IF */ |
1666 | #define NIG_REG_PBF_LB_IN_EN 0x100b4 | 1952 | #define NIG_REG_PBF_LB_IN_EN 0x100b4 |
1667 | /* [RW 1] Value of this register will be transmitted to port swap when | 1953 | /* [RW 1] Value of this register will be transmitted to port swap when |
1668 | ~nig_registers_strap_override.strap_override =1 */ | 1954 | ~nig_registers_strap_override.strap_override =1 */ |
1669 | #define NIG_REG_PORT_SWAP 0x10394 | 1955 | #define NIG_REG_PORT_SWAP 0x10394 |
1956 | /* [RW 1] PPP enable for port0. This register may get 1 only when | ||
1957 | * ~safc_enable.safc_enable = 0 and pause_enable.pause_enable =0 for the | ||
1958 | * same port */ | ||
1959 | #define NIG_REG_PPP_ENABLE_0 0x160b0 | ||
1960 | #define NIG_REG_PPP_ENABLE_1 0x160b4 | ||
1670 | /* [RW 1] output enable for RX parser descriptor IF */ | 1961 | /* [RW 1] output enable for RX parser descriptor IF */ |
1671 | #define NIG_REG_PRS_EOP_OUT_EN 0x10104 | 1962 | #define NIG_REG_PRS_EOP_OUT_EN 0x10104 |
1672 | /* [RW 1] Input enable for RX parser request IF */ | 1963 | /* [RW 1] Input enable for RX parser request IF */ |
@@ -1733,6 +2024,14 @@ | |||
1733 | #define NIG_STATUS_INTERRUPT_PORT0_REG_STATUS_XGXS0_LINK10G (0x1<<15) | 2024 | #define NIG_STATUS_INTERRUPT_PORT0_REG_STATUS_XGXS0_LINK10G (0x1<<15) |
1734 | #define NIG_STATUS_INTERRUPT_PORT0_REG_STATUS_XGXS0_LINK_STATUS (0xf<<18) | 2025 | #define NIG_STATUS_INTERRUPT_PORT0_REG_STATUS_XGXS0_LINK_STATUS (0xf<<18) |
1735 | #define NIG_STATUS_INTERRUPT_PORT0_REG_STATUS_XGXS0_LINK_STATUS_SIZE 18 | 2026 | #define NIG_STATUS_INTERRUPT_PORT0_REG_STATUS_XGXS0_LINK_STATUS_SIZE 18 |
2027 | /* [RW 31] The upper bound of the weight of COS0 in the ETS command arbiter. */ | ||
2028 | #define PBF_REG_COS0_UPPER_BOUND 0x15c05c | ||
2029 | /* [RW 31] The weight of COS0 in the ETS command arbiter. */ | ||
2030 | #define PBF_REG_COS0_WEIGHT 0x15c054 | ||
2031 | /* [RW 31] The upper bound of the weight of COS1 in the ETS command arbiter. */ | ||
2032 | #define PBF_REG_COS1_UPPER_BOUND 0x15c060 | ||
2033 | /* [RW 31] The weight of COS1 in the ETS command arbiter. */ | ||
2034 | #define PBF_REG_COS1_WEIGHT 0x15c058 | ||
1736 | /* [RW 1] Disable processing further tasks from port 0 (after ending the | 2035 | /* [RW 1] Disable processing further tasks from port 0 (after ending the |
1737 | current task in process). */ | 2036 | current task in process). */ |
1738 | #define PBF_REG_DISABLE_NEW_TASK_PROC_P0 0x14005c | 2037 | #define PBF_REG_DISABLE_NEW_TASK_PROC_P0 0x14005c |
@@ -1742,6 +2041,17 @@ | |||
1742 | /* [RW 1] Disable processing further tasks from port 4 (after ending the | 2041 | /* [RW 1] Disable processing further tasks from port 4 (after ending the |
1743 | current task in process). */ | 2042 | current task in process). */ |
1744 | #define PBF_REG_DISABLE_NEW_TASK_PROC_P4 0x14006c | 2043 | #define PBF_REG_DISABLE_NEW_TASK_PROC_P4 0x14006c |
2044 | #define PBF_REG_DISABLE_PF 0x1402e8 | ||
2045 | /* [RW 1] Indicates that ETS is performed between the COSes in the command | ||
2046 | * arbiter. If reset strict priority w/ anti-starvation will be performed | ||
2047 | * w/o WFQ. */ | ||
2048 | #define PBF_REG_ETS_ENABLED 0x15c050 | ||
2049 | /* [RW 6] Bit-map indicating which L2 hdrs may appear after the basic | ||
2050 | * Ethernet header. */ | ||
2051 | #define PBF_REG_HDRS_AFTER_BASIC 0x15c0a8 | ||
2052 | /* [RW 1] Indicates which COS is conncted to the highest priority in the | ||
2053 | * command arbiter. */ | ||
2054 | #define PBF_REG_HIGH_PRIORITY_COS_NUM 0x15c04c | ||
1745 | #define PBF_REG_IF_ENABLE_REG 0x140044 | 2055 | #define PBF_REG_IF_ENABLE_REG 0x140044 |
1746 | /* [RW 1] Init bit. When set the initial credits are copied to the credit | 2056 | /* [RW 1] Init bit. When set the initial credits are copied to the credit |
1747 | registers (except the port credits). Should be set and then reset after | 2057 | registers (except the port credits). Should be set and then reset after |
@@ -1765,6 +2075,12 @@ | |||
1765 | #define PBF_REG_MAC_IF1_ENABLE 0x140034 | 2075 | #define PBF_REG_MAC_IF1_ENABLE 0x140034 |
1766 | /* [RW 1] Enable for the loopback interface. */ | 2076 | /* [RW 1] Enable for the loopback interface. */ |
1767 | #define PBF_REG_MAC_LB_ENABLE 0x140040 | 2077 | #define PBF_REG_MAC_LB_ENABLE 0x140040 |
2078 | /* [RW 6] Bit-map indicating which headers must appear in the packet */ | ||
2079 | #define PBF_REG_MUST_HAVE_HDRS 0x15c0c4 | ||
2080 | /* [RW 16] The number of strict priority arbitration slots between 2 RR | ||
2081 | * arbitration slots. A value of 0 means no strict priority cycles; i.e. the | ||
2082 | * strict-priority w/ anti-starvation arbiter is a RR arbiter. */ | ||
2083 | #define PBF_REG_NUM_STRICT_ARB_SLOTS 0x15c064 | ||
1768 | /* [RW 10] Port 0 threshold used by arbiter in 16 byte lines used when pause | 2084 | /* [RW 10] Port 0 threshold used by arbiter in 16 byte lines used when pause |
1769 | not suppoterd. */ | 2085 | not suppoterd. */ |
1770 | #define PBF_REG_P0_ARB_THRSH 0x1400e4 | 2086 | #define PBF_REG_P0_ARB_THRSH 0x1400e4 |
@@ -1795,6 +2111,10 @@ | |||
1795 | #define PBF_REG_PBF_INT_MASK 0x1401d4 | 2111 | #define PBF_REG_PBF_INT_MASK 0x1401d4 |
1796 | /* [R 5] Interrupt register #0 read */ | 2112 | /* [R 5] Interrupt register #0 read */ |
1797 | #define PBF_REG_PBF_INT_STS 0x1401c8 | 2113 | #define PBF_REG_PBF_INT_STS 0x1401c8 |
2114 | /* [RW 20] Parity mask register #0 read/write */ | ||
2115 | #define PBF_REG_PBF_PRTY_MASK 0x1401e4 | ||
2116 | /* [RC 20] Parity register #0 read clear */ | ||
2117 | #define PBF_REG_PBF_PRTY_STS_CLR 0x1401dc | ||
1798 | #define PB_REG_CONTROL 0 | 2118 | #define PB_REG_CONTROL 0 |
1799 | /* [RW 2] Interrupt mask register #0 read/write */ | 2119 | /* [RW 2] Interrupt mask register #0 read/write */ |
1800 | #define PB_REG_PB_INT_MASK 0x28 | 2120 | #define PB_REG_PB_INT_MASK 0x28 |
@@ -1804,6 +2124,261 @@ | |||
1804 | #define PB_REG_PB_PRTY_MASK 0x38 | 2124 | #define PB_REG_PB_PRTY_MASK 0x38 |
1805 | /* [R 4] Parity register #0 read */ | 2125 | /* [R 4] Parity register #0 read */ |
1806 | #define PB_REG_PB_PRTY_STS 0x2c | 2126 | #define PB_REG_PB_PRTY_STS 0x2c |
2127 | /* [RC 4] Parity register #0 read clear */ | ||
2128 | #define PB_REG_PB_PRTY_STS_CLR 0x30 | ||
2129 | #define PGLUE_B_PGLUE_B_INT_STS_REG_ADDRESS_ERROR (0x1<<0) | ||
2130 | #define PGLUE_B_PGLUE_B_INT_STS_REG_CSSNOOP_FIFO_OVERFLOW (0x1<<8) | ||
2131 | #define PGLUE_B_PGLUE_B_INT_STS_REG_INCORRECT_RCV_BEHAVIOR (0x1<<1) | ||
2132 | #define PGLUE_B_PGLUE_B_INT_STS_REG_TCPL_ERROR_ATTN (0x1<<6) | ||
2133 | #define PGLUE_B_PGLUE_B_INT_STS_REG_TCPL_IN_TWO_RCBS_ATTN (0x1<<7) | ||
2134 | #define PGLUE_B_PGLUE_B_INT_STS_REG_VF_GRC_SPACE_VIOLATION_ATTN (0x1<<4) | ||
2135 | #define PGLUE_B_PGLUE_B_INT_STS_REG_VF_LENGTH_VIOLATION_ATTN (0x1<<3) | ||
2136 | #define PGLUE_B_PGLUE_B_INT_STS_REG_VF_MSIX_BAR_VIOLATION_ATTN (0x1<<5) | ||
2137 | #define PGLUE_B_PGLUE_B_INT_STS_REG_WAS_ERROR_ATTN (0x1<<2) | ||
2138 | /* [R 8] Config space A attention dirty bits. Each bit indicates that the | ||
2139 | * corresponding PF generates config space A attention. Set by PXP. Reset by | ||
2140 | * MCP writing 1 to icfg_space_a_request_clr. Note: register contains bits | ||
2141 | * from both paths. */ | ||
2142 | #define PGLUE_B_REG_CFG_SPACE_A_REQUEST 0x9010 | ||
2143 | /* [R 8] Config space B attention dirty bits. Each bit indicates that the | ||
2144 | * corresponding PF generates config space B attention. Set by PXP. Reset by | ||
2145 | * MCP writing 1 to icfg_space_b_request_clr. Note: register contains bits | ||
2146 | * from both paths. */ | ||
2147 | #define PGLUE_B_REG_CFG_SPACE_B_REQUEST 0x9014 | ||
2148 | /* [RW 1] Type A PF enable inbound interrupt table for CSDM. 0 - disable; 1 | ||
2149 | * - enable. */ | ||
2150 | #define PGLUE_B_REG_CSDM_INB_INT_A_PF_ENABLE 0x9194 | ||
2151 | /* [RW 18] Type B VF inbound interrupt table for CSDM: bits[17:9]-mask; | ||
2152 | * its[8:0]-address. Bits [1:0] must be zero (DW resolution address). */ | ||
2153 | #define PGLUE_B_REG_CSDM_INB_INT_B_VF 0x916c | ||
2154 | /* [RW 1] Type B VF enable inbound interrupt table for CSDM. 0 - disable; 1 | ||
2155 | * - enable. */ | ||
2156 | #define PGLUE_B_REG_CSDM_INB_INT_B_VF_ENABLE 0x919c | ||
2157 | /* [RW 16] Start offset of CSDM zone A (queue zone) in the internal RAM */ | ||
2158 | #define PGLUE_B_REG_CSDM_START_OFFSET_A 0x9100 | ||
2159 | /* [RW 16] Start offset of CSDM zone B (legacy zone) in the internal RAM */ | ||
2160 | #define PGLUE_B_REG_CSDM_START_OFFSET_B 0x9108 | ||
2161 | /* [RW 5] VF Shift of CSDM zone B (legacy zone) in the internal RAM */ | ||
2162 | #define PGLUE_B_REG_CSDM_VF_SHIFT_B 0x9110 | ||
2163 | /* [RW 1] 0 - Zone A size is 136x32B; 1 - Zone A size is 152x32B. */ | ||
2164 | #define PGLUE_B_REG_CSDM_ZONE_A_SIZE_PF 0x91ac | ||
2165 | /* [R 8] FLR request attention dirty bits for PFs 0 to 7. Each bit indicates | ||
2166 | * that the FLR register of the corresponding PF was set. Set by PXP. Reset | ||
2167 | * by MCP writing 1 to flr_request_pf_7_0_clr. Note: register contains bits | ||
2168 | * from both paths. */ | ||
2169 | #define PGLUE_B_REG_FLR_REQUEST_PF_7_0 0x9028 | ||
2170 | /* [W 8] FLR request attention dirty bits clear for PFs 0 to 7. MCP writes 1 | ||
2171 | * to a bit in this register in order to clear the corresponding bit in | ||
2172 | * flr_request_pf_7_0 register. Note: register contains bits from both | ||
2173 | * paths. */ | ||
2174 | #define PGLUE_B_REG_FLR_REQUEST_PF_7_0_CLR 0x9418 | ||
2175 | /* [R 32] FLR request attention dirty bits for VFs 96 to 127. Each bit | ||
2176 | * indicates that the FLR register of the corresponding VF was set. Set by | ||
2177 | * PXP. Reset by MCP writing 1 to flr_request_vf_127_96_clr. */ | ||
2178 | #define PGLUE_B_REG_FLR_REQUEST_VF_127_96 0x9024 | ||
2179 | /* [R 32] FLR request attention dirty bits for VFs 0 to 31. Each bit | ||
2180 | * indicates that the FLR register of the corresponding VF was set. Set by | ||
2181 | * PXP. Reset by MCP writing 1 to flr_request_vf_31_0_clr. */ | ||
2182 | #define PGLUE_B_REG_FLR_REQUEST_VF_31_0 0x9018 | ||
2183 | /* [R 32] FLR request attention dirty bits for VFs 32 to 63. Each bit | ||
2184 | * indicates that the FLR register of the corresponding VF was set. Set by | ||
2185 | * PXP. Reset by MCP writing 1 to flr_request_vf_63_32_clr. */ | ||
2186 | #define PGLUE_B_REG_FLR_REQUEST_VF_63_32 0x901c | ||
2187 | /* [R 32] FLR request attention dirty bits for VFs 64 to 95. Each bit | ||
2188 | * indicates that the FLR register of the corresponding VF was set. Set by | ||
2189 | * PXP. Reset by MCP writing 1 to flr_request_vf_95_64_clr. */ | ||
2190 | #define PGLUE_B_REG_FLR_REQUEST_VF_95_64 0x9020 | ||
2191 | /* [R 8] Each bit indicates an incorrect behavior in user RX interface. Bit | ||
2192 | * 0 - Target memory read arrived with a correctable error. Bit 1 - Target | ||
2193 | * memory read arrived with an uncorrectable error. Bit 2 - Configuration RW | ||
2194 | * arrived with a correctable error. Bit 3 - Configuration RW arrived with | ||
2195 | * an uncorrectable error. Bit 4 - Completion with Configuration Request | ||
2196 | * Retry Status. Bit 5 - Expansion ROM access received with a write request. | ||
2197 | * Bit 6 - Completion with pcie_rx_err of 0000; CMPL_STATUS of non-zero; and | ||
2198 | * pcie_rx_last not asserted. Bit 7 - Completion with pcie_rx_err of 1010; | ||
2199 | * and pcie_rx_last not asserted. */ | ||
2200 | #define PGLUE_B_REG_INCORRECT_RCV_DETAILS 0x9068 | ||
2201 | #define PGLUE_B_REG_INTERNAL_PFID_ENABLE_MASTER 0x942c | ||
2202 | #define PGLUE_B_REG_INTERNAL_PFID_ENABLE_TARGET_READ 0x9430 | ||
2203 | #define PGLUE_B_REG_INTERNAL_PFID_ENABLE_TARGET_WRITE 0x9434 | ||
2204 | #define PGLUE_B_REG_INTERNAL_VFID_ENABLE 0x9438 | ||
2205 | /* [R 9] Interrupt register #0 read */ | ||
2206 | #define PGLUE_B_REG_PGLUE_B_INT_STS 0x9298 | ||
2207 | /* [RC 9] Interrupt register #0 read clear */ | ||
2208 | #define PGLUE_B_REG_PGLUE_B_INT_STS_CLR 0x929c | ||
2209 | /* [R 2] Parity register #0 read */ | ||
2210 | #define PGLUE_B_REG_PGLUE_B_PRTY_STS 0x92a8 | ||
2211 | /* [R 13] Details of first request received with error. [2:0] - PFID. [3] - | ||
2212 | * VF_VALID. [9:4] - VFID. [11:10] - Error Code - 0 - Indicates Completion | ||
2213 | * Timeout of a User Tx non-posted request. 1 - unsupported request. 2 - | ||
2214 | * completer abort. 3 - Illegal value for this field. [12] valid - indicates | ||
2215 | * if there was a completion error since the last time this register was | ||
2216 | * cleared. */ | ||
2217 | #define PGLUE_B_REG_RX_ERR_DETAILS 0x9080 | ||
2218 | /* [R 18] Details of first ATS Translation Completion request received with | ||
2219 | * error. [2:0] - PFID. [3] - VF_VALID. [9:4] - VFID. [11:10] - Error Code - | ||
2220 | * 0 - Indicates Completion Timeout of a User Tx non-posted request. 1 - | ||
2221 | * unsupported request. 2 - completer abort. 3 - Illegal value for this | ||
2222 | * field. [16:12] - ATC OTB EntryID. [17] valid - indicates if there was a | ||
2223 | * completion error since the last time this register was cleared. */ | ||
2224 | #define PGLUE_B_REG_RX_TCPL_ERR_DETAILS 0x9084 | ||
2225 | /* [W 8] Debug only - Shadow BME bits clear for PFs 0 to 7. MCP writes 1 to | ||
2226 | * a bit in this register in order to clear the corresponding bit in | ||
2227 | * shadow_bme_pf_7_0 register. MCP should never use this unless a | ||
2228 | * work-around is needed. Note: register contains bits from both paths. */ | ||
2229 | #define PGLUE_B_REG_SHADOW_BME_PF_7_0_CLR 0x9458 | ||
2230 | /* [R 8] SR IOV disabled attention dirty bits. Each bit indicates that the | ||
2231 | * VF enable register of the corresponding PF is written to 0 and was | ||
2232 | * previously 1. Set by PXP. Reset by MCP writing 1 to | ||
2233 | * sr_iov_disabled_request_clr. Note: register contains bits from both | ||
2234 | * paths. */ | ||
2235 | #define PGLUE_B_REG_SR_IOV_DISABLED_REQUEST 0x9030 | ||
2236 | /* [R 32] Indicates the status of tags 32-63. 0 - tags is used - read | ||
2237 | * completion did not return yet. 1 - tag is unused. Same functionality as | ||
2238 | * pxp2_registers_pgl_exp_rom_data2 for tags 0-31. */ | ||
2239 | #define PGLUE_B_REG_TAGS_63_32 0x9244 | ||
2240 | /* [RW 1] Type A PF enable inbound interrupt table for TSDM. 0 - disable; 1 | ||
2241 | * - enable. */ | ||
2242 | #define PGLUE_B_REG_TSDM_INB_INT_A_PF_ENABLE 0x9170 | ||
2243 | /* [RW 16] Start offset of TSDM zone A (queue zone) in the internal RAM */ | ||
2244 | #define PGLUE_B_REG_TSDM_START_OFFSET_A 0x90c4 | ||
2245 | /* [RW 16] Start offset of TSDM zone B (legacy zone) in the internal RAM */ | ||
2246 | #define PGLUE_B_REG_TSDM_START_OFFSET_B 0x90cc | ||
2247 | /* [RW 5] VF Shift of TSDM zone B (legacy zone) in the internal RAM */ | ||
2248 | #define PGLUE_B_REG_TSDM_VF_SHIFT_B 0x90d4 | ||
2249 | /* [RW 1] 0 - Zone A size is 136x32B; 1 - Zone A size is 152x32B. */ | ||
2250 | #define PGLUE_B_REG_TSDM_ZONE_A_SIZE_PF 0x91a0 | ||
2251 | /* [R 32] Address [31:0] of first read request not submitted due to error */ | ||
2252 | #define PGLUE_B_REG_TX_ERR_RD_ADD_31_0 0x9098 | ||
2253 | /* [R 32] Address [63:32] of first read request not submitted due to error */ | ||
2254 | #define PGLUE_B_REG_TX_ERR_RD_ADD_63_32 0x909c | ||
2255 | /* [R 31] Details of first read request not submitted due to error. [4:0] | ||
2256 | * VQID. [5] TREQ. 1 - Indicates the request is a Translation Request. | ||
2257 | * [20:8] - Length in bytes. [23:21] - PFID. [24] - VF_VALID. [30:25] - | ||
2258 | * VFID. */ | ||
2259 | #define PGLUE_B_REG_TX_ERR_RD_DETAILS 0x90a0 | ||
2260 | /* [R 26] Details of first read request not submitted due to error. [15:0] | ||
2261 | * Request ID. [19:16] client ID. [20] - last SR. [24:21] - Error type - | ||
2262 | * [21] - Indicates was_error was set; [22] - Indicates BME was cleared; | ||
2263 | * [23] - Indicates FID_enable was cleared; [24] - Indicates VF with parent | ||
2264 | * PF FLR_request or IOV_disable_request dirty bit is set. [25] valid - | ||
2265 | * indicates if there was a request not submitted due to error since the | ||
2266 | * last time this register was cleared. */ | ||
2267 | #define PGLUE_B_REG_TX_ERR_RD_DETAILS2 0x90a4 | ||
2268 | /* [R 32] Address [31:0] of first write request not submitted due to error */ | ||
2269 | #define PGLUE_B_REG_TX_ERR_WR_ADD_31_0 0x9088 | ||
2270 | /* [R 32] Address [63:32] of first write request not submitted due to error */ | ||
2271 | #define PGLUE_B_REG_TX_ERR_WR_ADD_63_32 0x908c | ||
2272 | /* [R 31] Details of first write request not submitted due to error. [4:0] | ||
2273 | * VQID. [20:8] - Length in bytes. [23:21] - PFID. [24] - VF_VALID. [30:25] | ||
2274 | * - VFID. */ | ||
2275 | #define PGLUE_B_REG_TX_ERR_WR_DETAILS 0x9090 | ||
2276 | /* [R 26] Details of first write request not submitted due to error. [15:0] | ||
2277 | * Request ID. [19:16] client ID. [20] - last SR. [24:21] - Error type - | ||
2278 | * [21] - Indicates was_error was set; [22] - Indicates BME was cleared; | ||
2279 | * [23] - Indicates FID_enable was cleared; [24] - Indicates VF with parent | ||
2280 | * PF FLR_request or IOV_disable_request dirty bit is set. [25] valid - | ||
2281 | * indicates if there was a request not submitted due to error since the | ||
2282 | * last time this register was cleared. */ | ||
2283 | #define PGLUE_B_REG_TX_ERR_WR_DETAILS2 0x9094 | ||
2284 | /* [RW 10] Type A PF/VF inbound interrupt table for USDM: bits[9:5]-mask; | ||
2285 | * its[4:0]-address relative to start_offset_a. Bits [1:0] can have any | ||
2286 | * value (Byte resolution address). */ | ||
2287 | #define PGLUE_B_REG_USDM_INB_INT_A_0 0x9128 | ||
2288 | #define PGLUE_B_REG_USDM_INB_INT_A_1 0x912c | ||
2289 | #define PGLUE_B_REG_USDM_INB_INT_A_2 0x9130 | ||
2290 | #define PGLUE_B_REG_USDM_INB_INT_A_3 0x9134 | ||
2291 | #define PGLUE_B_REG_USDM_INB_INT_A_4 0x9138 | ||
2292 | #define PGLUE_B_REG_USDM_INB_INT_A_5 0x913c | ||
2293 | #define PGLUE_B_REG_USDM_INB_INT_A_6 0x9140 | ||
2294 | /* [RW 1] Type A PF enable inbound interrupt table for USDM. 0 - disable; 1 | ||
2295 | * - enable. */ | ||
2296 | #define PGLUE_B_REG_USDM_INB_INT_A_PF_ENABLE 0x917c | ||
2297 | /* [RW 1] Type A VF enable inbound interrupt table for USDM. 0 - disable; 1 | ||
2298 | * - enable. */ | ||
2299 | #define PGLUE_B_REG_USDM_INB_INT_A_VF_ENABLE 0x9180 | ||
2300 | /* [RW 1] Type B VF enable inbound interrupt table for USDM. 0 - disable; 1 | ||
2301 | * - enable. */ | ||
2302 | #define PGLUE_B_REG_USDM_INB_INT_B_VF_ENABLE 0x9184 | ||
2303 | /* [RW 16] Start offset of USDM zone A (queue zone) in the internal RAM */ | ||
2304 | #define PGLUE_B_REG_USDM_START_OFFSET_A 0x90d8 | ||
2305 | /* [RW 16] Start offset of USDM zone B (legacy zone) in the internal RAM */ | ||
2306 | #define PGLUE_B_REG_USDM_START_OFFSET_B 0x90e0 | ||
2307 | /* [RW 5] VF Shift of USDM zone B (legacy zone) in the internal RAM */ | ||
2308 | #define PGLUE_B_REG_USDM_VF_SHIFT_B 0x90e8 | ||
2309 | /* [RW 1] 0 - Zone A size is 136x32B; 1 - Zone A size is 152x32B. */ | ||
2310 | #define PGLUE_B_REG_USDM_ZONE_A_SIZE_PF 0x91a4 | ||
2311 | /* [R 26] Details of first target VF request accessing VF GRC space that | ||
2312 | * failed permission check. [14:0] Address. [15] w_nr: 0 - Read; 1 - Write. | ||
2313 | * [21:16] VFID. [24:22] - PFID. [25] valid - indicates if there was a | ||
2314 | * request accessing VF GRC space that failed permission check since the | ||
2315 | * last time this register was cleared. Permission checks are: function | ||
2316 | * permission; R/W permission; address range permission. */ | ||
2317 | #define PGLUE_B_REG_VF_GRC_SPACE_VIOLATION_DETAILS 0x9234 | ||
2318 | /* [R 31] Details of first target VF request with length violation (too many | ||
2319 | * DWs) accessing BAR0. [12:0] Address in DWs (bits [14:2] of byte address). | ||
2320 | * [14:13] BAR. [20:15] VFID. [23:21] - PFID. [29:24] - Length in DWs. [30] | ||
2321 | * valid - indicates if there was a request with length violation since the | ||
2322 | * last time this register was cleared. Length violations: length of more | ||
2323 | * than 2DWs; length of 2DWs and address not QW aligned; window is GRC and | ||
2324 | * length is more than 1 DW. */ | ||
2325 | #define PGLUE_B_REG_VF_LENGTH_VIOLATION_DETAILS 0x9230 | ||
2326 | /* [R 8] Was_error indication dirty bits for PFs 0 to 7. Each bit indicates | ||
2327 | * that there was a completion with uncorrectable error for the | ||
2328 | * corresponding PF. Set by PXP. Reset by MCP writing 1 to | ||
2329 | * was_error_pf_7_0_clr. */ | ||
2330 | #define PGLUE_B_REG_WAS_ERROR_PF_7_0 0x907c | ||
2331 | /* [W 8] Was_error indication dirty bits clear for PFs 0 to 7. MCP writes 1 | ||
2332 | * to a bit in this register in order to clear the corresponding bit in | ||
2333 | * flr_request_pf_7_0 register. */ | ||
2334 | #define PGLUE_B_REG_WAS_ERROR_PF_7_0_CLR 0x9470 | ||
2335 | /* [R 32] Was_error indication dirty bits for VFs 96 to 127. Each bit | ||
2336 | * indicates that there was a completion with uncorrectable error for the | ||
2337 | * corresponding VF. Set by PXP. Reset by MCP writing 1 to | ||
2338 | * was_error_vf_127_96_clr. */ | ||
2339 | #define PGLUE_B_REG_WAS_ERROR_VF_127_96 0x9078 | ||
2340 | /* [W 32] Was_error indication dirty bits clear for VFs 96 to 127. MCP | ||
2341 | * writes 1 to a bit in this register in order to clear the corresponding | ||
2342 | * bit in was_error_vf_127_96 register. */ | ||
2343 | #define PGLUE_B_REG_WAS_ERROR_VF_127_96_CLR 0x9474 | ||
2344 | /* [R 32] Was_error indication dirty bits for VFs 0 to 31. Each bit | ||
2345 | * indicates that there was a completion with uncorrectable error for the | ||
2346 | * corresponding VF. Set by PXP. Reset by MCP writing 1 to | ||
2347 | * was_error_vf_31_0_clr. */ | ||
2348 | #define PGLUE_B_REG_WAS_ERROR_VF_31_0 0x906c | ||
2349 | /* [W 32] Was_error indication dirty bits clear for VFs 0 to 31. MCP writes | ||
2350 | * 1 to a bit in this register in order to clear the corresponding bit in | ||
2351 | * was_error_vf_31_0 register. */ | ||
2352 | #define PGLUE_B_REG_WAS_ERROR_VF_31_0_CLR 0x9478 | ||
2353 | /* [R 32] Was_error indication dirty bits for VFs 32 to 63. Each bit | ||
2354 | * indicates that there was a completion with uncorrectable error for the | ||
2355 | * corresponding VF. Set by PXP. Reset by MCP writing 1 to | ||
2356 | * was_error_vf_63_32_clr. */ | ||
2357 | #define PGLUE_B_REG_WAS_ERROR_VF_63_32 0x9070 | ||
2358 | /* [W 32] Was_error indication dirty bits clear for VFs 32 to 63. MCP writes | ||
2359 | * 1 to a bit in this register in order to clear the corresponding bit in | ||
2360 | * was_error_vf_63_32 register. */ | ||
2361 | #define PGLUE_B_REG_WAS_ERROR_VF_63_32_CLR 0x947c | ||
2362 | /* [R 32] Was_error indication dirty bits for VFs 64 to 95. Each bit | ||
2363 | * indicates that there was a completion with uncorrectable error for the | ||
2364 | * corresponding VF. Set by PXP. Reset by MCP writing 1 to | ||
2365 | * was_error_vf_95_64_clr. */ | ||
2366 | #define PGLUE_B_REG_WAS_ERROR_VF_95_64 0x9074 | ||
2367 | /* [W 32] Was_error indication dirty bits clear for VFs 64 to 95. MCP writes | ||
2368 | * 1 to a bit in this register in order to clear the corresponding bit in | ||
2369 | * was_error_vf_95_64 register. */ | ||
2370 | #define PGLUE_B_REG_WAS_ERROR_VF_95_64_CLR 0x9480 | ||
2371 | /* [RW 1] Type A PF enable inbound interrupt table for XSDM. 0 - disable; 1 | ||
2372 | * - enable. */ | ||
2373 | #define PGLUE_B_REG_XSDM_INB_INT_A_PF_ENABLE 0x9188 | ||
2374 | /* [RW 16] Start offset of XSDM zone A (queue zone) in the internal RAM */ | ||
2375 | #define PGLUE_B_REG_XSDM_START_OFFSET_A 0x90ec | ||
2376 | /* [RW 16] Start offset of XSDM zone B (legacy zone) in the internal RAM */ | ||
2377 | #define PGLUE_B_REG_XSDM_START_OFFSET_B 0x90f4 | ||
2378 | /* [RW 5] VF Shift of XSDM zone B (legacy zone) in the internal RAM */ | ||
2379 | #define PGLUE_B_REG_XSDM_VF_SHIFT_B 0x90fc | ||
2380 | /* [RW 1] 0 - Zone A size is 136x32B; 1 - Zone A size is 152x32B. */ | ||
2381 | #define PGLUE_B_REG_XSDM_ZONE_A_SIZE_PF 0x91a8 | ||
1807 | #define PRS_REG_A_PRSU_20 0x40134 | 2382 | #define PRS_REG_A_PRSU_20 0x40134 |
1808 | /* [R 8] debug only: CFC load request current credit. Transaction based. */ | 2383 | /* [R 8] debug only: CFC load request current credit. Transaction based. */ |
1809 | #define PRS_REG_CFC_LD_CURRENT_CREDIT 0x40164 | 2384 | #define PRS_REG_CFC_LD_CURRENT_CREDIT 0x40164 |
@@ -1866,9 +2441,13 @@ | |||
1866 | #define PRS_REG_FLUSH_REGIONS_TYPE_5 0x40018 | 2441 | #define PRS_REG_FLUSH_REGIONS_TYPE_5 0x40018 |
1867 | #define PRS_REG_FLUSH_REGIONS_TYPE_6 0x4001c | 2442 | #define PRS_REG_FLUSH_REGIONS_TYPE_6 0x4001c |
1868 | #define PRS_REG_FLUSH_REGIONS_TYPE_7 0x40020 | 2443 | #define PRS_REG_FLUSH_REGIONS_TYPE_7 0x40020 |
2444 | /* [RW 6] Bit-map indicating which L2 hdrs may appear after the basic | ||
2445 | * Ethernet header. */ | ||
2446 | #define PRS_REG_HDRS_AFTER_BASIC 0x40238 | ||
1869 | /* [RW 4] The increment value to send in the CFC load request message */ | 2447 | /* [RW 4] The increment value to send in the CFC load request message */ |
1870 | #define PRS_REG_INC_VALUE 0x40048 | 2448 | #define PRS_REG_INC_VALUE 0x40048 |
1871 | /* [RW 1] If set indicates not to send messages to CFC on received packets */ | 2449 | /* [RW 6] Bit-map indicating which headers must appear in the packet */ |
2450 | #define PRS_REG_MUST_HAVE_HDRS 0x40254 | ||
1872 | #define PRS_REG_NIC_MODE 0x40138 | 2451 | #define PRS_REG_NIC_MODE 0x40138 |
1873 | /* [RW 8] The 8-bit event ID for cases where there is no match on the | 2452 | /* [RW 8] The 8-bit event ID for cases where there is no match on the |
1874 | connection. Used in packet start message to TCM. */ | 2453 | connection. Used in packet start message to TCM. */ |
@@ -1902,6 +2481,8 @@ | |||
1902 | #define PRS_REG_PRS_PRTY_MASK 0x401a4 | 2481 | #define PRS_REG_PRS_PRTY_MASK 0x401a4 |
1903 | /* [R 8] Parity register #0 read */ | 2482 | /* [R 8] Parity register #0 read */ |
1904 | #define PRS_REG_PRS_PRTY_STS 0x40198 | 2483 | #define PRS_REG_PRS_PRTY_STS 0x40198 |
2484 | /* [RC 8] Parity register #0 read clear */ | ||
2485 | #define PRS_REG_PRS_PRTY_STS_CLR 0x4019c | ||
1905 | /* [RW 8] Context region for pure acknowledge packets. Used in CFC load | 2486 | /* [RW 8] Context region for pure acknowledge packets. Used in CFC load |
1906 | request message */ | 2487 | request message */ |
1907 | #define PRS_REG_PURE_REGIONS 0x40024 | 2488 | #define PRS_REG_PURE_REGIONS 0x40024 |
@@ -1919,6 +2500,13 @@ | |||
1919 | #define PRS_REG_TCM_CURRENT_CREDIT 0x40160 | 2500 | #define PRS_REG_TCM_CURRENT_CREDIT 0x40160 |
1920 | /* [R 8] debug only: TSDM current credit. Transaction based. */ | 2501 | /* [R 8] debug only: TSDM current credit. Transaction based. */ |
1921 | #define PRS_REG_TSDM_CURRENT_CREDIT 0x4015c | 2502 | #define PRS_REG_TSDM_CURRENT_CREDIT 0x4015c |
2503 | #define PXP2_PXP2_INT_MASK_0_REG_PGL_CPL_AFT (0x1<<19) | ||
2504 | #define PXP2_PXP2_INT_MASK_0_REG_PGL_CPL_OF (0x1<<20) | ||
2505 | #define PXP2_PXP2_INT_MASK_0_REG_PGL_PCIE_ATTN (0x1<<22) | ||
2506 | #define PXP2_PXP2_INT_MASK_0_REG_PGL_READ_BLOCKED (0x1<<23) | ||
2507 | #define PXP2_PXP2_INT_MASK_0_REG_PGL_WRITE_BLOCKED (0x1<<24) | ||
2508 | #define PXP2_PXP2_INT_STS_0_REG_WR_PGLUE_EOP_ERROR (0x1<<7) | ||
2509 | #define PXP2_PXP2_INT_STS_CLR_0_REG_WR_PGLUE_EOP_ERROR (0x1<<7) | ||
1922 | /* [R 6] Debug only: Number of used entries in the data FIFO */ | 2510 | /* [R 6] Debug only: Number of used entries in the data FIFO */ |
1923 | #define PXP2_REG_HST_DATA_FIFO_STATUS 0x12047c | 2511 | #define PXP2_REG_HST_DATA_FIFO_STATUS 0x12047c |
1924 | /* [R 7] Debug only: Number of used entries in the header FIFO */ | 2512 | /* [R 7] Debug only: Number of used entries in the header FIFO */ |
@@ -2048,6 +2636,9 @@ | |||
2048 | /* [R 32] Parity register #0 read */ | 2636 | /* [R 32] Parity register #0 read */ |
2049 | #define PXP2_REG_PXP2_PRTY_STS_0 0x12057c | 2637 | #define PXP2_REG_PXP2_PRTY_STS_0 0x12057c |
2050 | #define PXP2_REG_PXP2_PRTY_STS_1 0x12058c | 2638 | #define PXP2_REG_PXP2_PRTY_STS_1 0x12058c |
2639 | /* [RC 32] Parity register #0 read clear */ | ||
2640 | #define PXP2_REG_PXP2_PRTY_STS_CLR_0 0x120580 | ||
2641 | #define PXP2_REG_PXP2_PRTY_STS_CLR_1 0x120590 | ||
2051 | /* [R 1] Debug only: The 'almost full' indication from each fifo (gives | 2642 | /* [R 1] Debug only: The 'almost full' indication from each fifo (gives |
2052 | indication about backpressure) */ | 2643 | indication about backpressure) */ |
2053 | #define PXP2_REG_RD_ALMOST_FULL_0 0x120424 | 2644 | #define PXP2_REG_RD_ALMOST_FULL_0 0x120424 |
@@ -2244,8 +2835,17 @@ | |||
2244 | /* [RW 1] When '1'; requests will enter input buffers but wont get out | 2835 | /* [RW 1] When '1'; requests will enter input buffers but wont get out |
2245 | towards the glue */ | 2836 | towards the glue */ |
2246 | #define PXP2_REG_RQ_DISABLE_INPUTS 0x120330 | 2837 | #define PXP2_REG_RQ_DISABLE_INPUTS 0x120330 |
2247 | /* [RW 1] 1 - SR will be aligned by 64B; 0 - SR will be aligned by 8B */ | 2838 | /* [RW 4] Determines alignment of write SRs when a request is split into |
2839 | * several SRs. 0 - 8B aligned. 1 - 64B aligned. 2 - 128B aligned. 3 - 256B | ||
2840 | * aligned. 4 - 512B aligned. */ | ||
2248 | #define PXP2_REG_RQ_DRAM_ALIGN 0x1205b0 | 2841 | #define PXP2_REG_RQ_DRAM_ALIGN 0x1205b0 |
2842 | /* [RW 4] Determines alignment of read SRs when a request is split into | ||
2843 | * several SRs. 0 - 8B aligned. 1 - 64B aligned. 2 - 128B aligned. 3 - 256B | ||
2844 | * aligned. 4 - 512B aligned. */ | ||
2845 | #define PXP2_REG_RQ_DRAM_ALIGN_RD 0x12092c | ||
2846 | /* [RW 1] when set the new alignment method (E2) will be applied; when reset | ||
2847 | * the original alignment method (E1 E1H) will be applied */ | ||
2848 | #define PXP2_REG_RQ_DRAM_ALIGN_SEL 0x120930 | ||
2249 | /* [RW 1] If 1 ILT failiue will not result in ELT access; An interrupt will | 2849 | /* [RW 1] If 1 ILT failiue will not result in ELT access; An interrupt will |
2250 | be asserted */ | 2850 | be asserted */ |
2251 | #define PXP2_REG_RQ_ELT_DISABLE 0x12066c | 2851 | #define PXP2_REG_RQ_ELT_DISABLE 0x12066c |
@@ -2415,7 +3015,7 @@ | |||
2415 | block. Should be used for close the gates. */ | 3015 | block. Should be used for close the gates. */ |
2416 | #define PXP_REG_HST_DISCARD_DOORBELLS 0x1030a4 | 3016 | #define PXP_REG_HST_DISCARD_DOORBELLS 0x1030a4 |
2417 | /* [R 1] debug only: '1' means this PSWHST is discarding doorbells. This bit | 3017 | /* [R 1] debug only: '1' means this PSWHST is discarding doorbells. This bit |
2418 | should update accoring to 'hst_discard_doorbells' register when the state | 3018 | should update according to 'hst_discard_doorbells' register when the state |
2419 | machine is idle */ | 3019 | machine is idle */ |
2420 | #define PXP_REG_HST_DISCARD_DOORBELLS_STATUS 0x1030a0 | 3020 | #define PXP_REG_HST_DISCARD_DOORBELLS_STATUS 0x1030a0 |
2421 | /* [RW 1] When 1; new internal writes arriving to the block are discarded. | 3021 | /* [RW 1] When 1; new internal writes arriving to the block are discarded. |
@@ -2423,7 +3023,7 @@ | |||
2423 | #define PXP_REG_HST_DISCARD_INTERNAL_WRITES 0x1030a8 | 3023 | #define PXP_REG_HST_DISCARD_INTERNAL_WRITES 0x1030a8 |
2424 | /* [R 6] debug only: A bit mask for all PSWHST internal write clients. '1' | 3024 | /* [R 6] debug only: A bit mask for all PSWHST internal write clients. '1' |
2425 | means this PSWHST is discarding inputs from this client. Each bit should | 3025 | means this PSWHST is discarding inputs from this client. Each bit should |
2426 | update accoring to 'hst_discard_internal_writes' register when the state | 3026 | update according to 'hst_discard_internal_writes' register when the state |
2427 | machine is idle. */ | 3027 | machine is idle. */ |
2428 | #define PXP_REG_HST_DISCARD_INTERNAL_WRITES_STATUS 0x10309c | 3028 | #define PXP_REG_HST_DISCARD_INTERNAL_WRITES_STATUS 0x10309c |
2429 | /* [WB 160] Used for initialization of the inbound interrupts memory */ | 3029 | /* [WB 160] Used for initialization of the inbound interrupts memory */ |
@@ -2436,10 +3036,13 @@ | |||
2436 | #define PXP_REG_PXP_INT_STS_1 0x103078 | 3036 | #define PXP_REG_PXP_INT_STS_1 0x103078 |
2437 | /* [RC 32] Interrupt register #0 read clear */ | 3037 | /* [RC 32] Interrupt register #0 read clear */ |
2438 | #define PXP_REG_PXP_INT_STS_CLR_0 0x10306c | 3038 | #define PXP_REG_PXP_INT_STS_CLR_0 0x10306c |
2439 | /* [RW 26] Parity mask register #0 read/write */ | 3039 | #define PXP_REG_PXP_INT_STS_CLR_1 0x10307c |
3040 | /* [RW 27] Parity mask register #0 read/write */ | ||
2440 | #define PXP_REG_PXP_PRTY_MASK 0x103094 | 3041 | #define PXP_REG_PXP_PRTY_MASK 0x103094 |
2441 | /* [R 26] Parity register #0 read */ | 3042 | /* [R 26] Parity register #0 read */ |
2442 | #define PXP_REG_PXP_PRTY_STS 0x103088 | 3043 | #define PXP_REG_PXP_PRTY_STS 0x103088 |
3044 | /* [RC 27] Parity register #0 read clear */ | ||
3045 | #define PXP_REG_PXP_PRTY_STS_CLR 0x10308c | ||
2443 | /* [RW 4] The activity counter initial increment value sent in the load | 3046 | /* [RW 4] The activity counter initial increment value sent in the load |
2444 | request */ | 3047 | request */ |
2445 | #define QM_REG_ACTCTRINITVAL_0 0x168040 | 3048 | #define QM_REG_ACTCTRINITVAL_0 0x168040 |
@@ -2566,6 +3169,7 @@ | |||
2566 | #define QM_REG_PAUSESTATE7 0x16e698 | 3169 | #define QM_REG_PAUSESTATE7 0x16e698 |
2567 | /* [RW 2] The PCI attributes field used in the PCI request. */ | 3170 | /* [RW 2] The PCI attributes field used in the PCI request. */ |
2568 | #define QM_REG_PCIREQAT 0x168054 | 3171 | #define QM_REG_PCIREQAT 0x168054 |
3172 | #define QM_REG_PF_EN 0x16e70c | ||
2569 | /* [R 16] The byte credit of port 0 */ | 3173 | /* [R 16] The byte credit of port 0 */ |
2570 | #define QM_REG_PORT0BYTECRD 0x168300 | 3174 | #define QM_REG_PORT0BYTECRD 0x168300 |
2571 | /* [R 16] The byte credit of port 1 */ | 3175 | /* [R 16] The byte credit of port 1 */ |
@@ -2595,6 +3199,8 @@ | |||
2595 | #define QM_REG_QM_PRTY_MASK 0x168454 | 3199 | #define QM_REG_QM_PRTY_MASK 0x168454 |
2596 | /* [R 12] Parity register #0 read */ | 3200 | /* [R 12] Parity register #0 read */ |
2597 | #define QM_REG_QM_PRTY_STS 0x168448 | 3201 | #define QM_REG_QM_PRTY_STS 0x168448 |
3202 | /* [RC 12] Parity register #0 read clear */ | ||
3203 | #define QM_REG_QM_PRTY_STS_CLR 0x16844c | ||
2598 | /* [R 32] Current queues in pipeline: Queues from 32 to 63 */ | 3204 | /* [R 32] Current queues in pipeline: Queues from 32 to 63 */ |
2599 | #define QM_REG_QSTATUS_HIGH 0x16802c | 3205 | #define QM_REG_QSTATUS_HIGH 0x16802c |
2600 | /* [R 32] Current queues in pipeline: Queues from 96 to 127 */ | 3206 | /* [R 32] Current queues in pipeline: Queues from 96 to 127 */ |
@@ -2880,6 +3486,8 @@ | |||
2880 | #define QM_REG_WRRWEIGHTS_9 0x168848 | 3486 | #define QM_REG_WRRWEIGHTS_9 0x168848 |
2881 | /* [R 6] Keep the fill level of the fifo from write client 1 */ | 3487 | /* [R 6] Keep the fill level of the fifo from write client 1 */ |
2882 | #define QM_REG_XQM_WRC_FIFOLVL 0x168000 | 3488 | #define QM_REG_XQM_WRC_FIFOLVL 0x168000 |
3489 | /* [W 1] reset to parity interrupt */ | ||
3490 | #define SEM_FAST_REG_PARITY_RST 0x18840 | ||
2883 | #define SRC_REG_COUNTFREE0 0x40500 | 3491 | #define SRC_REG_COUNTFREE0 0x40500 |
2884 | /* [RW 1] If clr the searcher is compatible to E1 A0 - support only two | 3492 | /* [RW 1] If clr the searcher is compatible to E1 A0 - support only two |
2885 | ports. If set the searcher support 8 functions. */ | 3493 | ports. If set the searcher support 8 functions. */ |
@@ -2908,6 +3516,8 @@ | |||
2908 | #define SRC_REG_SRC_PRTY_MASK 0x404c8 | 3516 | #define SRC_REG_SRC_PRTY_MASK 0x404c8 |
2909 | /* [R 3] Parity register #0 read */ | 3517 | /* [R 3] Parity register #0 read */ |
2910 | #define SRC_REG_SRC_PRTY_STS 0x404bc | 3518 | #define SRC_REG_SRC_PRTY_STS 0x404bc |
3519 | /* [RC 3] Parity register #0 read clear */ | ||
3520 | #define SRC_REG_SRC_PRTY_STS_CLR 0x404c0 | ||
2911 | /* [R 4] Used to read the value of the XX protection CAM occupancy counter. */ | 3521 | /* [R 4] Used to read the value of the XX protection CAM occupancy counter. */ |
2912 | #define TCM_REG_CAM_OCCUP 0x5017c | 3522 | #define TCM_REG_CAM_OCCUP 0x5017c |
2913 | /* [RW 1] CDU AG read Interface enable. If 0 - the request input is | 3523 | /* [RW 1] CDU AG read Interface enable. If 0 - the request input is |
@@ -3034,8 +3644,12 @@ | |||
3034 | #define TCM_REG_TCM_INT_MASK 0x501dc | 3644 | #define TCM_REG_TCM_INT_MASK 0x501dc |
3035 | /* [R 11] Interrupt register #0 read */ | 3645 | /* [R 11] Interrupt register #0 read */ |
3036 | #define TCM_REG_TCM_INT_STS 0x501d0 | 3646 | #define TCM_REG_TCM_INT_STS 0x501d0 |
3647 | /* [RW 27] Parity mask register #0 read/write */ | ||
3648 | #define TCM_REG_TCM_PRTY_MASK 0x501ec | ||
3037 | /* [R 27] Parity register #0 read */ | 3649 | /* [R 27] Parity register #0 read */ |
3038 | #define TCM_REG_TCM_PRTY_STS 0x501e0 | 3650 | #define TCM_REG_TCM_PRTY_STS 0x501e0 |
3651 | /* [RC 27] Parity register #0 read clear */ | ||
3652 | #define TCM_REG_TCM_PRTY_STS_CLR 0x501e4 | ||
3039 | /* [RW 3] The size of AG context region 0 in REG-pairs. Designates the MS | 3653 | /* [RW 3] The size of AG context region 0 in REG-pairs. Designates the MS |
3040 | REG-pair number (e.g. if region 0 is 6 REG-pairs; the value should be 5). | 3654 | REG-pair number (e.g. if region 0 is 6 REG-pairs; the value should be 5). |
3041 | Is used to determine the number of the AG context REG-pairs written back; | 3655 | Is used to determine the number of the AG context REG-pairs written back; |
@@ -3193,6 +3807,10 @@ | |||
3193 | #define TM_REG_TM_INT_MASK 0x1640fc | 3807 | #define TM_REG_TM_INT_MASK 0x1640fc |
3194 | /* [R 1] Interrupt register #0 read */ | 3808 | /* [R 1] Interrupt register #0 read */ |
3195 | #define TM_REG_TM_INT_STS 0x1640f0 | 3809 | #define TM_REG_TM_INT_STS 0x1640f0 |
3810 | /* [RW 7] Parity mask register #0 read/write */ | ||
3811 | #define TM_REG_TM_PRTY_MASK 0x16410c | ||
3812 | /* [RC 7] Parity register #0 read clear */ | ||
3813 | #define TM_REG_TM_PRTY_STS_CLR 0x164104 | ||
3196 | /* [RW 8] The event id for aggregated interrupt 0 */ | 3814 | /* [RW 8] The event id for aggregated interrupt 0 */ |
3197 | #define TSDM_REG_AGG_INT_EVENT_0 0x42038 | 3815 | #define TSDM_REG_AGG_INT_EVENT_0 0x42038 |
3198 | #define TSDM_REG_AGG_INT_EVENT_1 0x4203c | 3816 | #define TSDM_REG_AGG_INT_EVENT_1 0x4203c |
@@ -3204,13 +3822,13 @@ | |||
3204 | #define TSDM_REG_AGG_INT_T_1 0x420bc | 3822 | #define TSDM_REG_AGG_INT_T_1 0x420bc |
3205 | /* [RW 13] The start address in the internal RAM for the cfc_rsp lcid */ | 3823 | /* [RW 13] The start address in the internal RAM for the cfc_rsp lcid */ |
3206 | #define TSDM_REG_CFC_RSP_START_ADDR 0x42008 | 3824 | #define TSDM_REG_CFC_RSP_START_ADDR 0x42008 |
3207 | /* [RW 16] The maximum value of the competion counter #0 */ | 3825 | /* [RW 16] The maximum value of the completion counter #0 */ |
3208 | #define TSDM_REG_CMP_COUNTER_MAX0 0x4201c | 3826 | #define TSDM_REG_CMP_COUNTER_MAX0 0x4201c |
3209 | /* [RW 16] The maximum value of the competion counter #1 */ | 3827 | /* [RW 16] The maximum value of the completion counter #1 */ |
3210 | #define TSDM_REG_CMP_COUNTER_MAX1 0x42020 | 3828 | #define TSDM_REG_CMP_COUNTER_MAX1 0x42020 |
3211 | /* [RW 16] The maximum value of the competion counter #2 */ | 3829 | /* [RW 16] The maximum value of the completion counter #2 */ |
3212 | #define TSDM_REG_CMP_COUNTER_MAX2 0x42024 | 3830 | #define TSDM_REG_CMP_COUNTER_MAX2 0x42024 |
3213 | /* [RW 16] The maximum value of the competion counter #3 */ | 3831 | /* [RW 16] The maximum value of the completion counter #3 */ |
3214 | #define TSDM_REG_CMP_COUNTER_MAX3 0x42028 | 3832 | #define TSDM_REG_CMP_COUNTER_MAX3 0x42028 |
3215 | /* [RW 13] The start address in the internal RAM for the completion | 3833 | /* [RW 13] The start address in the internal RAM for the completion |
3216 | counters. */ | 3834 | counters. */ |
@@ -3273,6 +3891,8 @@ | |||
3273 | #define TSDM_REG_TSDM_PRTY_MASK 0x422bc | 3891 | #define TSDM_REG_TSDM_PRTY_MASK 0x422bc |
3274 | /* [R 11] Parity register #0 read */ | 3892 | /* [R 11] Parity register #0 read */ |
3275 | #define TSDM_REG_TSDM_PRTY_STS 0x422b0 | 3893 | #define TSDM_REG_TSDM_PRTY_STS 0x422b0 |
3894 | /* [RC 11] Parity register #0 read clear */ | ||
3895 | #define TSDM_REG_TSDM_PRTY_STS_CLR 0x422b4 | ||
3276 | /* [RW 5] The number of time_slots in the arbitration cycle */ | 3896 | /* [RW 5] The number of time_slots in the arbitration cycle */ |
3277 | #define TSEM_REG_ARB_CYCLE_SIZE 0x180034 | 3897 | #define TSEM_REG_ARB_CYCLE_SIZE 0x180034 |
3278 | /* [RW 3] The source that is associated with arbitration element 0. Source | 3898 | /* [RW 3] The source that is associated with arbitration element 0. Source |
@@ -3352,6 +3972,9 @@ | |||
3352 | #define TSEM_REG_SLOW_EXT_STORE_EMPTY 0x1802a0 | 3972 | #define TSEM_REG_SLOW_EXT_STORE_EMPTY 0x1802a0 |
3353 | /* [RW 8] List of free threads . There is a bit per thread. */ | 3973 | /* [RW 8] List of free threads . There is a bit per thread. */ |
3354 | #define TSEM_REG_THREADS_LIST 0x1802e4 | 3974 | #define TSEM_REG_THREADS_LIST 0x1802e4 |
3975 | /* [RC 32] Parity register #0 read clear */ | ||
3976 | #define TSEM_REG_TSEM_PRTY_STS_CLR_0 0x180118 | ||
3977 | #define TSEM_REG_TSEM_PRTY_STS_CLR_1 0x180128 | ||
3355 | /* [RW 3] The arbitration scheme of time_slot 0 */ | 3978 | /* [RW 3] The arbitration scheme of time_slot 0 */ |
3356 | #define TSEM_REG_TS_0_AS 0x180038 | 3979 | #define TSEM_REG_TS_0_AS 0x180038 |
3357 | /* [RW 3] The arbitration scheme of time_slot 10 */ | 3980 | /* [RW 3] The arbitration scheme of time_slot 10 */ |
@@ -3402,6 +4025,14 @@ | |||
3402 | /* [R 32] Parity register #0 read */ | 4025 | /* [R 32] Parity register #0 read */ |
3403 | #define TSEM_REG_TSEM_PRTY_STS_0 0x180114 | 4026 | #define TSEM_REG_TSEM_PRTY_STS_0 0x180114 |
3404 | #define TSEM_REG_TSEM_PRTY_STS_1 0x180124 | 4027 | #define TSEM_REG_TSEM_PRTY_STS_1 0x180124 |
4028 | /* [W 7] VF or PF ID for reset error bit. Values 0-63 reset error bit for 64 | ||
4029 | * VF; values 64-67 reset error for 4 PF; values 68-127 are not valid. */ | ||
4030 | #define TSEM_REG_VFPF_ERR_NUM 0x180380 | ||
4031 | /* [RW 32] Indirect access to AG context with 32-bits granularity. The bits | ||
4032 | * [10:8] of the address should be the offset within the accessed LCID | ||
4033 | * context; the bits [7:0] are the accessed LCID.Example: to write to REG10 | ||
4034 | * LCID100. The RBC address should be 12'ha64. */ | ||
4035 | #define UCM_REG_AG_CTX 0xe2000 | ||
3405 | /* [R 5] Used to read the XX protection CAM occupancy counter. */ | 4036 | /* [R 5] Used to read the XX protection CAM occupancy counter. */ |
3406 | #define UCM_REG_CAM_OCCUP 0xe0170 | 4037 | #define UCM_REG_CAM_OCCUP 0xe0170 |
3407 | /* [RW 1] CDU AG read Interface enable. If 0 - the request input is | 4038 | /* [RW 1] CDU AG read Interface enable. If 0 - the request input is |
@@ -3546,6 +4177,8 @@ | |||
3546 | #define UCM_REG_UCM_INT_STS 0xe01c8 | 4177 | #define UCM_REG_UCM_INT_STS 0xe01c8 |
3547 | /* [R 27] Parity register #0 read */ | 4178 | /* [R 27] Parity register #0 read */ |
3548 | #define UCM_REG_UCM_PRTY_STS 0xe01d8 | 4179 | #define UCM_REG_UCM_PRTY_STS 0xe01d8 |
4180 | /* [RC 27] Parity register #0 read clear */ | ||
4181 | #define UCM_REG_UCM_PRTY_STS_CLR 0xe01dc | ||
3549 | /* [RW 2] The size of AG context region 0 in REG-pairs. Designates the MS | 4182 | /* [RW 2] The size of AG context region 0 in REG-pairs. Designates the MS |
3550 | REG-pair number (e.g. if region 0 is 6 REG-pairs; the value should be 5). | 4183 | REG-pair number (e.g. if region 0 is 6 REG-pairs; the value should be 5). |
3551 | Is used to determine the number of the AG context REG-pairs written back; | 4184 | Is used to determine the number of the AG context REG-pairs written back; |
@@ -3651,13 +4284,13 @@ | |||
3651 | #define USDM_REG_AGG_INT_T_6 0xc40d0 | 4284 | #define USDM_REG_AGG_INT_T_6 0xc40d0 |
3652 | /* [RW 13] The start address in the internal RAM for the cfc_rsp lcid */ | 4285 | /* [RW 13] The start address in the internal RAM for the cfc_rsp lcid */ |
3653 | #define USDM_REG_CFC_RSP_START_ADDR 0xc4008 | 4286 | #define USDM_REG_CFC_RSP_START_ADDR 0xc4008 |
3654 | /* [RW 16] The maximum value of the competion counter #0 */ | 4287 | /* [RW 16] The maximum value of the completion counter #0 */ |
3655 | #define USDM_REG_CMP_COUNTER_MAX0 0xc401c | 4288 | #define USDM_REG_CMP_COUNTER_MAX0 0xc401c |
3656 | /* [RW 16] The maximum value of the competion counter #1 */ | 4289 | /* [RW 16] The maximum value of the completion counter #1 */ |
3657 | #define USDM_REG_CMP_COUNTER_MAX1 0xc4020 | 4290 | #define USDM_REG_CMP_COUNTER_MAX1 0xc4020 |
3658 | /* [RW 16] The maximum value of the competion counter #2 */ | 4291 | /* [RW 16] The maximum value of the completion counter #2 */ |
3659 | #define USDM_REG_CMP_COUNTER_MAX2 0xc4024 | 4292 | #define USDM_REG_CMP_COUNTER_MAX2 0xc4024 |
3660 | /* [RW 16] The maximum value of the competion counter #3 */ | 4293 | /* [RW 16] The maximum value of the completion counter #3 */ |
3661 | #define USDM_REG_CMP_COUNTER_MAX3 0xc4028 | 4294 | #define USDM_REG_CMP_COUNTER_MAX3 0xc4028 |
3662 | /* [RW 13] The start address in the internal RAM for the completion | 4295 | /* [RW 13] The start address in the internal RAM for the completion |
3663 | counters. */ | 4296 | counters. */ |
@@ -3722,6 +4355,8 @@ | |||
3722 | #define USDM_REG_USDM_PRTY_MASK 0xc42c0 | 4355 | #define USDM_REG_USDM_PRTY_MASK 0xc42c0 |
3723 | /* [R 11] Parity register #0 read */ | 4356 | /* [R 11] Parity register #0 read */ |
3724 | #define USDM_REG_USDM_PRTY_STS 0xc42b4 | 4357 | #define USDM_REG_USDM_PRTY_STS 0xc42b4 |
4358 | /* [RC 11] Parity register #0 read clear */ | ||
4359 | #define USDM_REG_USDM_PRTY_STS_CLR 0xc42b8 | ||
3725 | /* [RW 5] The number of time_slots in the arbitration cycle */ | 4360 | /* [RW 5] The number of time_slots in the arbitration cycle */ |
3726 | #define USEM_REG_ARB_CYCLE_SIZE 0x300034 | 4361 | #define USEM_REG_ARB_CYCLE_SIZE 0x300034 |
3727 | /* [RW 3] The source that is associated with arbitration element 0. Source | 4362 | /* [RW 3] The source that is associated with arbitration element 0. Source |
@@ -3851,6 +4486,20 @@ | |||
3851 | /* [R 32] Parity register #0 read */ | 4486 | /* [R 32] Parity register #0 read */ |
3852 | #define USEM_REG_USEM_PRTY_STS_0 0x300124 | 4487 | #define USEM_REG_USEM_PRTY_STS_0 0x300124 |
3853 | #define USEM_REG_USEM_PRTY_STS_1 0x300134 | 4488 | #define USEM_REG_USEM_PRTY_STS_1 0x300134 |
4489 | /* [RC 32] Parity register #0 read clear */ | ||
4490 | #define USEM_REG_USEM_PRTY_STS_CLR_0 0x300128 | ||
4491 | #define USEM_REG_USEM_PRTY_STS_CLR_1 0x300138 | ||
4492 | /* [W 7] VF or PF ID for reset error bit. Values 0-63 reset error bit for 64 | ||
4493 | * VF; values 64-67 reset error for 4 PF; values 68-127 are not valid. */ | ||
4494 | #define USEM_REG_VFPF_ERR_NUM 0x300380 | ||
4495 | #define VFC_MEMORIES_RST_REG_CAM_RST (0x1<<0) | ||
4496 | #define VFC_MEMORIES_RST_REG_RAM_RST (0x1<<1) | ||
4497 | #define VFC_REG_MEMORIES_RST 0x1943c | ||
4498 | /* [RW 32] Indirect access to AG context with 32-bits granularity. The bits | ||
4499 | * [12:8] of the address should be the offset within the accessed LCID | ||
4500 | * context; the bits [7:0] are the accessed LCID.Example: to write to REG10 | ||
4501 | * LCID100. The RBC address should be 13'ha64. */ | ||
4502 | #define XCM_REG_AG_CTX 0x28000 | ||
3854 | /* [RW 2] The queue index for registration on Aux1 counter flag. */ | 4503 | /* [RW 2] The queue index for registration on Aux1 counter flag. */ |
3855 | #define XCM_REG_AUX1_Q 0x20134 | 4504 | #define XCM_REG_AUX1_Q 0x20134 |
3856 | /* [RW 2] Per each decision rule the queue index to register to. */ | 4505 | /* [RW 2] Per each decision rule the queue index to register to. */ |
@@ -4149,13 +4798,13 @@ | |||
4149 | #define XSDM_REG_AGG_INT_MODE_1 0x1661bc | 4798 | #define XSDM_REG_AGG_INT_MODE_1 0x1661bc |
4150 | /* [RW 13] The start address in the internal RAM for the cfc_rsp lcid */ | 4799 | /* [RW 13] The start address in the internal RAM for the cfc_rsp lcid */ |
4151 | #define XSDM_REG_CFC_RSP_START_ADDR 0x166008 | 4800 | #define XSDM_REG_CFC_RSP_START_ADDR 0x166008 |
4152 | /* [RW 16] The maximum value of the competion counter #0 */ | 4801 | /* [RW 16] The maximum value of the completion counter #0 */ |
4153 | #define XSDM_REG_CMP_COUNTER_MAX0 0x16601c | 4802 | #define XSDM_REG_CMP_COUNTER_MAX0 0x16601c |
4154 | /* [RW 16] The maximum value of the competion counter #1 */ | 4803 | /* [RW 16] The maximum value of the completion counter #1 */ |
4155 | #define XSDM_REG_CMP_COUNTER_MAX1 0x166020 | 4804 | #define XSDM_REG_CMP_COUNTER_MAX1 0x166020 |
4156 | /* [RW 16] The maximum value of the competion counter #2 */ | 4805 | /* [RW 16] The maximum value of the completion counter #2 */ |
4157 | #define XSDM_REG_CMP_COUNTER_MAX2 0x166024 | 4806 | #define XSDM_REG_CMP_COUNTER_MAX2 0x166024 |
4158 | /* [RW 16] The maximum value of the competion counter #3 */ | 4807 | /* [RW 16] The maximum value of the completion counter #3 */ |
4159 | #define XSDM_REG_CMP_COUNTER_MAX3 0x166028 | 4808 | #define XSDM_REG_CMP_COUNTER_MAX3 0x166028 |
4160 | /* [RW 13] The start address in the internal RAM for the completion | 4809 | /* [RW 13] The start address in the internal RAM for the completion |
4161 | counters. */ | 4810 | counters. */ |
@@ -4216,6 +4865,8 @@ | |||
4216 | #define XSDM_REG_XSDM_PRTY_MASK 0x1662bc | 4865 | #define XSDM_REG_XSDM_PRTY_MASK 0x1662bc |
4217 | /* [R 11] Parity register #0 read */ | 4866 | /* [R 11] Parity register #0 read */ |
4218 | #define XSDM_REG_XSDM_PRTY_STS 0x1662b0 | 4867 | #define XSDM_REG_XSDM_PRTY_STS 0x1662b0 |
4868 | /* [RC 11] Parity register #0 read clear */ | ||
4869 | #define XSDM_REG_XSDM_PRTY_STS_CLR 0x1662b4 | ||
4219 | /* [RW 5] The number of time_slots in the arbitration cycle */ | 4870 | /* [RW 5] The number of time_slots in the arbitration cycle */ |
4220 | #define XSEM_REG_ARB_CYCLE_SIZE 0x280034 | 4871 | #define XSEM_REG_ARB_CYCLE_SIZE 0x280034 |
4221 | /* [RW 3] The source that is associated with arbitration element 0. Source | 4872 | /* [RW 3] The source that is associated with arbitration element 0. Source |
@@ -4333,6 +4984,9 @@ | |||
4333 | #define XSEM_REG_TS_8_AS 0x280058 | 4984 | #define XSEM_REG_TS_8_AS 0x280058 |
4334 | /* [RW 3] The arbitration scheme of time_slot 9 */ | 4985 | /* [RW 3] The arbitration scheme of time_slot 9 */ |
4335 | #define XSEM_REG_TS_9_AS 0x28005c | 4986 | #define XSEM_REG_TS_9_AS 0x28005c |
4987 | /* [W 7] VF or PF ID for reset error bit. Values 0-63 reset error bit for 64 | ||
4988 | * VF; values 64-67 reset error for 4 PF; values 68-127 are not valid. */ | ||
4989 | #define XSEM_REG_VFPF_ERR_NUM 0x280380 | ||
4336 | /* [RW 32] Interrupt mask register #0 read/write */ | 4990 | /* [RW 32] Interrupt mask register #0 read/write */ |
4337 | #define XSEM_REG_XSEM_INT_MASK_0 0x280110 | 4991 | #define XSEM_REG_XSEM_INT_MASK_0 0x280110 |
4338 | #define XSEM_REG_XSEM_INT_MASK_1 0x280120 | 4992 | #define XSEM_REG_XSEM_INT_MASK_1 0x280120 |
@@ -4345,6 +4999,9 @@ | |||
4345 | /* [R 32] Parity register #0 read */ | 4999 | /* [R 32] Parity register #0 read */ |
4346 | #define XSEM_REG_XSEM_PRTY_STS_0 0x280124 | 5000 | #define XSEM_REG_XSEM_PRTY_STS_0 0x280124 |
4347 | #define XSEM_REG_XSEM_PRTY_STS_1 0x280134 | 5001 | #define XSEM_REG_XSEM_PRTY_STS_1 0x280134 |
5002 | /* [RC 32] Parity register #0 read clear */ | ||
5003 | #define XSEM_REG_XSEM_PRTY_STS_CLR_0 0x280128 | ||
5004 | #define XSEM_REG_XSEM_PRTY_STS_CLR_1 0x280138 | ||
4348 | #define MCPR_NVM_ACCESS_ENABLE_EN (1L<<0) | 5005 | #define MCPR_NVM_ACCESS_ENABLE_EN (1L<<0) |
4349 | #define MCPR_NVM_ACCESS_ENABLE_WR_EN (1L<<1) | 5006 | #define MCPR_NVM_ACCESS_ENABLE_WR_EN (1L<<1) |
4350 | #define MCPR_NVM_ADDR_NVM_ADDR_VALUE (0xffffffL<<0) | 5007 | #define MCPR_NVM_ADDR_NVM_ADDR_VALUE (0xffffffL<<0) |
@@ -4371,6 +5028,23 @@ | |||
4371 | #define BIGMAC_REGISTER_TX_SOURCE_ADDR (0x08<<3) | 5028 | #define BIGMAC_REGISTER_TX_SOURCE_ADDR (0x08<<3) |
4372 | #define BIGMAC_REGISTER_TX_STAT_GTBYT (0x20<<3) | 5029 | #define BIGMAC_REGISTER_TX_STAT_GTBYT (0x20<<3) |
4373 | #define BIGMAC_REGISTER_TX_STAT_GTPKT (0x0C<<3) | 5030 | #define BIGMAC_REGISTER_TX_STAT_GTPKT (0x0C<<3) |
5031 | #define BIGMAC2_REGISTER_BMAC_CONTROL (0x00<<3) | ||
5032 | #define BIGMAC2_REGISTER_BMAC_XGXS_CONTROL (0x01<<3) | ||
5033 | #define BIGMAC2_REGISTER_CNT_MAX_SIZE (0x05<<3) | ||
5034 | #define BIGMAC2_REGISTER_PFC_CONTROL (0x06<<3) | ||
5035 | #define BIGMAC2_REGISTER_RX_CONTROL (0x3A<<3) | ||
5036 | #define BIGMAC2_REGISTER_RX_LLFC_MSG_FLDS (0x62<<3) | ||
5037 | #define BIGMAC2_REGISTER_RX_MAX_SIZE (0x3C<<3) | ||
5038 | #define BIGMAC2_REGISTER_RX_STAT_GR64 (0x40<<3) | ||
5039 | #define BIGMAC2_REGISTER_RX_STAT_GRIPJ (0x5f<<3) | ||
5040 | #define BIGMAC2_REGISTER_RX_STAT_GRPP (0x51<<3) | ||
5041 | #define BIGMAC2_REGISTER_TX_CONTROL (0x1C<<3) | ||
5042 | #define BIGMAC2_REGISTER_TX_MAX_SIZE (0x1E<<3) | ||
5043 | #define BIGMAC2_REGISTER_TX_PAUSE_CONTROL (0x20<<3) | ||
5044 | #define BIGMAC2_REGISTER_TX_SOURCE_ADDR (0x1D<<3) | ||
5045 | #define BIGMAC2_REGISTER_TX_STAT_GTBYT (0x39<<3) | ||
5046 | #define BIGMAC2_REGISTER_TX_STAT_GTPOK (0x22<<3) | ||
5047 | #define BIGMAC2_REGISTER_TX_STAT_GTPP (0x24<<3) | ||
4374 | #define EMAC_LED_1000MB_OVERRIDE (1L<<1) | 5048 | #define EMAC_LED_1000MB_OVERRIDE (1L<<1) |
4375 | #define EMAC_LED_100MB_OVERRIDE (1L<<2) | 5049 | #define EMAC_LED_100MB_OVERRIDE (1L<<2) |
4376 | #define EMAC_LED_10MB_OVERRIDE (1L<<3) | 5050 | #define EMAC_LED_10MB_OVERRIDE (1L<<3) |
@@ -4405,7 +5079,23 @@ | |||
4405 | #define EMAC_REG_EMAC_TX_MODE 0xbc | 5079 | #define EMAC_REG_EMAC_TX_MODE 0xbc |
4406 | #define EMAC_REG_EMAC_TX_STAT_AC 0x280 | 5080 | #define EMAC_REG_EMAC_TX_STAT_AC 0x280 |
4407 | #define EMAC_REG_EMAC_TX_STAT_AC_COUNT 22 | 5081 | #define EMAC_REG_EMAC_TX_STAT_AC_COUNT 22 |
5082 | #define EMAC_REG_RX_PFC_MODE 0x320 | ||
5083 | #define EMAC_REG_RX_PFC_MODE_PRIORITIES (1L<<2) | ||
5084 | #define EMAC_REG_RX_PFC_MODE_RX_EN (1L<<1) | ||
5085 | #define EMAC_REG_RX_PFC_MODE_TX_EN (1L<<0) | ||
5086 | #define EMAC_REG_RX_PFC_PARAM 0x324 | ||
5087 | #define EMAC_REG_RX_PFC_PARAM_OPCODE_BITSHIFT 0 | ||
5088 | #define EMAC_REG_RX_PFC_PARAM_PRIORITY_EN_BITSHIFT 16 | ||
5089 | #define EMAC_REG_RX_PFC_STATS_XOFF_RCVD 0x328 | ||
5090 | #define EMAC_REG_RX_PFC_STATS_XOFF_RCVD_COUNT (0xffff<<0) | ||
5091 | #define EMAC_REG_RX_PFC_STATS_XOFF_SENT 0x330 | ||
5092 | #define EMAC_REG_RX_PFC_STATS_XOFF_SENT_COUNT (0xffff<<0) | ||
5093 | #define EMAC_REG_RX_PFC_STATS_XON_RCVD 0x32c | ||
5094 | #define EMAC_REG_RX_PFC_STATS_XON_RCVD_COUNT (0xffff<<0) | ||
5095 | #define EMAC_REG_RX_PFC_STATS_XON_SENT 0x334 | ||
5096 | #define EMAC_REG_RX_PFC_STATS_XON_SENT_COUNT (0xffff<<0) | ||
4408 | #define EMAC_RX_MODE_FLOW_EN (1L<<2) | 5097 | #define EMAC_RX_MODE_FLOW_EN (1L<<2) |
5098 | #define EMAC_RX_MODE_KEEP_MAC_CONTROL (1L<<3) | ||
4409 | #define EMAC_RX_MODE_KEEP_VLAN_TAG (1L<<10) | 5099 | #define EMAC_RX_MODE_KEEP_VLAN_TAG (1L<<10) |
4410 | #define EMAC_RX_MODE_PROMISCUOUS (1L<<8) | 5100 | #define EMAC_RX_MODE_PROMISCUOUS (1L<<8) |
4411 | #define EMAC_RX_MODE_RESET (1L<<0) | 5101 | #define EMAC_RX_MODE_RESET (1L<<0) |
@@ -4478,6 +5168,8 @@ | |||
4478 | #define HW_LOCK_RESOURCE_SPIO 2 | 5168 | #define HW_LOCK_RESOURCE_SPIO 2 |
4479 | #define HW_LOCK_RESOURCE_UNDI 5 | 5169 | #define HW_LOCK_RESOURCE_UNDI 5 |
4480 | #define PRS_FLAG_OVERETH_IPV4 1 | 5170 | #define PRS_FLAG_OVERETH_IPV4 1 |
5171 | #define AEU_INPUTS_ATTN_BITS_ATC_HW_INTERRUPT (0x1<<4) | ||
5172 | #define AEU_INPUTS_ATTN_BITS_ATC_PARITY_ERROR (0x1<<5) | ||
4481 | #define AEU_INPUTS_ATTN_BITS_BRB_PARITY_ERROR (1<<18) | 5173 | #define AEU_INPUTS_ATTN_BITS_BRB_PARITY_ERROR (1<<18) |
4482 | #define AEU_INPUTS_ATTN_BITS_CCM_HW_INTERRUPT (1<<31) | 5174 | #define AEU_INPUTS_ATTN_BITS_CCM_HW_INTERRUPT (1<<31) |
4483 | #define AEU_INPUTS_ATTN_BITS_CDU_HW_INTERRUPT (1<<9) | 5175 | #define AEU_INPUTS_ATTN_BITS_CDU_HW_INTERRUPT (1<<9) |
@@ -4504,6 +5196,8 @@ | |||
4504 | #define AEU_INPUTS_ATTN_BITS_PARSER_PARITY_ERROR (1<<20) | 5196 | #define AEU_INPUTS_ATTN_BITS_PARSER_PARITY_ERROR (1<<20) |
4505 | #define AEU_INPUTS_ATTN_BITS_PBCLIENT_PARITY_ERROR (1<<0) | 5197 | #define AEU_INPUTS_ATTN_BITS_PBCLIENT_PARITY_ERROR (1<<0) |
4506 | #define AEU_INPUTS_ATTN_BITS_PBF_HW_INTERRUPT (1<<31) | 5198 | #define AEU_INPUTS_ATTN_BITS_PBF_HW_INTERRUPT (1<<31) |
5199 | #define AEU_INPUTS_ATTN_BITS_PGLUE_HW_INTERRUPT (0x1<<2) | ||
5200 | #define AEU_INPUTS_ATTN_BITS_PGLUE_PARITY_ERROR (0x1<<3) | ||
4507 | #define AEU_INPUTS_ATTN_BITS_PXP_HW_INTERRUPT (1<<3) | 5201 | #define AEU_INPUTS_ATTN_BITS_PXP_HW_INTERRUPT (1<<3) |
4508 | #define AEU_INPUTS_ATTN_BITS_PXP_PARITY_ERROR (1<<2) | 5202 | #define AEU_INPUTS_ATTN_BITS_PXP_PARITY_ERROR (1<<2) |
4509 | #define AEU_INPUTS_ATTN_BITS_PXPPCICLOCKCLIENT_HW_INTERRUPT (1<<5) | 5203 | #define AEU_INPUTS_ATTN_BITS_PXPPCICLOCKCLIENT_HW_INTERRUPT (1<<5) |
@@ -4796,6 +5490,253 @@ | |||
4796 | #define PCI_ID_VAL1 0x434 | 5490 | #define PCI_ID_VAL1 0x434 |
4797 | #define PCI_ID_VAL2 0x438 | 5491 | #define PCI_ID_VAL2 0x438 |
4798 | 5492 | ||
5493 | #define PXPCS_TL_CONTROL_5 0x814 | ||
5494 | #define PXPCS_TL_CONTROL_5_UNKNOWNTYPE_ERR_ATTN (1 << 29) /*WC*/ | ||
5495 | #define PXPCS_TL_CONTROL_5_BOUNDARY4K_ERR_ATTN (1 << 28) /*WC*/ | ||
5496 | #define PXPCS_TL_CONTROL_5_MRRS_ERR_ATTN (1 << 27) /*WC*/ | ||
5497 | #define PXPCS_TL_CONTROL_5_MPS_ERR_ATTN (1 << 26) /*WC*/ | ||
5498 | #define PXPCS_TL_CONTROL_5_TTX_BRIDGE_FORWARD_ERR (1 << 25) /*WC*/ | ||
5499 | #define PXPCS_TL_CONTROL_5_TTX_TXINTF_OVERFLOW (1 << 24) /*WC*/ | ||
5500 | #define PXPCS_TL_CONTROL_5_PHY_ERR_ATTN (1 << 23) /*RO*/ | ||
5501 | #define PXPCS_TL_CONTROL_5_DL_ERR_ATTN (1 << 22) /*RO*/ | ||
5502 | #define PXPCS_TL_CONTROL_5_TTX_ERR_NP_TAG_IN_USE (1 << 21) /*WC*/ | ||
5503 | #define PXPCS_TL_CONTROL_5_TRX_ERR_UNEXP_RTAG (1 << 20) /*WC*/ | ||
5504 | #define PXPCS_TL_CONTROL_5_PRI_SIG_TARGET_ABORT1 (1 << 19) /*WC*/ | ||
5505 | #define PXPCS_TL_CONTROL_5_ERR_UNSPPORT1 (1 << 18) /*WC*/ | ||
5506 | #define PXPCS_TL_CONTROL_5_ERR_ECRC1 (1 << 17) /*WC*/ | ||
5507 | #define PXPCS_TL_CONTROL_5_ERR_MALF_TLP1 (1 << 16) /*WC*/ | ||
5508 | #define PXPCS_TL_CONTROL_5_ERR_RX_OFLOW1 (1 << 15) /*WC*/ | ||
5509 | #define PXPCS_TL_CONTROL_5_ERR_UNEXP_CPL1 (1 << 14) /*WC*/ | ||
5510 | #define PXPCS_TL_CONTROL_5_ERR_MASTER_ABRT1 (1 << 13) /*WC*/ | ||
5511 | #define PXPCS_TL_CONTROL_5_ERR_CPL_TIMEOUT1 (1 << 12) /*WC*/ | ||
5512 | #define PXPCS_TL_CONTROL_5_ERR_FC_PRTL1 (1 << 11) /*WC*/ | ||
5513 | #define PXPCS_TL_CONTROL_5_ERR_PSND_TLP1 (1 << 10) /*WC*/ | ||
5514 | #define PXPCS_TL_CONTROL_5_PRI_SIG_TARGET_ABORT (1 << 9) /*WC*/ | ||
5515 | #define PXPCS_TL_CONTROL_5_ERR_UNSPPORT (1 << 8) /*WC*/ | ||
5516 | #define PXPCS_TL_CONTROL_5_ERR_ECRC (1 << 7) /*WC*/ | ||
5517 | #define PXPCS_TL_CONTROL_5_ERR_MALF_TLP (1 << 6) /*WC*/ | ||
5518 | #define PXPCS_TL_CONTROL_5_ERR_RX_OFLOW (1 << 5) /*WC*/ | ||
5519 | #define PXPCS_TL_CONTROL_5_ERR_UNEXP_CPL (1 << 4) /*WC*/ | ||
5520 | #define PXPCS_TL_CONTROL_5_ERR_MASTER_ABRT (1 << 3) /*WC*/ | ||
5521 | #define PXPCS_TL_CONTROL_5_ERR_CPL_TIMEOUT (1 << 2) /*WC*/ | ||
5522 | #define PXPCS_TL_CONTROL_5_ERR_FC_PRTL (1 << 1) /*WC*/ | ||
5523 | #define PXPCS_TL_CONTROL_5_ERR_PSND_TLP (1 << 0) /*WC*/ | ||
5524 | |||
5525 | |||
5526 | #define PXPCS_TL_FUNC345_STAT 0x854 | ||
5527 | #define PXPCS_TL_FUNC345_STAT_PRI_SIG_TARGET_ABORT4 (1 << 29) /* WC */ | ||
5528 | #define PXPCS_TL_FUNC345_STAT_ERR_UNSPPORT4\ | ||
5529 | (1 << 28) /* Unsupported Request Error Status in function4, if \ | ||
5530 | set, generate pcie_err_attn output when this error is seen. WC */ | ||
5531 | #define PXPCS_TL_FUNC345_STAT_ERR_ECRC4\ | ||
5532 | (1 << 27) /* ECRC Error TLP Status Status in function 4, if set, \ | ||
5533 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5534 | #define PXPCS_TL_FUNC345_STAT_ERR_MALF_TLP4\ | ||
5535 | (1 << 26) /* Malformed TLP Status Status in function 4, if set, \ | ||
5536 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5537 | #define PXPCS_TL_FUNC345_STAT_ERR_RX_OFLOW4\ | ||
5538 | (1 << 25) /* Receiver Overflow Status Status in function 4, if \ | ||
5539 | set, generate pcie_err_attn output when this error is seen.. WC \ | ||
5540 | */ | ||
5541 | #define PXPCS_TL_FUNC345_STAT_ERR_UNEXP_CPL4\ | ||
5542 | (1 << 24) /* Unexpected Completion Status Status in function 4, \ | ||
5543 | if set, generate pcie_err_attn output when this error is seen. WC \ | ||
5544 | */ | ||
5545 | #define PXPCS_TL_FUNC345_STAT_ERR_MASTER_ABRT4\ | ||
5546 | (1 << 23) /* Receive UR Statusin function 4. If set, generate \ | ||
5547 | pcie_err_attn output when this error is seen. WC */ | ||
5548 | #define PXPCS_TL_FUNC345_STAT_ERR_CPL_TIMEOUT4\ | ||
5549 | (1 << 22) /* Completer Timeout Status Status in function 4, if \ | ||
5550 | set, generate pcie_err_attn output when this error is seen. WC */ | ||
5551 | #define PXPCS_TL_FUNC345_STAT_ERR_FC_PRTL4\ | ||
5552 | (1 << 21) /* Flow Control Protocol Error Status Status in \ | ||
5553 | function 4, if set, generate pcie_err_attn output when this error \ | ||
5554 | is seen. WC */ | ||
5555 | #define PXPCS_TL_FUNC345_STAT_ERR_PSND_TLP4\ | ||
5556 | (1 << 20) /* Poisoned Error Status Status in function 4, if set, \ | ||
5557 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5558 | #define PXPCS_TL_FUNC345_STAT_PRI_SIG_TARGET_ABORT3 (1 << 19) /* WC */ | ||
5559 | #define PXPCS_TL_FUNC345_STAT_ERR_UNSPPORT3\ | ||
5560 | (1 << 18) /* Unsupported Request Error Status in function3, if \ | ||
5561 | set, generate pcie_err_attn output when this error is seen. WC */ | ||
5562 | #define PXPCS_TL_FUNC345_STAT_ERR_ECRC3\ | ||
5563 | (1 << 17) /* ECRC Error TLP Status Status in function 3, if set, \ | ||
5564 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5565 | #define PXPCS_TL_FUNC345_STAT_ERR_MALF_TLP3\ | ||
5566 | (1 << 16) /* Malformed TLP Status Status in function 3, if set, \ | ||
5567 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5568 | #define PXPCS_TL_FUNC345_STAT_ERR_RX_OFLOW3\ | ||
5569 | (1 << 15) /* Receiver Overflow Status Status in function 3, if \ | ||
5570 | set, generate pcie_err_attn output when this error is seen.. WC \ | ||
5571 | */ | ||
5572 | #define PXPCS_TL_FUNC345_STAT_ERR_UNEXP_CPL3\ | ||
5573 | (1 << 14) /* Unexpected Completion Status Status in function 3, \ | ||
5574 | if set, generate pcie_err_attn output when this error is seen. WC \ | ||
5575 | */ | ||
5576 | #define PXPCS_TL_FUNC345_STAT_ERR_MASTER_ABRT3\ | ||
5577 | (1 << 13) /* Receive UR Statusin function 3. If set, generate \ | ||
5578 | pcie_err_attn output when this error is seen. WC */ | ||
5579 | #define PXPCS_TL_FUNC345_STAT_ERR_CPL_TIMEOUT3\ | ||
5580 | (1 << 12) /* Completer Timeout Status Status in function 3, if \ | ||
5581 | set, generate pcie_err_attn output when this error is seen. WC */ | ||
5582 | #define PXPCS_TL_FUNC345_STAT_ERR_FC_PRTL3\ | ||
5583 | (1 << 11) /* Flow Control Protocol Error Status Status in \ | ||
5584 | function 3, if set, generate pcie_err_attn output when this error \ | ||
5585 | is seen. WC */ | ||
5586 | #define PXPCS_TL_FUNC345_STAT_ERR_PSND_TLP3\ | ||
5587 | (1 << 10) /* Poisoned Error Status Status in function 3, if set, \ | ||
5588 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5589 | #define PXPCS_TL_FUNC345_STAT_PRI_SIG_TARGET_ABORT2 (1 << 9) /* WC */ | ||
5590 | #define PXPCS_TL_FUNC345_STAT_ERR_UNSPPORT2\ | ||
5591 | (1 << 8) /* Unsupported Request Error Status for Function 2, if \ | ||
5592 | set, generate pcie_err_attn output when this error is seen. WC */ | ||
5593 | #define PXPCS_TL_FUNC345_STAT_ERR_ECRC2\ | ||
5594 | (1 << 7) /* ECRC Error TLP Status Status for Function 2, if set, \ | ||
5595 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5596 | #define PXPCS_TL_FUNC345_STAT_ERR_MALF_TLP2\ | ||
5597 | (1 << 6) /* Malformed TLP Status Status for Function 2, if set, \ | ||
5598 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5599 | #define PXPCS_TL_FUNC345_STAT_ERR_RX_OFLOW2\ | ||
5600 | (1 << 5) /* Receiver Overflow Status Status for Function 2, if \ | ||
5601 | set, generate pcie_err_attn output when this error is seen.. WC \ | ||
5602 | */ | ||
5603 | #define PXPCS_TL_FUNC345_STAT_ERR_UNEXP_CPL2\ | ||
5604 | (1 << 4) /* Unexpected Completion Status Status for Function 2, \ | ||
5605 | if set, generate pcie_err_attn output when this error is seen. WC \ | ||
5606 | */ | ||
5607 | #define PXPCS_TL_FUNC345_STAT_ERR_MASTER_ABRT2\ | ||
5608 | (1 << 3) /* Receive UR Statusfor Function 2. If set, generate \ | ||
5609 | pcie_err_attn output when this error is seen. WC */ | ||
5610 | #define PXPCS_TL_FUNC345_STAT_ERR_CPL_TIMEOUT2\ | ||
5611 | (1 << 2) /* Completer Timeout Status Status for Function 2, if \ | ||
5612 | set, generate pcie_err_attn output when this error is seen. WC */ | ||
5613 | #define PXPCS_TL_FUNC345_STAT_ERR_FC_PRTL2\ | ||
5614 | (1 << 1) /* Flow Control Protocol Error Status Status for \ | ||
5615 | Function 2, if set, generate pcie_err_attn output when this error \ | ||
5616 | is seen. WC */ | ||
5617 | #define PXPCS_TL_FUNC345_STAT_ERR_PSND_TLP2\ | ||
5618 | (1 << 0) /* Poisoned Error Status Status for Function 2, if set, \ | ||
5619 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5620 | |||
5621 | |||
5622 | #define PXPCS_TL_FUNC678_STAT 0x85C | ||
5623 | #define PXPCS_TL_FUNC678_STAT_PRI_SIG_TARGET_ABORT7 (1 << 29) /* WC */ | ||
5624 | #define PXPCS_TL_FUNC678_STAT_ERR_UNSPPORT7\ | ||
5625 | (1 << 28) /* Unsupported Request Error Status in function7, if \ | ||
5626 | set, generate pcie_err_attn output when this error is seen. WC */ | ||
5627 | #define PXPCS_TL_FUNC678_STAT_ERR_ECRC7\ | ||
5628 | (1 << 27) /* ECRC Error TLP Status Status in function 7, if set, \ | ||
5629 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5630 | #define PXPCS_TL_FUNC678_STAT_ERR_MALF_TLP7\ | ||
5631 | (1 << 26) /* Malformed TLP Status Status in function 7, if set, \ | ||
5632 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5633 | #define PXPCS_TL_FUNC678_STAT_ERR_RX_OFLOW7\ | ||
5634 | (1 << 25) /* Receiver Overflow Status Status in function 7, if \ | ||
5635 | set, generate pcie_err_attn output when this error is seen.. WC \ | ||
5636 | */ | ||
5637 | #define PXPCS_TL_FUNC678_STAT_ERR_UNEXP_CPL7\ | ||
5638 | (1 << 24) /* Unexpected Completion Status Status in function 7, \ | ||
5639 | if set, generate pcie_err_attn output when this error is seen. WC \ | ||
5640 | */ | ||
5641 | #define PXPCS_TL_FUNC678_STAT_ERR_MASTER_ABRT7\ | ||
5642 | (1 << 23) /* Receive UR Statusin function 7. If set, generate \ | ||
5643 | pcie_err_attn output when this error is seen. WC */ | ||
5644 | #define PXPCS_TL_FUNC678_STAT_ERR_CPL_TIMEOUT7\ | ||
5645 | (1 << 22) /* Completer Timeout Status Status in function 7, if \ | ||
5646 | set, generate pcie_err_attn output when this error is seen. WC */ | ||
5647 | #define PXPCS_TL_FUNC678_STAT_ERR_FC_PRTL7\ | ||
5648 | (1 << 21) /* Flow Control Protocol Error Status Status in \ | ||
5649 | function 7, if set, generate pcie_err_attn output when this error \ | ||
5650 | is seen. WC */ | ||
5651 | #define PXPCS_TL_FUNC678_STAT_ERR_PSND_TLP7\ | ||
5652 | (1 << 20) /* Poisoned Error Status Status in function 7, if set, \ | ||
5653 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5654 | #define PXPCS_TL_FUNC678_STAT_PRI_SIG_TARGET_ABORT6 (1 << 19) /* WC */ | ||
5655 | #define PXPCS_TL_FUNC678_STAT_ERR_UNSPPORT6\ | ||
5656 | (1 << 18) /* Unsupported Request Error Status in function6, if \ | ||
5657 | set, generate pcie_err_attn output when this error is seen. WC */ | ||
5658 | #define PXPCS_TL_FUNC678_STAT_ERR_ECRC6\ | ||
5659 | (1 << 17) /* ECRC Error TLP Status Status in function 6, if set, \ | ||
5660 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5661 | #define PXPCS_TL_FUNC678_STAT_ERR_MALF_TLP6\ | ||
5662 | (1 << 16) /* Malformed TLP Status Status in function 6, if set, \ | ||
5663 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5664 | #define PXPCS_TL_FUNC678_STAT_ERR_RX_OFLOW6\ | ||
5665 | (1 << 15) /* Receiver Overflow Status Status in function 6, if \ | ||
5666 | set, generate pcie_err_attn output when this error is seen.. WC \ | ||
5667 | */ | ||
5668 | #define PXPCS_TL_FUNC678_STAT_ERR_UNEXP_CPL6\ | ||
5669 | (1 << 14) /* Unexpected Completion Status Status in function 6, \ | ||
5670 | if set, generate pcie_err_attn output when this error is seen. WC \ | ||
5671 | */ | ||
5672 | #define PXPCS_TL_FUNC678_STAT_ERR_MASTER_ABRT6\ | ||
5673 | (1 << 13) /* Receive UR Statusin function 6. If set, generate \ | ||
5674 | pcie_err_attn output when this error is seen. WC */ | ||
5675 | #define PXPCS_TL_FUNC678_STAT_ERR_CPL_TIMEOUT6\ | ||
5676 | (1 << 12) /* Completer Timeout Status Status in function 6, if \ | ||
5677 | set, generate pcie_err_attn output when this error is seen. WC */ | ||
5678 | #define PXPCS_TL_FUNC678_STAT_ERR_FC_PRTL6\ | ||
5679 | (1 << 11) /* Flow Control Protocol Error Status Status in \ | ||
5680 | function 6, if set, generate pcie_err_attn output when this error \ | ||
5681 | is seen. WC */ | ||
5682 | #define PXPCS_TL_FUNC678_STAT_ERR_PSND_TLP6\ | ||
5683 | (1 << 10) /* Poisoned Error Status Status in function 6, if set, \ | ||
5684 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5685 | #define PXPCS_TL_FUNC678_STAT_PRI_SIG_TARGET_ABORT5 (1 << 9) /* WC */ | ||
5686 | #define PXPCS_TL_FUNC678_STAT_ERR_UNSPPORT5\ | ||
5687 | (1 << 8) /* Unsupported Request Error Status for Function 5, if \ | ||
5688 | set, generate pcie_err_attn output when this error is seen. WC */ | ||
5689 | #define PXPCS_TL_FUNC678_STAT_ERR_ECRC5\ | ||
5690 | (1 << 7) /* ECRC Error TLP Status Status for Function 5, if set, \ | ||
5691 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5692 | #define PXPCS_TL_FUNC678_STAT_ERR_MALF_TLP5\ | ||
5693 | (1 << 6) /* Malformed TLP Status Status for Function 5, if set, \ | ||
5694 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5695 | #define PXPCS_TL_FUNC678_STAT_ERR_RX_OFLOW5\ | ||
5696 | (1 << 5) /* Receiver Overflow Status Status for Function 5, if \ | ||
5697 | set, generate pcie_err_attn output when this error is seen.. WC \ | ||
5698 | */ | ||
5699 | #define PXPCS_TL_FUNC678_STAT_ERR_UNEXP_CPL5\ | ||
5700 | (1 << 4) /* Unexpected Completion Status Status for Function 5, \ | ||
5701 | if set, generate pcie_err_attn output when this error is seen. WC \ | ||
5702 | */ | ||
5703 | #define PXPCS_TL_FUNC678_STAT_ERR_MASTER_ABRT5\ | ||
5704 | (1 << 3) /* Receive UR Statusfor Function 5. If set, generate \ | ||
5705 | pcie_err_attn output when this error is seen. WC */ | ||
5706 | #define PXPCS_TL_FUNC678_STAT_ERR_CPL_TIMEOUT5\ | ||
5707 | (1 << 2) /* Completer Timeout Status Status for Function 5, if \ | ||
5708 | set, generate pcie_err_attn output when this error is seen. WC */ | ||
5709 | #define PXPCS_TL_FUNC678_STAT_ERR_FC_PRTL5\ | ||
5710 | (1 << 1) /* Flow Control Protocol Error Status Status for \ | ||
5711 | Function 5, if set, generate pcie_err_attn output when this error \ | ||
5712 | is seen. WC */ | ||
5713 | #define PXPCS_TL_FUNC678_STAT_ERR_PSND_TLP5\ | ||
5714 | (1 << 0) /* Poisoned Error Status Status for Function 5, if set, \ | ||
5715 | generate pcie_err_attn output when this error is seen.. WC */ | ||
5716 | |||
5717 | |||
5718 | #define BAR_USTRORM_INTMEM 0x400000 | ||
5719 | #define BAR_CSTRORM_INTMEM 0x410000 | ||
5720 | #define BAR_XSTRORM_INTMEM 0x420000 | ||
5721 | #define BAR_TSTRORM_INTMEM 0x430000 | ||
5722 | |||
5723 | /* for accessing the IGU in case of status block ACK */ | ||
5724 | #define BAR_IGU_INTMEM 0x440000 | ||
5725 | |||
5726 | #define BAR_DOORBELL_OFFSET 0x800000 | ||
5727 | |||
5728 | #define BAR_ME_REGISTER 0x450000 | ||
5729 | #define ME_REG_PF_NUM_SHIFT 0 | ||
5730 | #define ME_REG_PF_NUM\ | ||
5731 | (7L<<ME_REG_PF_NUM_SHIFT) /* Relative PF Num */ | ||
5732 | #define ME_REG_VF_VALID (1<<8) | ||
5733 | #define ME_REG_VF_NUM_SHIFT 9 | ||
5734 | #define ME_REG_VF_NUM_MASK (0x3f<<ME_REG_VF_NUM_SHIFT) | ||
5735 | #define ME_REG_VF_ERR (0x1<<3) | ||
5736 | #define ME_REG_ABS_PF_NUM_SHIFT 16 | ||
5737 | #define ME_REG_ABS_PF_NUM\ | ||
5738 | (7L<<ME_REG_ABS_PF_NUM_SHIFT) /* Absolute PF Num */ | ||
5739 | |||
4799 | 5740 | ||
4800 | #define MDIO_REG_BANK_CL73_IEEEB0 0x0 | 5741 | #define MDIO_REG_BANK_CL73_IEEEB0 0x0 |
4801 | #define MDIO_CL73_IEEEB0_CL73_AN_CONTROL 0x0 | 5742 | #define MDIO_CL73_IEEEB0_CL73_AN_CONTROL 0x0 |
@@ -4964,6 +5905,8 @@ | |||
4964 | #define MDIO_SERDES_DIGITAL_A_1000X_CONTROL2_PRL_DT_EN 0x0001 | 5905 | #define MDIO_SERDES_DIGITAL_A_1000X_CONTROL2_PRL_DT_EN 0x0001 |
4965 | #define MDIO_SERDES_DIGITAL_A_1000X_CONTROL2_AN_FST_TMR 0x0040 | 5906 | #define MDIO_SERDES_DIGITAL_A_1000X_CONTROL2_AN_FST_TMR 0x0040 |
4966 | #define MDIO_SERDES_DIGITAL_A_1000X_STATUS1 0x14 | 5907 | #define MDIO_SERDES_DIGITAL_A_1000X_STATUS1 0x14 |
5908 | #define MDIO_SERDES_DIGITAL_A_1000X_STATUS1_SGMII 0x0001 | ||
5909 | #define MDIO_SERDES_DIGITAL_A_1000X_STATUS1_LINK 0x0002 | ||
4967 | #define MDIO_SERDES_DIGITAL_A_1000X_STATUS1_DUPLEX 0x0004 | 5910 | #define MDIO_SERDES_DIGITAL_A_1000X_STATUS1_DUPLEX 0x0004 |
4968 | #define MDIO_SERDES_DIGITAL_A_1000X_STATUS1_SPEED_MASK 0x0018 | 5911 | #define MDIO_SERDES_DIGITAL_A_1000X_STATUS1_SPEED_MASK 0x0018 |
4969 | #define MDIO_SERDES_DIGITAL_A_1000X_STATUS1_SPEED_SHIFT 3 | 5912 | #define MDIO_SERDES_DIGITAL_A_1000X_STATUS1_SPEED_SHIFT 3 |
@@ -5135,28 +6078,36 @@ Theotherbitsarereservedandshouldbezero*/ | |||
5135 | #define MDIO_PMA_REG_8727_TWO_WIRE_SLAVE_ADDR 0x8005 | 6078 | #define MDIO_PMA_REG_8727_TWO_WIRE_SLAVE_ADDR 0x8005 |
5136 | #define MDIO_PMA_REG_8727_TWO_WIRE_DATA_BUF 0x8007 | 6079 | #define MDIO_PMA_REG_8727_TWO_WIRE_DATA_BUF 0x8007 |
5137 | #define MDIO_PMA_REG_8727_TWO_WIRE_DATA_MASK 0xff | 6080 | #define MDIO_PMA_REG_8727_TWO_WIRE_DATA_MASK 0xff |
5138 | #define MDIO_PMA_REG_8727_MISC_CTRL 0x8309 | ||
5139 | #define MDIO_PMA_REG_8727_TX_CTRL1 0xca02 | 6081 | #define MDIO_PMA_REG_8727_TX_CTRL1 0xca02 |
5140 | #define MDIO_PMA_REG_8727_TX_CTRL2 0xca05 | 6082 | #define MDIO_PMA_REG_8727_TX_CTRL2 0xca05 |
5141 | #define MDIO_PMA_REG_8727_PCS_OPT_CTRL 0xc808 | 6083 | #define MDIO_PMA_REG_8727_PCS_OPT_CTRL 0xc808 |
5142 | #define MDIO_PMA_REG_8727_GPIO_CTRL 0xc80e | 6084 | #define MDIO_PMA_REG_8727_GPIO_CTRL 0xc80e |
6085 | #define MDIO_PMA_REG_8727_PCS_GP 0xc842 | ||
6086 | #define MDIO_PMA_REG_8727_OPT_CFG_REG 0xc8e4 | ||
6087 | |||
6088 | #define MDIO_AN_REG_8727_MISC_CTRL 0x8309 | ||
5143 | 6089 | ||
5144 | #define MDIO_PMA_REG_8073_CHIP_REV 0xc801 | 6090 | #define MDIO_PMA_REG_8073_CHIP_REV 0xc801 |
5145 | #define MDIO_PMA_REG_8073_SPEED_LINK_STATUS 0xc820 | 6091 | #define MDIO_PMA_REG_8073_SPEED_LINK_STATUS 0xc820 |
5146 | #define MDIO_PMA_REG_8073_XAUI_WA 0xc841 | 6092 | #define MDIO_PMA_REG_8073_XAUI_WA 0xc841 |
6093 | #define MDIO_PMA_REG_8073_OPT_DIGITAL_CTRL 0xcd08 | ||
5147 | 6094 | ||
5148 | #define MDIO_PMA_REG_7101_RESET 0xc000 | 6095 | #define MDIO_PMA_REG_7101_RESET 0xc000 |
5149 | #define MDIO_PMA_REG_7107_LED_CNTL 0xc007 | 6096 | #define MDIO_PMA_REG_7107_LED_CNTL 0xc007 |
6097 | #define MDIO_PMA_REG_7107_LINK_LED_CNTL 0xc009 | ||
5150 | #define MDIO_PMA_REG_7101_VER1 0xc026 | 6098 | #define MDIO_PMA_REG_7101_VER1 0xc026 |
5151 | #define MDIO_PMA_REG_7101_VER2 0xc027 | 6099 | #define MDIO_PMA_REG_7101_VER2 0xc027 |
5152 | 6100 | ||
5153 | #define MDIO_PMA_REG_8481_PMD_SIGNAL 0xa811 | 6101 | #define MDIO_PMA_REG_8481_PMD_SIGNAL 0xa811 |
5154 | #define MDIO_PMA_REG_8481_LED1_MASK 0xa82c | 6102 | #define MDIO_PMA_REG_8481_LED1_MASK 0xa82c |
5155 | #define MDIO_PMA_REG_8481_LED2_MASK 0xa82f | 6103 | #define MDIO_PMA_REG_8481_LED2_MASK 0xa82f |
5156 | #define MDIO_PMA_REG_8481_LED3_MASK 0xa832 | 6104 | #define MDIO_PMA_REG_8481_LED3_MASK 0xa832 |
5157 | #define MDIO_PMA_REG_8481_LED3_BLINK 0xa834 | 6105 | #define MDIO_PMA_REG_8481_LED3_BLINK 0xa834 |
5158 | #define MDIO_PMA_REG_8481_SIGNAL_MASK 0xa835 | 6106 | #define MDIO_PMA_REG_8481_LED5_MASK 0xa838 |
5159 | #define MDIO_PMA_REG_8481_LINK_SIGNAL 0xa83b | 6107 | #define MDIO_PMA_REG_8481_SIGNAL_MASK 0xa835 |
6108 | #define MDIO_PMA_REG_8481_LINK_SIGNAL 0xa83b | ||
6109 | #define MDIO_PMA_REG_8481_LINK_SIGNAL_LED4_ENABLE_MASK 0x800 | ||
6110 | #define MDIO_PMA_REG_8481_LINK_SIGNAL_LED4_ENABLE_SHIFT 11 | ||
5160 | 6111 | ||
5161 | 6112 | ||
5162 | #define MDIO_WIS_DEVAD 0x2 | 6113 | #define MDIO_WIS_DEVAD 0x2 |
@@ -5188,6 +6139,8 @@ Theotherbitsarereservedandshouldbezero*/ | |||
5188 | #define MDIO_XS_8706_REG_BANK_RX3 0x80ec | 6139 | #define MDIO_XS_8706_REG_BANK_RX3 0x80ec |
5189 | #define MDIO_XS_8706_REG_BANK_RXA 0x80fc | 6140 | #define MDIO_XS_8706_REG_BANK_RXA 0x80fc |
5190 | 6141 | ||
6142 | #define MDIO_XS_REG_8073_RX_CTRL_PCIE 0x80FA | ||
6143 | |||
5191 | #define MDIO_AN_DEVAD 0x7 | 6144 | #define MDIO_AN_DEVAD 0x7 |
5192 | /*ieee*/ | 6145 | /*ieee*/ |
5193 | #define MDIO_AN_REG_CTRL 0x0000 | 6146 | #define MDIO_AN_REG_CTRL 0x0000 |
@@ -5210,14 +6163,44 @@ Theotherbitsarereservedandshouldbezero*/ | |||
5210 | #define MDIO_AN_REG_CL37_FC_LP 0xffe5 | 6163 | #define MDIO_AN_REG_CL37_FC_LP 0xffe5 |
5211 | 6164 | ||
5212 | #define MDIO_AN_REG_8073_2_5G 0x8329 | 6165 | #define MDIO_AN_REG_8073_2_5G 0x8329 |
6166 | #define MDIO_AN_REG_8073_BAM 0x8350 | ||
5213 | 6167 | ||
6168 | #define MDIO_AN_REG_8481_10GBASE_T_AN_CTRL 0x0020 | ||
5214 | #define MDIO_AN_REG_8481_LEGACY_MII_CTRL 0xffe0 | 6169 | #define MDIO_AN_REG_8481_LEGACY_MII_CTRL 0xffe0 |
6170 | #define MDIO_AN_REG_8481_LEGACY_MII_STATUS 0xffe1 | ||
5215 | #define MDIO_AN_REG_8481_LEGACY_AN_ADV 0xffe4 | 6171 | #define MDIO_AN_REG_8481_LEGACY_AN_ADV 0xffe4 |
6172 | #define MDIO_AN_REG_8481_LEGACY_AN_EXPANSION 0xffe6 | ||
5216 | #define MDIO_AN_REG_8481_1000T_CTRL 0xffe9 | 6173 | #define MDIO_AN_REG_8481_1000T_CTRL 0xffe9 |
5217 | #define MDIO_AN_REG_8481_EXPANSION_REG_RD_RW 0xfff5 | 6174 | #define MDIO_AN_REG_8481_EXPANSION_REG_RD_RW 0xfff5 |
5218 | #define MDIO_AN_REG_8481_EXPANSION_REG_ACCESS 0xfff7 | 6175 | #define MDIO_AN_REG_8481_EXPANSION_REG_ACCESS 0xfff7 |
6176 | #define MDIO_AN_REG_8481_AUX_CTRL 0xfff8 | ||
5219 | #define MDIO_AN_REG_8481_LEGACY_SHADOW 0xfffc | 6177 | #define MDIO_AN_REG_8481_LEGACY_SHADOW 0xfffc |
5220 | 6178 | ||
6179 | /* BCM84823 only */ | ||
6180 | #define MDIO_CTL_DEVAD 0x1e | ||
6181 | #define MDIO_CTL_REG_84823_MEDIA 0x401a | ||
6182 | #define MDIO_CTL_REG_84823_MEDIA_MAC_MASK 0x0018 | ||
6183 | /* These pins configure the BCM84823 interface to MAC after reset. */ | ||
6184 | #define MDIO_CTL_REG_84823_CTRL_MAC_XFI 0x0008 | ||
6185 | #define MDIO_CTL_REG_84823_MEDIA_MAC_XAUI_M 0x0010 | ||
6186 | /* These pins configure the BCM84823 interface to Line after reset. */ | ||
6187 | #define MDIO_CTL_REG_84823_MEDIA_LINE_MASK 0x0060 | ||
6188 | #define MDIO_CTL_REG_84823_MEDIA_LINE_XAUI_L 0x0020 | ||
6189 | #define MDIO_CTL_REG_84823_MEDIA_LINE_XFI 0x0040 | ||
6190 | /* When this pin is active high during reset, 10GBASE-T core is power | ||
6191 | * down, When it is active low the 10GBASE-T is power up | ||
6192 | */ | ||
6193 | #define MDIO_CTL_REG_84823_MEDIA_COPPER_CORE_DOWN 0x0080 | ||
6194 | #define MDIO_CTL_REG_84823_MEDIA_PRIORITY_MASK 0x0100 | ||
6195 | #define MDIO_CTL_REG_84823_MEDIA_PRIORITY_COPPER 0x0000 | ||
6196 | #define MDIO_CTL_REG_84823_MEDIA_PRIORITY_FIBER 0x0100 | ||
6197 | #define MDIO_CTL_REG_84823_MEDIA_FIBER_1G 0x1000 | ||
6198 | #define MDIO_CTL_REG_84823_USER_CTRL_REG 0x4005 | ||
6199 | #define MDIO_CTL_REG_84823_USER_CTRL_CMS 0x0080 | ||
6200 | |||
6201 | #define MDIO_PMA_REG_84823_CTL_LED_CTL_1 0xa8e3 | ||
6202 | #define MDIO_PMA_REG_84823_LED3_STRETCH_EN 0x0080 | ||
6203 | |||
5221 | #define IGU_FUNC_BASE 0x0400 | 6204 | #define IGU_FUNC_BASE 0x0400 |
5222 | 6205 | ||
5223 | #define IGU_ADDR_MSIX 0x0000 | 6206 | #define IGU_ADDR_MSIX 0x0000 |
@@ -5239,6 +6222,11 @@ Theotherbitsarereservedandshouldbezero*/ | |||
5239 | #define IGU_INT_NOP 2 | 6222 | #define IGU_INT_NOP 2 |
5240 | #define IGU_INT_NOP2 3 | 6223 | #define IGU_INT_NOP2 3 |
5241 | 6224 | ||
6225 | #define IGU_USE_REGISTER_ustorm_type_0_sb_cleanup 0 | ||
6226 | #define IGU_USE_REGISTER_ustorm_type_1_sb_cleanup 1 | ||
6227 | #define IGU_USE_REGISTER_cstorm_type_0_sb_cleanup 2 | ||
6228 | #define IGU_USE_REGISTER_cstorm_type_1_sb_cleanup 3 | ||
6229 | |||
5242 | #define COMMAND_REG_INT_ACK 0x0 | 6230 | #define COMMAND_REG_INT_ACK 0x0 |
5243 | #define COMMAND_REG_PROD_UPD 0x4 | 6231 | #define COMMAND_REG_PROD_UPD 0x4 |
5244 | #define COMMAND_REG_ATTN_BITS_UPD 0x8 | 6232 | #define COMMAND_REG_ATTN_BITS_UPD 0x8 |
@@ -5281,6 +6269,50 @@ Theotherbitsarereservedandshouldbezero*/ | |||
5281 | #define IGU_REG_SISR_MDPC_WOMASK_UPPER 0x05a6 | 6269 | #define IGU_REG_SISR_MDPC_WOMASK_UPPER 0x05a6 |
5282 | 6270 | ||
5283 | #define IGU_REG_RESERVED_UPPER 0x05ff | 6271 | #define IGU_REG_RESERVED_UPPER 0x05ff |
6272 | /* Fields of IGU PF CONFIGRATION REGISTER */ | ||
6273 | #define IGU_PF_CONF_FUNC_EN (0x1<<0) /* function enable */ | ||
6274 | #define IGU_PF_CONF_MSI_MSIX_EN (0x1<<1) /* MSI/MSIX enable */ | ||
6275 | #define IGU_PF_CONF_INT_LINE_EN (0x1<<2) /* INT enable */ | ||
6276 | #define IGU_PF_CONF_ATTN_BIT_EN (0x1<<3) /* attention enable */ | ||
6277 | #define IGU_PF_CONF_SINGLE_ISR_EN (0x1<<4) /* single ISR mode enable */ | ||
6278 | #define IGU_PF_CONF_SIMD_MODE (0x1<<5) /* simd all ones mode */ | ||
6279 | |||
6280 | /* Fields of IGU VF CONFIGRATION REGISTER */ | ||
6281 | #define IGU_VF_CONF_FUNC_EN (0x1<<0) /* function enable */ | ||
6282 | #define IGU_VF_CONF_MSI_MSIX_EN (0x1<<1) /* MSI/MSIX enable */ | ||
6283 | #define IGU_VF_CONF_PARENT_MASK (0x3<<2) /* Parent PF */ | ||
6284 | #define IGU_VF_CONF_PARENT_SHIFT 2 /* Parent PF */ | ||
6285 | #define IGU_VF_CONF_SINGLE_ISR_EN (0x1<<4) /* single ISR mode enable */ | ||
6286 | |||
6287 | |||
6288 | #define IGU_BC_DSB_NUM_SEGS 5 | ||
6289 | #define IGU_BC_NDSB_NUM_SEGS 2 | ||
6290 | #define IGU_NORM_DSB_NUM_SEGS 2 | ||
6291 | #define IGU_NORM_NDSB_NUM_SEGS 1 | ||
6292 | #define IGU_BC_BASE_DSB_PROD 128 | ||
6293 | #define IGU_NORM_BASE_DSB_PROD 136 | ||
6294 | |||
6295 | #define IGU_CTRL_CMD_TYPE_WR\ | ||
6296 | 1 | ||
6297 | #define IGU_CTRL_CMD_TYPE_RD\ | ||
6298 | 0 | ||
6299 | |||
6300 | #define IGU_SEG_ACCESS_NORM 0 | ||
6301 | #define IGU_SEG_ACCESS_DEF 1 | ||
6302 | #define IGU_SEG_ACCESS_ATTN 2 | ||
6303 | |||
6304 | /* FID (if VF - [6] = 0; [5:0] = VF number; if PF - [6] = 1; \ | ||
6305 | [5:2] = 0; [1:0] = PF number) */ | ||
6306 | #define IGU_FID_ENCODE_IS_PF (0x1<<6) | ||
6307 | #define IGU_FID_ENCODE_IS_PF_SHIFT 6 | ||
6308 | #define IGU_FID_VF_NUM_MASK (0x3f) | ||
6309 | #define IGU_FID_PF_NUM_MASK (0x7) | ||
6310 | |||
6311 | #define IGU_REG_MAPPING_MEMORY_VALID (1<<0) | ||
6312 | #define IGU_REG_MAPPING_MEMORY_VECTOR_MASK (0x3F<<1) | ||
6313 | #define IGU_REG_MAPPING_MEMORY_VECTOR_SHIFT 1 | ||
6314 | #define IGU_REG_MAPPING_MEMORY_FID_MASK (0x7F<<7) | ||
6315 | #define IGU_REG_MAPPING_MEMORY_FID_SHIFT 7 | ||
5284 | 6316 | ||
5285 | 6317 | ||
5286 | #define CDU_REGION_NUMBER_XCM_AG 2 | 6318 | #define CDU_REGION_NUMBER_XCM_AG 2 |
@@ -5362,3 +6394,4 @@ static inline u8 calc_crc8(u32 data, u8 crc) | |||
5362 | } | 6394 | } |
5363 | 6395 | ||
5364 | 6396 | ||
6397 | #endif /* BNX2X_REG_H */ | ||