aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/bnx2x/bnx2x_reg.h
diff options
context:
space:
mode:
authorGlenn Elliott <gelliott@cs.unc.edu>2012-03-04 19:47:13 -0500
committerGlenn Elliott <gelliott@cs.unc.edu>2012-03-04 19:47:13 -0500
commitc71c03bda1e86c9d5198c5d83f712e695c4f2a1e (patch)
treeecb166cb3e2b7e2adb3b5e292245fefd23381ac8 /drivers/net/bnx2x/bnx2x_reg.h
parentea53c912f8a86a8567697115b6a0d8152beee5c8 (diff)
parent6a00f206debf8a5c8899055726ad127dbeeed098 (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.h1111
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 */