cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

rvu_reg.h (33995B)


      1/* SPDX-License-Identifier: GPL-2.0 */
      2/* Marvell RVU Admin Function driver
      3 *
      4 * Copyright (C) 2018 Marvell.
      5 *
      6 */
      7
      8#ifndef RVU_REG_H
      9#define RVU_REG_H
     10
     11/* Admin function registers */
     12#define RVU_AF_MSIXTR_BASE                  (0x10)
     13#define RVU_AF_ECO                          (0x20)
     14#define RVU_AF_BLK_RST                      (0x30)
     15#define RVU_AF_PF_BAR4_ADDR                 (0x40)
     16#define RVU_AF_RAS                          (0x100)
     17#define RVU_AF_RAS_W1S                      (0x108)
     18#define RVU_AF_RAS_ENA_W1S                  (0x110)
     19#define RVU_AF_RAS_ENA_W1C                  (0x118)
     20#define RVU_AF_GEN_INT                      (0x120)
     21#define RVU_AF_GEN_INT_W1S                  (0x128)
     22#define RVU_AF_GEN_INT_ENA_W1S              (0x130)
     23#define RVU_AF_GEN_INT_ENA_W1C              (0x138)
     24#define	RVU_AF_AFPF_MBOX0		    (0x02000)
     25#define	RVU_AF_AFPF_MBOX1		    (0x02008)
     26#define RVU_AF_AFPFX_MBOXX(a, b)            (0x2000 | (a) << 4 | (b) << 3)
     27#define RVU_AF_PFME_STATUS                  (0x2800)
     28#define RVU_AF_PFTRPEND                     (0x2810)
     29#define RVU_AF_PFTRPEND_W1S                 (0x2820)
     30#define RVU_AF_PF_RST                       (0x2840)
     31#define RVU_AF_HWVF_RST                     (0x2850)
     32#define RVU_AF_PFAF_MBOX_INT                (0x2880)
     33#define RVU_AF_PFAF_MBOX_INT_W1S            (0x2888)
     34#define RVU_AF_PFAF_MBOX_INT_ENA_W1S        (0x2890)
     35#define RVU_AF_PFAF_MBOX_INT_ENA_W1C        (0x2898)
     36#define RVU_AF_PFFLR_INT                    (0x28a0)
     37#define RVU_AF_PFFLR_INT_W1S                (0x28a8)
     38#define RVU_AF_PFFLR_INT_ENA_W1S            (0x28b0)
     39#define RVU_AF_PFFLR_INT_ENA_W1C            (0x28b8)
     40#define RVU_AF_PFME_INT                     (0x28c0)
     41#define RVU_AF_PFME_INT_W1S                 (0x28c8)
     42#define RVU_AF_PFME_INT_ENA_W1S             (0x28d0)
     43#define RVU_AF_PFME_INT_ENA_W1C             (0x28d8)
     44#define RVU_AF_PFX_BAR4_ADDR(a)             (0x5000 | (a) << 4)
     45#define RVU_AF_PFX_BAR4_CFG                 (0x5200 | (a) << 4)
     46#define RVU_AF_PFX_VF_BAR4_ADDR             (0x5400 | (a) << 4)
     47#define RVU_AF_PFX_VF_BAR4_CFG              (0x5600 | (a) << 4)
     48#define RVU_AF_PFX_LMTLINE_ADDR             (0x5800 | (a) << 4)
     49#define RVU_AF_SMMU_ADDR_REQ		    (0x6000)
     50#define RVU_AF_SMMU_TXN_REQ		    (0x6008)
     51#define RVU_AF_SMMU_ADDR_RSP_STS	    (0x6010)
     52#define RVU_AF_SMMU_ADDR_TLN		    (0x6018)
     53#define RVU_AF_SMMU_TLN_FLIT0		    (0x6020)
     54
     55/* Admin function's privileged PF/VF registers */
     56#define RVU_PRIV_CONST                      (0x8000000)
     57#define RVU_PRIV_GEN_CFG                    (0x8000010)
     58#define RVU_PRIV_CLK_CFG                    (0x8000020)
     59#define RVU_PRIV_ACTIVE_PC                  (0x8000030)
     60#define RVU_PRIV_PFX_CFG(a)                 (0x8000100 | (a) << 16)
     61#define RVU_PRIV_PFX_MSIX_CFG(a)            (0x8000110 | (a) << 16)
     62#define RVU_PRIV_PFX_ID_CFG(a)              (0x8000120 | (a) << 16)
     63#define RVU_PRIV_PFX_INT_CFG(a)             (0x8000200 | (a) << 16)
     64#define RVU_PRIV_PFX_NIXX_CFG(a)            (0x8000300 | (a) << 3)
     65#define RVU_PRIV_PFX_NPA_CFG		    (0x8000310)
     66#define RVU_PRIV_PFX_SSO_CFG                (0x8000320)
     67#define RVU_PRIV_PFX_SSOW_CFG               (0x8000330)
     68#define RVU_PRIV_PFX_TIM_CFG                (0x8000340)
     69#define RVU_PRIV_PFX_CPTX_CFG(a)            (0x8000350 | (a) << 3)
     70#define RVU_PRIV_BLOCK_TYPEX_REV(a)         (0x8000400 | (a) << 3)
     71#define RVU_PRIV_HWVFX_INT_CFG(a)           (0x8001280 | (a) << 16)
     72#define RVU_PRIV_HWVFX_NIXX_CFG(a)          (0x8001300 | (a) << 3)
     73#define RVU_PRIV_HWVFX_NPA_CFG              (0x8001310)
     74#define RVU_PRIV_HWVFX_SSO_CFG              (0x8001320)
     75#define RVU_PRIV_HWVFX_SSOW_CFG             (0x8001330)
     76#define RVU_PRIV_HWVFX_TIM_CFG              (0x8001340)
     77#define RVU_PRIV_HWVFX_CPTX_CFG(a)          (0x8001350 | (a) << 3)
     78
     79/* RVU PF registers */
     80#define	RVU_PF_VFX_PFVF_MBOX0		    (0x00000)
     81#define	RVU_PF_VFX_PFVF_MBOX1		    (0x00008)
     82#define RVU_PF_VFX_PFVF_MBOXX(a, b)         (0x0 | (a) << 12 | (b) << 3)
     83#define RVU_PF_VF_BAR4_ADDR                 (0x10)
     84#define RVU_PF_BLOCK_ADDRX_DISC(a)          (0x200 | (a) << 3)
     85#define RVU_PF_VFME_STATUSX(a)              (0x800 | (a) << 3)
     86#define RVU_PF_VFTRPENDX(a)                 (0x820 | (a) << 3)
     87#define RVU_PF_VFTRPEND_W1SX(a)             (0x840 | (a) << 3)
     88#define RVU_PF_VFPF_MBOX_INTX(a)            (0x880 | (a) << 3)
     89#define RVU_PF_VFPF_MBOX_INT_W1SX(a)        (0x8A0 | (a) << 3)
     90#define RVU_PF_VFPF_MBOX_INT_ENA_W1SX(a)    (0x8C0 | (a) << 3)
     91#define RVU_PF_VFPF_MBOX_INT_ENA_W1CX(a)    (0x8E0 | (a) << 3)
     92#define RVU_PF_VFFLR_INTX(a)                (0x900 | (a) << 3)
     93#define RVU_PF_VFFLR_INT_W1SX(a)            (0x920 | (a) << 3)
     94#define RVU_PF_VFFLR_INT_ENA_W1SX(a)        (0x940 | (a) << 3)
     95#define RVU_PF_VFFLR_INT_ENA_W1CX(a)        (0x960 | (a) << 3)
     96#define RVU_PF_VFME_INTX(a)                 (0x980 | (a) << 3)
     97#define RVU_PF_VFME_INT_W1SX(a)             (0x9A0 | (a) << 3)
     98#define RVU_PF_VFME_INT_ENA_W1SX(a)         (0x9C0 | (a) << 3)
     99#define RVU_PF_VFME_INT_ENA_W1CX(a)         (0x9E0 | (a) << 3)
    100#define RVU_PF_PFAF_MBOX0                   (0xC00)
    101#define RVU_PF_PFAF_MBOX1                   (0xC08)
    102#define RVU_PF_PFAF_MBOXX(a)                (0xC00 | (a) << 3)
    103#define RVU_PF_INT                          (0xc20)
    104#define RVU_PF_INT_W1S                      (0xc28)
    105#define RVU_PF_INT_ENA_W1S                  (0xc30)
    106#define RVU_PF_INT_ENA_W1C                  (0xc38)
    107#define RVU_PF_MSIX_VECX_ADDR(a)            (0x000 | (a) << 4)
    108#define RVU_PF_MSIX_VECX_CTL(a)             (0x008 | (a) << 4)
    109#define RVU_PF_MSIX_PBAX(a)                 (0xF0000 | (a) << 3)
    110#define RVU_PF_VF_MBOX_ADDR                 (0xC40)
    111#define RVU_PF_LMTLINE_ADDR                 (0xC48)
    112
    113/* RVU VF registers */
    114#define	RVU_VF_VFPF_MBOX0		    (0x00000)
    115#define	RVU_VF_VFPF_MBOX1		    (0x00008)
    116
    117/* NPA block's admin function registers */
    118#define NPA_AF_BLK_RST                  (0x0000)
    119#define NPA_AF_CONST                    (0x0010)
    120#define NPA_AF_CONST1                   (0x0018)
    121#define NPA_AF_LF_RST                   (0x0020)
    122#define NPA_AF_GEN_CFG                  (0x0030)
    123#define NPA_AF_NDC_CFG                  (0x0040)
    124#define NPA_AF_INP_CTL                  (0x00D0)
    125#define NPA_AF_ACTIVE_CYCLES_PC         (0x00F0)
    126#define NPA_AF_AVG_DELAY                (0x0100)
    127#define NPA_AF_GEN_INT                  (0x0140)
    128#define NPA_AF_GEN_INT_W1S              (0x0148)
    129#define NPA_AF_GEN_INT_ENA_W1S          (0x0150)
    130#define NPA_AF_GEN_INT_ENA_W1C          (0x0158)
    131#define NPA_AF_RVU_INT                  (0x0160)
    132#define NPA_AF_RVU_INT_W1S              (0x0168)
    133#define NPA_AF_RVU_INT_ENA_W1S          (0x0170)
    134#define NPA_AF_RVU_INT_ENA_W1C          (0x0178)
    135#define NPA_AF_ERR_INT			(0x0180)
    136#define NPA_AF_ERR_INT_W1S		(0x0188)
    137#define NPA_AF_ERR_INT_ENA_W1S		(0x0190)
    138#define NPA_AF_ERR_INT_ENA_W1C		(0x0198)
    139#define NPA_AF_RAS			(0x01A0)
    140#define NPA_AF_RAS_W1S			(0x01A8)
    141#define NPA_AF_RAS_ENA_W1S		(0x01B0)
    142#define NPA_AF_RAS_ENA_W1C		(0x01B8)
    143#define NPA_AF_BP_TEST                  (0x0200)
    144#define NPA_AF_ECO                      (0x0300)
    145#define NPA_AF_AQ_CFG                   (0x0600)
    146#define NPA_AF_AQ_BASE                  (0x0610)
    147#define NPA_AF_AQ_STATUS		(0x0620)
    148#define NPA_AF_AQ_DOOR                  (0x0630)
    149#define NPA_AF_AQ_DONE_WAIT             (0x0640)
    150#define NPA_AF_AQ_DONE                  (0x0650)
    151#define NPA_AF_AQ_DONE_ACK              (0x0660)
    152#define NPA_AF_AQ_DONE_INT              (0x0680)
    153#define NPA_AF_AQ_DONE_INT_W1S          (0x0688)
    154#define NPA_AF_AQ_DONE_ENA_W1S          (0x0690)
    155#define NPA_AF_AQ_DONE_ENA_W1C          (0x0698)
    156#define NPA_AF_BATCH_CTL		(0x06a0)
    157#define NPA_AF_LFX_AURAS_CFG(a)         (0x4000 | (a) << 18)
    158#define NPA_AF_LFX_LOC_AURAS_BASE(a)    (0x4010 | (a) << 18)
    159#define NPA_AF_LFX_QINTS_CFG(a)         (0x4100 | (a) << 18)
    160#define NPA_AF_LFX_QINTS_BASE(a)        (0x4110 | (a) << 18)
    161#define NPA_PRIV_AF_INT_CFG             (0x10000)
    162#define NPA_PRIV_LFX_CFG		(0x10010)
    163#define NPA_PRIV_LFX_INT_CFG		(0x10020)
    164#define NPA_AF_RVU_LF_CFG_DEBUG         (0x10030)
    165
    166/* NIX block's admin function registers */
    167#define NIX_AF_CFG			(0x0000)
    168#define NIX_AF_STATUS			(0x0010)
    169#define NIX_AF_NDC_CFG			(0x0018)
    170#define NIX_AF_CONST			(0x0020)
    171#define NIX_AF_CONST1			(0x0028)
    172#define NIX_AF_CONST2			(0x0030)
    173#define NIX_AF_CONST3			(0x0038)
    174#define NIX_AF_SQ_CONST			(0x0040)
    175#define NIX_AF_CQ_CONST			(0x0048)
    176#define NIX_AF_RQ_CONST			(0x0050)
    177#define NIX_AF_PL_CONST			(0x0058)
    178#define NIX_AF_PSE_CONST		(0x0060)
    179#define NIX_AF_TL1_CONST		(0x0070)
    180#define NIX_AF_TL2_CONST		(0x0078)
    181#define NIX_AF_TL3_CONST		(0x0080)
    182#define NIX_AF_TL4_CONST		(0x0088)
    183#define NIX_AF_MDQ_CONST		(0x0090)
    184#define NIX_AF_MC_MIRROR_CONST		(0x0098)
    185#define NIX_AF_LSO_CFG			(0x00A8)
    186#define NIX_AF_BLK_RST			(0x00B0)
    187#define NIX_AF_TX_TSTMP_CFG		(0x00C0)
    188#define NIX_AF_PL_TS			(0x00C8)
    189#define NIX_AF_RX_CFG			(0x00D0)
    190#define NIX_AF_AVG_DELAY		(0x00E0)
    191#define NIX_AF_CINT_DELAY		(0x00F0)
    192#define NIX_AF_RX_MCAST_BASE		(0x0100)
    193#define NIX_AF_RX_MCAST_CFG		(0x0110)
    194#define NIX_AF_RX_MCAST_BUF_BASE	(0x0120)
    195#define NIX_AF_RX_MCAST_BUF_CFG		(0x0130)
    196#define NIX_AF_RX_MIRROR_BUF_BASE	(0x0140)
    197#define NIX_AF_RX_MIRROR_BUF_CFG	(0x0148)
    198#define NIX_AF_LF_RST			(0x0150)
    199#define NIX_AF_GEN_INT			(0x0160)
    200#define NIX_AF_GEN_INT_W1S		(0x0168)
    201#define NIX_AF_GEN_INT_ENA_W1S		(0x0170)
    202#define NIX_AF_GEN_INT_ENA_W1C		(0x0178)
    203#define NIX_AF_ERR_INT			(0x0180)
    204#define NIX_AF_ERR_INT_W1S		(0x0188)
    205#define NIX_AF_ERR_INT_ENA_W1S		(0x0190)
    206#define NIX_AF_ERR_INT_ENA_W1C		(0x0198)
    207#define NIX_AF_RAS			(0x01A0)
    208#define NIX_AF_RAS_W1S			(0x01A8)
    209#define NIX_AF_RAS_ENA_W1S		(0x01B0)
    210#define NIX_AF_RAS_ENA_W1C		(0x01B8)
    211#define NIX_AF_RVU_INT			(0x01C0)
    212#define NIX_AF_RVU_INT_W1S		(0x01C8)
    213#define NIX_AF_RVU_INT_ENA_W1S		(0x01D0)
    214#define NIX_AF_RVU_INT_ENA_W1C		(0x01D8)
    215#define NIX_AF_TCP_TIMER		(0x01E0)
    216#define NIX_AF_RX_DEF_ET(a)		(0x01F0ull | (uint64_t)(a) << 3)
    217#define NIX_AF_RX_DEF_OL2		(0x0200)
    218#define NIX_AF_RX_DEF_OIP4		(0x0210)
    219#define NIX_AF_RX_DEF_IIP4		(0x0220)
    220#define NIX_AF_RX_DEF_VLAN0_PCP_DEI	(0x0228)
    221#define NIX_AF_RX_DEF_OIP6		(0x0230)
    222#define NIX_AF_RX_DEF_VLAN1_PCP_DEI	(0x0238)
    223#define NIX_AF_RX_DEF_IIP6		(0x0240)
    224#define NIX_AF_RX_DEF_OTCP		(0x0250)
    225#define NIX_AF_RX_DEF_ITCP		(0x0260)
    226#define NIX_AF_RX_DEF_OUDP		(0x0270)
    227#define NIX_AF_RX_DEF_IUDP		(0x0280)
    228#define NIX_AF_RX_DEF_OSCTP		(0x0290)
    229#define NIX_AF_RX_DEF_CST_APAD0		(0x0298)
    230#define NIX_AF_RX_DEF_ISCTP		(0x02A0)
    231#define NIX_AF_RX_DEF_IPSECX		(0x02B0)
    232#define NIX_AF_RX_DEF_CST_APAD1		(0x02A8)
    233#define NIX_AF_RX_DEF_IIP4_DSCP		(0x02E0)
    234#define NIX_AF_RX_DEF_OIP4_DSCP		(0x02E8)
    235#define NIX_AF_RX_DEF_IIP6_DSCP		(0x02F0)
    236#define NIX_AF_RX_DEF_OIP6_DSCP		(0x02F8)
    237#define NIX_AF_RX_IPSEC_GEN_CFG		(0x0300)
    238#define NIX_AF_RX_CPTX_INST_ADDR	(0x0310)
    239#define NIX_AF_RX_CPTX_INST_QSEL(a)	(0x0320ull | (uint64_t)(a) << 3)
    240#define NIX_AF_RX_CPTX_CREDIT(a)	(0x0360ull | (uint64_t)(a) << 3)
    241#define NIX_AF_NDC_TX_SYNC		(0x03F0)
    242#define NIX_AF_AQ_CFG			(0x0400)
    243#define NIX_AF_AQ_BASE			(0x0410)
    244#define NIX_AF_AQ_STATUS		(0x0420)
    245#define NIX_AF_AQ_DOOR			(0x0430)
    246#define NIX_AF_AQ_DONE_WAIT		(0x0440)
    247#define NIX_AF_AQ_DONE			(0x0450)
    248#define NIX_AF_AQ_DONE_ACK		(0x0460)
    249#define NIX_AF_AQ_DONE_TIMER		(0x0470)
    250#define NIX_AF_AQ_DONE_INT		(0x0480)
    251#define NIX_AF_AQ_DONE_INT_W1S		(0x0488)
    252#define NIX_AF_AQ_DONE_ENA_W1S		(0x0490)
    253#define NIX_AF_AQ_DONE_ENA_W1C		(0x0498)
    254#define NIX_AF_RX_LINKX_SLX_SPKT_CNT	(0x0500)
    255#define NIX_AF_RX_LINKX_SLX_SXQE_CNT	(0x0510)
    256#define NIX_AF_RX_MCAST_JOBSX_SW_CNT	(0x0520)
    257#define NIX_AF_RX_MIRROR_JOBSX_SW_CNT	(0x0530)
    258#define NIX_AF_RX_LINKX_CFG(a)		(0x0540 | (a) << 16)
    259#define NIX_AF_RX_SW_SYNC		(0x0550)
    260#define NIX_AF_RX_SW_SYNC_DONE		(0x0560)
    261#define NIX_AF_SEB_ECO			(0x0600)
    262#define NIX_AF_SEB_TEST_BP		(0x0610)
    263#define NIX_AF_NORM_TX_FIFO_STATUS	(0x0620)
    264#define NIX_AF_EXPR_TX_FIFO_STATUS	(0x0630)
    265#define NIX_AF_SDP_TX_FIFO_STATUS	(0x0640)
    266#define NIX_AF_TX_NPC_CAPTURE_CONFIG	(0x0660)
    267#define NIX_AF_TX_NPC_CAPTURE_INFO	(0x0670)
    268#define NIX_AF_SEB_CFG			(0x05F0)
    269
    270#define NIX_AF_DEBUG_NPC_RESP_DATAX(a)          (0x680 | (a) << 3)
    271#define NIX_AF_SMQX_CFG(a)                      (0x700 | (a) << 16)
    272#define NIX_AF_SQM_DBG_CTL_STATUS               (0x750)
    273#define NIX_AF_DWRR_SDP_MTU                     (0x790)
    274#define NIX_AF_DWRR_RPM_MTU                     (0x7A0)
    275#define NIX_AF_PSE_CHANNEL_LEVEL                (0x800)
    276#define NIX_AF_PSE_SHAPER_CFG                   (0x810)
    277#define NIX_AF_TX_EXPR_CREDIT			(0x830)
    278#define NIX_AF_MARK_FORMATX_CTL(a)              (0x900 | (a) << 18)
    279#define NIX_AF_TX_LINKX_NORM_CREDIT(a)		(0xA00 | (a) << 16)
    280#define NIX_AF_TX_LINKX_EXPR_CREDIT(a)		(0xA10 | (a) << 16)
    281#define NIX_AF_TX_LINKX_SW_XOFF(a)              (0xA20 | (a) << 16)
    282#define NIX_AF_TX_LINKX_HW_XOFF(a)              (0xA30 | (a) << 16)
    283#define NIX_AF_SDP_LINK_CREDIT                  (0xa40)
    284#define NIX_AF_SDP_SW_XOFFX(a)                  (0xA60 | (a) << 3)
    285#define NIX_AF_SDP_HW_XOFFX(a)                  (0xAC0 | (a) << 3)
    286#define NIX_AF_TL4X_BP_STATUS(a)                (0xB00 | (a) << 16)
    287#define NIX_AF_TL4X_SDP_LINK_CFG(a)             (0xB10 | (a) << 16)
    288#define NIX_AF_TL1X_SCHEDULE(a)                 (0xC00 | (a) << 16)
    289#define NIX_AF_TL1X_SHAPE(a)                    (0xC10 | (a) << 16)
    290#define NIX_AF_TL1X_CIR(a)                      (0xC20 | (a) << 16)
    291#define NIX_AF_TL1X_SHAPE_STATE(a)              (0xC50 | (a) << 16)
    292#define NIX_AF_TL1X_SW_XOFF(a)                  (0xC70 | (a) << 16)
    293#define NIX_AF_TL1X_TOPOLOGY(a)                 (0xC80 | (a) << 16)
    294#define NIX_AF_TL1X_GREEN(a)                    (0xC90 | (a) << 16)
    295#define NIX_AF_TL1X_YELLOW(a)                   (0xCA0 | (a) << 16)
    296#define NIX_AF_TL1X_RED(a)                      (0xCB0 | (a) << 16)
    297#define NIX_AF_TL1X_MD_DEBUG0(a)                (0xCC0 | (a) << 16)
    298#define NIX_AF_TL1X_MD_DEBUG1(a)                (0xCC8 | (a) << 16)
    299#define NIX_AF_TL1X_MD_DEBUG2(a)                (0xCD0 | (a) << 16)
    300#define NIX_AF_TL1X_MD_DEBUG3(a)                (0xCD8 | (a) << 16)
    301#define NIX_AF_TL1A_DEBUG                       (0xce0)
    302#define NIX_AF_TL1B_DEBUG                       (0xcf0)
    303#define NIX_AF_TL1_DEBUG_GREEN                  (0xd00)
    304#define NIX_AF_TL1_DEBUG_NODE                   (0xd10)
    305#define NIX_AF_TL1X_DROPPED_PACKETS(a)          (0xD20 | (a) << 16)
    306#define NIX_AF_TL1X_DROPPED_BYTES(a)            (0xD30 | (a) << 16)
    307#define NIX_AF_TL1X_RED_PACKETS(a)              (0xD40 | (a) << 16)
    308#define NIX_AF_TL1X_RED_BYTES(a)                (0xD50 | (a) << 16)
    309#define NIX_AF_TL1X_YELLOW_PACKETS(a)           (0xD60 | (a) << 16)
    310#define NIX_AF_TL1X_YELLOW_BYTES(a)             (0xD70 | (a) << 16)
    311#define NIX_AF_TL1X_GREEN_PACKETS(a)            (0xD80 | (a) << 16)
    312#define NIX_AF_TL1X_GREEN_BYTES(a)              (0xD90 | (a) << 16)
    313#define NIX_AF_TL2X_SCHEDULE(a)                 (0xE00 | (a) << 16)
    314#define NIX_AF_TL2X_SHAPE(a)                    (0xE10 | (a) << 16)
    315#define NIX_AF_TL2X_CIR(a)                      (0xE20 | (a) << 16)
    316#define NIX_AF_TL2X_PIR(a)                      (0xE30 | (a) << 16)
    317#define NIX_AF_TL2X_SCHED_STATE(a)              (0xE40 | (a) << 16)
    318#define NIX_AF_TL2X_SHAPE_STATE(a)              (0xE50 | (a) << 16)
    319#define NIX_AF_TL2X_POINTERS(a)                 (0xE60 | (a) << 16)
    320#define NIX_AF_TL2X_SW_XOFF(a)                  (0xE70 | (a) << 16)
    321#define NIX_AF_TL2X_TOPOLOGY(a)                 (0xE80 | (a) << 16)
    322#define NIX_AF_TL2X_PARENT(a)                   (0xE88 | (a) << 16)
    323#define NIX_AF_TL2X_GREEN(a)                    (0xE90 | (a) << 16)
    324#define NIX_AF_TL2X_YELLOW(a)                   (0xEA0 | (a) << 16)
    325#define NIX_AF_TL2X_RED(a)                      (0xEB0 | (a) << 16)
    326#define NIX_AF_TL2X_MD_DEBUG0(a)                (0xEC0 | (a) << 16)
    327#define NIX_AF_TL2X_MD_DEBUG1(a)                (0xEC8 | (a) << 16)
    328#define NIX_AF_TL2X_MD_DEBUG2(a)                (0xED0 | (a) << 16)
    329#define NIX_AF_TL2X_MD_DEBUG3(a)                (0xED8 | (a) << 16)
    330#define NIX_AF_TL2A_DEBUG                       (0xee0)
    331#define NIX_AF_TL2B_DEBUG                       (0xef0)
    332#define NIX_AF_TL3X_SCHEDULE(a)                 (0x1000 | (a) << 16)
    333#define NIX_AF_TL3X_SHAPE(a)                    (0x1010 | (a) << 16)
    334#define NIX_AF_TL3X_CIR(a)                      (0x1020 | (a) << 16)
    335#define NIX_AF_TL3X_PIR(a)                      (0x1030 | (a) << 16)
    336#define NIX_AF_TL3X_SCHED_STATE(a)              (0x1040 | (a) << 16)
    337#define NIX_AF_TL3X_SHAPE_STATE(a)              (0x1050 | (a) << 16)
    338#define NIX_AF_TL3X_POINTERS(a)                 (0x1060 | (a) << 16)
    339#define NIX_AF_TL3X_SW_XOFF(a)                  (0x1070 | (a) << 16)
    340#define NIX_AF_TL3X_TOPOLOGY(a)                 (0x1080 | (a) << 16)
    341#define NIX_AF_TL3X_PARENT(a)                   (0x1088 | (a) << 16)
    342#define NIX_AF_TL3X_GREEN(a)                    (0x1090 | (a) << 16)
    343#define NIX_AF_TL3X_YELLOW(a)                   (0x10A0 | (a) << 16)
    344#define NIX_AF_TL3X_RED(a)                      (0x10B0 | (a) << 16)
    345#define NIX_AF_TL3X_MD_DEBUG0(a)                (0x10C0 | (a) << 16)
    346#define NIX_AF_TL3X_MD_DEBUG1(a)                (0x10C8 | (a) << 16)
    347#define NIX_AF_TL3X_MD_DEBUG2(a)                (0x10D0 | (a) << 16)
    348#define NIX_AF_TL3X_MD_DEBUG3(a)                (0x10D8 | (a) << 16)
    349#define NIX_AF_TL3A_DEBUG                       (0x10e0)
    350#define NIX_AF_TL3B_DEBUG                       (0x10f0)
    351#define NIX_AF_TL4X_SCHEDULE(a)                 (0x1200 | (a) << 16)
    352#define NIX_AF_TL4X_SHAPE(a)                    (0x1210 | (a) << 16)
    353#define NIX_AF_TL4X_CIR(a)                      (0x1220 | (a) << 16)
    354#define NIX_AF_TL4X_PIR(a)                      (0x1230 | (a) << 16)
    355#define NIX_AF_TL4X_SCHED_STATE(a)              (0x1240 | (a) << 16)
    356#define NIX_AF_TL4X_SHAPE_STATE(a)              (0x1250 | (a) << 16)
    357#define NIX_AF_TL4X_POINTERS(a)                 (0x1260 | (a) << 16)
    358#define NIX_AF_TL4X_SW_XOFF(a)                  (0x1270 | (a) << 16)
    359#define NIX_AF_TL4X_TOPOLOGY(a)                 (0x1280 | (a) << 16)
    360#define NIX_AF_TL4X_PARENT(a)                   (0x1288 | (a) << 16)
    361#define NIX_AF_TL4X_GREEN(a)                    (0x1290 | (a) << 16)
    362#define NIX_AF_TL4X_YELLOW(a)                   (0x12A0 | (a) << 16)
    363#define NIX_AF_TL4X_RED(a)                      (0x12B0 | (a) << 16)
    364#define NIX_AF_TL4X_MD_DEBUG0(a)                (0x12C0 | (a) << 16)
    365#define NIX_AF_TL4X_MD_DEBUG1(a)                (0x12C8 | (a) << 16)
    366#define NIX_AF_TL4X_MD_DEBUG2(a)                (0x12D0 | (a) << 16)
    367#define NIX_AF_TL4X_MD_DEBUG3(a)                (0x12D8 | (a) << 16)
    368#define NIX_AF_TL4A_DEBUG                       (0x12e0)
    369#define NIX_AF_TL4B_DEBUG                       (0x12f0)
    370#define NIX_AF_MDQX_SCHEDULE(a)                 (0x1400 | (a) << 16)
    371#define NIX_AF_MDQX_SHAPE(a)                    (0x1410 | (a) << 16)
    372#define NIX_AF_MDQX_CIR(a)                      (0x1420 | (a) << 16)
    373#define NIX_AF_MDQX_PIR(a)                      (0x1430 | (a) << 16)
    374#define NIX_AF_MDQX_SCHED_STATE(a)              (0x1440 | (a) << 16)
    375#define NIX_AF_MDQX_SHAPE_STATE(a)              (0x1450 | (a) << 16)
    376#define NIX_AF_MDQX_POINTERS(a)                 (0x1460 | (a) << 16)
    377#define NIX_AF_MDQX_SW_XOFF(a)                  (0x1470 | (a) << 16)
    378#define NIX_AF_MDQX_PARENT(a)                   (0x1480 | (a) << 16)
    379#define NIX_AF_MDQX_MD_DEBUG(a)                 (0x14C0 | (a) << 16)
    380#define NIX_AF_MDQX_PTR_FIFO(a)                 (0x14D0 | (a) << 16)
    381#define NIX_AF_MDQA_DEBUG                       (0x14e0)
    382#define NIX_AF_MDQB_DEBUG                       (0x14f0)
    383#define NIX_AF_TL3_TL2X_CFG(a)                  (0x1600 | (a) << 18)
    384#define NIX_AF_TL3_TL2X_BP_STATUS(a)            (0x1610 | (a) << 16)
    385#define NIX_AF_TL3_TL2X_LINKX_CFG(a, b)         (0x1700 | (a) << 16 | (b) << 3)
    386#define NIX_AF_RX_FLOW_KEY_ALGX_FIELDX(a, b)    (0x1800 | (a) << 18 | (b) << 3)
    387#define NIX_AF_TX_MCASTX(a)                     (0x1900 | (a) << 15)
    388#define NIX_AF_TX_VTAG_DEFX_CTL(a)              (0x1A00 | (a) << 16)
    389#define NIX_AF_TX_VTAG_DEFX_DATA(a)             (0x1A10 | (a) << 16)
    390#define NIX_AF_RX_BPIDX_STATUS(a)               (0x1A20 | (a) << 17)
    391#define NIX_AF_RX_CHANX_CFG(a)                  (0x1A30 | (a) << 15)
    392#define NIX_AF_CINT_TIMERX(a)                   (0x1A40 | (a) << 18)
    393#define NIX_AF_LSO_FORMATX_FIELDX(a, b)         (0x1B00 | (a) << 16 | (b) << 3)
    394#define NIX_AF_LFX_CFG(a)		(0x4000 | (a) << 17)
    395#define NIX_AF_LFX_SQS_CFG(a)		(0x4020 | (a) << 17)
    396#define NIX_AF_LFX_TX_CFG2(a)		(0x4028 | (a) << 17)
    397#define NIX_AF_LFX_SQS_BASE(a)		(0x4030 | (a) << 17)
    398#define NIX_AF_LFX_RQS_CFG(a)		(0x4040 | (a) << 17)
    399#define NIX_AF_LFX_RQS_BASE(a)		(0x4050 | (a) << 17)
    400#define NIX_AF_LFX_CQS_CFG(a)		(0x4060 | (a) << 17)
    401#define NIX_AF_LFX_CQS_BASE(a)		(0x4070 | (a) << 17)
    402#define NIX_AF_LFX_TX_CFG(a)		(0x4080 | (a) << 17)
    403#define NIX_AF_LFX_TX_PARSE_CFG(a)	(0x4090 | (a) << 17)
    404#define NIX_AF_LFX_RX_CFG(a)		(0x40A0 | (a) << 17)
    405#define NIX_AF_LFX_RSS_CFG(a)		(0x40C0 | (a) << 17)
    406#define NIX_AF_LFX_RSS_BASE(a)		(0x40D0 | (a) << 17)
    407#define NIX_AF_LFX_QINTS_CFG(a)		(0x4100 | (a) << 17)
    408#define NIX_AF_LFX_QINTS_BASE(a)	(0x4110 | (a) << 17)
    409#define NIX_AF_LFX_CINTS_CFG(a)		(0x4120 | (a) << 17)
    410#define NIX_AF_LFX_CINTS_BASE(a)	(0x4130 | (a) << 17)
    411#define NIX_AF_LFX_RX_IPSEC_CFG0(a)	(0x4140 | (a) << 17)
    412#define NIX_AF_LFX_RX_IPSEC_CFG1(a)	(0x4148 | (a) << 17)
    413#define NIX_AF_LFX_RX_IPSEC_DYNO_CFG(a)	(0x4150 | (a) << 17)
    414#define NIX_AF_LFX_RX_IPSEC_DYNO_BASE(a)	(0x4158 | (a) << 17)
    415#define NIX_AF_LFX_RX_IPSEC_SA_BASE(a)	(0x4170 | (a) << 17)
    416#define NIX_AF_LFX_TX_STATUS(a)		(0x4180 | (a) << 17)
    417#define NIX_AF_LFX_RX_VTAG_TYPEX(a, b)	(0x4200 | (a) << 17 | (b) << 3)
    418#define NIX_AF_LFX_LOCKX(a, b)		(0x4300 | (a) << 17 | (b) << 3)
    419#define NIX_AF_LFX_TX_STATX(a, b)	(0x4400 | (a) << 17 | (b) << 3)
    420#define NIX_AF_LFX_RX_STATX(a, b)	(0x4500 | (a) << 17 | (b) << 3)
    421#define NIX_AF_LFX_RSS_GRPX(a, b)	(0x4600 | (a) << 17 | (b) << 3)
    422#define NIX_AF_RX_NPC_MC_RCV		(0x4700)
    423#define NIX_AF_RX_NPC_MC_DROP		(0x4710)
    424#define NIX_AF_RX_NPC_MIRROR_RCV	(0x4720)
    425#define NIX_AF_RX_NPC_MIRROR_DROP	(0x4730)
    426#define NIX_AF_RX_ACTIVE_CYCLES_PCX(a)	(0x4800 | (a) << 16)
    427#define NIX_AF_LINKX_CFG(a)		(0x4010 | (a) << 17)
    428
    429#define NIX_PRIV_AF_INT_CFG		(0x8000000)
    430#define NIX_PRIV_LFX_CFG		(0x8000010)
    431#define NIX_PRIV_LFX_INT_CFG		(0x8000020)
    432#define NIX_AF_RVU_LF_CFG_DEBUG		(0x8000030)
    433
    434#define NIX_AF_LINKX_BASE_MASK		GENMASK_ULL(11, 0)
    435#define NIX_AF_LINKX_RANGE_MASK		GENMASK_ULL(19, 16)
    436
    437/* SSO */
    438#define SSO_AF_CONST			(0x1000)
    439#define SSO_AF_CONST1			(0x1008)
    440#define SSO_AF_BLK_RST			(0x10f8)
    441#define SSO_AF_LF_HWGRP_RST		(0x10e0)
    442#define SSO_AF_RVU_LF_CFG_DEBUG		(0x3800)
    443#define SSO_PRIV_LFX_HWGRP_CFG		(0x10000)
    444#define SSO_PRIV_LFX_HWGRP_INT_CFG	(0x20000)
    445
    446/* SSOW */
    447#define SSOW_AF_RVU_LF_HWS_CFG_DEBUG	(0x0010)
    448#define SSOW_AF_LF_HWS_RST		(0x0030)
    449#define SSOW_PRIV_LFX_HWS_CFG		(0x1000)
    450#define SSOW_PRIV_LFX_HWS_INT_CFG	(0x2000)
    451
    452/* TIM */
    453#define TIM_AF_CONST			(0x90)
    454#define TIM_PRIV_LFX_CFG		(0x20000)
    455#define TIM_PRIV_LFX_INT_CFG		(0x24000)
    456#define TIM_AF_RVU_LF_CFG_DEBUG		(0x30000)
    457#define TIM_AF_BLK_RST			(0x10)
    458#define TIM_AF_LF_RST			(0x20)
    459
    460/* CPT */
    461#define CPT_AF_CONSTANTS0               (0x0000)
    462#define CPT_AF_CONSTANTS1               (0x1000)
    463#define CPT_AF_DIAG                     (0x3000)
    464#define CPT_AF_ECO                      (0x4000)
    465#define CPT_AF_FLTX_INT(a)              (0xa000ull | (u64)(a) << 3)
    466#define CPT_AF_FLTX_INT_W1S(a)          (0xb000ull | (u64)(a) << 3)
    467#define CPT_AF_FLTX_INT_ENA_W1C(a)      (0xc000ull | (u64)(a) << 3)
    468#define CPT_AF_FLTX_INT_ENA_W1S(a)      (0xd000ull | (u64)(a) << 3)
    469#define CPT_AF_PSNX_EXE(a)              (0xe000ull | (u64)(a) << 3)
    470#define CPT_AF_PSNX_EXE_W1S(a)          (0xf000ull | (u64)(a) << 3)
    471#define CPT_AF_PSNX_LF(a)               (0x10000ull | (u64)(a) << 3)
    472#define CPT_AF_PSNX_LF_W1S(a)           (0x11000ull | (u64)(a) << 3)
    473#define CPT_AF_EXEX_CTL2(a)             (0x12000ull | (u64)(a) << 3)
    474#define CPT_AF_EXEX_STS(a)              (0x13000ull | (u64)(a) << 3)
    475#define CPT_AF_EXE_ERR_INFO             (0x14000)
    476#define CPT_AF_EXEX_ACTIVE(a)           (0x16000ull | (u64)(a) << 3)
    477#define CPT_AF_INST_REQ_PC              (0x17000)
    478#define CPT_AF_INST_LATENCY_PC          (0x18000)
    479#define CPT_AF_RD_REQ_PC                (0x19000)
    480#define CPT_AF_RD_LATENCY_PC            (0x1a000)
    481#define CPT_AF_RD_UC_PC                 (0x1b000)
    482#define CPT_AF_ACTIVE_CYCLES_PC         (0x1c000)
    483#define CPT_AF_EXE_DBG_CTL              (0x1d000)
    484#define CPT_AF_EXE_DBG_DATA             (0x1e000)
    485#define CPT_AF_EXE_REQ_TIMER            (0x1f000)
    486#define CPT_AF_EXEX_CTL(a)              (0x20000ull | (u64)(a) << 3)
    487#define CPT_AF_EXE_PERF_CTL             (0x21000)
    488#define CPT_AF_EXE_DBG_CNTX(a)          (0x22000ull | (u64)(a) << 3)
    489#define CPT_AF_EXE_PERF_EVENT_CNT       (0x23000)
    490#define CPT_AF_EXE_EPCI_INBX_CNT(a)     (0x24000ull | (u64)(a) << 3)
    491#define CPT_AF_EXE_EPCI_OUTBX_CNT(a)    (0x25000ull | (u64)(a) << 3)
    492#define CPT_AF_EXEX_UCODE_BASE(a)       (0x26000ull | (u64)(a) << 3)
    493#define CPT_AF_LFX_CTL(a)               (0x27000ull | (u64)(a) << 3)
    494#define CPT_AF_LFX_CTL2(a)              (0x29000ull | (u64)(a) << 3)
    495#define CPT_AF_CPTCLK_CNT               (0x2a000)
    496#define CPT_AF_PF_FUNC                  (0x2b000)
    497#define CPT_AF_LFX_PTR_CTL(a)           (0x2c000ull | (u64)(a) << 3)
    498#define CPT_AF_GRPX_THR(a)              (0x2d000ull | (u64)(a) << 3)
    499#define CPT_AF_CTL                      (0x2e000ull)
    500#define CPT_AF_XEX_THR(a)               (0x2f000ull | (u64)(a) << 3)
    501#define CPT_PRIV_LFX_CFG                (0x41000)
    502#define CPT_PRIV_AF_INT_CFG             (0x42000)
    503#define CPT_PRIV_LFX_INT_CFG            (0x43000)
    504#define CPT_AF_LF_RST                   (0x44000)
    505#define CPT_AF_RVU_LF_CFG_DEBUG         (0x45000)
    506#define CPT_AF_BLK_RST                  (0x46000)
    507#define CPT_AF_RVU_INT                  (0x47000)
    508#define CPT_AF_RVU_INT_W1S              (0x47008)
    509#define CPT_AF_RVU_INT_ENA_W1S          (0x47010)
    510#define CPT_AF_RVU_INT_ENA_W1C          (0x47018)
    511#define CPT_AF_RAS_INT                  (0x47020)
    512#define CPT_AF_RAS_INT_W1S              (0x47028)
    513#define CPT_AF_RAS_INT_ENA_W1S          (0x47030)
    514#define CPT_AF_RAS_INT_ENA_W1C          (0x47038)
    515#define CPT_AF_CTX_FLUSH_TIMER          (0x48000ull)
    516#define CPT_AF_CTX_ERR                  (0x48008ull)
    517#define CPT_AF_CTX_ENC_ID               (0x48010ull)
    518#define CPT_AF_CTX_MIS_PC		(0x49400ull)
    519#define CPT_AF_CTX_HIT_PC		(0x49408ull)
    520#define CPT_AF_CTX_AOP_PC		(0x49410ull)
    521#define CPT_AF_CTX_AOP_LATENCY_PC       (0x49418ull)
    522#define CPT_AF_CTX_IFETCH_PC            (0x49420ull)
    523#define CPT_AF_CTX_IFETCH_LATENCY_PC    (0x49428ull)
    524#define CPT_AF_CTX_FFETCH_PC            (0x49430ull)
    525#define CPT_AF_CTX_FFETCH_LATENCY_PC    (0x49438ull)
    526#define CPT_AF_CTX_WBACK_PC             (0x49440ull)
    527#define CPT_AF_CTX_WBACK_LATENCY_PC     (0x49448ull)
    528#define CPT_AF_CTX_PSH_PC               (0x49450ull)
    529#define CPT_AF_CTX_PSH_LATENCY_PC       (0x49458ull)
    530#define CPT_AF_CTX_CAM_DATA(a)          (0x49800ull | (u64)(a) << 3)
    531#define CPT_AF_RXC_TIME                 (0x50010ull)
    532#define CPT_AF_RXC_TIME_CFG             (0x50018ull)
    533#define CPT_AF_RXC_DFRG                 (0x50020ull)
    534#define CPT_AF_RXC_ACTIVE_STS           (0x50028ull)
    535#define CPT_AF_RXC_ZOMBIE_STS           (0x50030ull)
    536#define CPT_AF_X2PX_LINK_CFG(a)         (0x51000ull | (u64)(a) << 3)
    537
    538#define AF_BAR2_ALIASX(a, b)            (0x9100000ull | (a) << 12 | (b))
    539#define CPT_AF_BAR2_SEL                 0x9000000
    540#define CPT_AF_BAR2_ALIASX(a, b)        AF_BAR2_ALIASX(a, b)
    541
    542#define CPT_AF_LF_CTL2_SHIFT 3
    543#define CPT_AF_LF_SSO_PF_FUNC_SHIFT 32
    544
    545#define CPT_LF_CTL                      0x10
    546#define CPT_LF_INPROG                   0x40
    547#define CPT_LF_Q_GRP_PTR                0x120
    548#define CPT_LF_CTX_FLUSH                0x510
    549
    550#define NPC_AF_BLK_RST                  (0x00040)
    551
    552/* NPC */
    553#define NPC_AF_CFG			(0x00000)
    554#define NPC_AF_ACTIVE_PC		(0x00010)
    555#define NPC_AF_CONST			(0x00020)
    556#define NPC_AF_CONST1			(0x00030)
    557#define NPC_AF_BLK_RST			(0x00040)
    558#define NPC_AF_MCAM_SCRUB_CTL		(0x000a0)
    559#define NPC_AF_KCAM_SCRUB_CTL		(0x000b0)
    560#define NPC_AF_CONST2			(0x00100)
    561#define NPC_AF_CONST3			(0x00110)
    562#define NPC_AF_KPUX_CFG(a)		(0x00500 | (a) << 3)
    563#define NPC_AF_PCK_CFG			(0x00600)
    564#define NPC_AF_PCK_DEF_OL2		(0x00610)
    565#define NPC_AF_PCK_DEF_OIP4		(0x00620)
    566#define NPC_AF_PCK_DEF_OIP6		(0x00630)
    567#define NPC_AF_PCK_DEF_IIP4		(0x00640)
    568#define NPC_AF_KEX_LDATAX_FLAGS_CFG(a)	(0x00800 | (a) << 3)
    569#define NPC_AF_INTFX_KEX_CFG(a)		(0x01010 | (a) << 8)
    570#define NPC_AF_PKINDX_ACTION0(a)	(0x80000ull | (a) << 6)
    571#define NPC_AF_PKINDX_ACTION1(a)	(0x80008ull | (a) << 6)
    572#define NPC_AF_PKINDX_CPI_DEFX(a, b)	(0x80020ull | (a) << 6 | (b) << 3)
    573#define NPC_AF_KPUX_ENTRYX_CAMX(a, b, c) \
    574		(0x100000 | (a) << 14 | (b) << 6 | (c) << 3)
    575#define NPC_AF_KPUX_ENTRYX_ACTION0(a, b) \
    576		(0x100020 | (a) << 14 | (b) << 6)
    577#define NPC_AF_KPUX_ENTRYX_ACTION1(a, b) \
    578		(0x100028 | (a) << 14 | (b) << 6)
    579#define NPC_AF_KPUX_ENTRY_DISX(a, b)	(0x180000 | (a) << 6 | (b) << 3)
    580#define NPC_AF_CPIX_CFG(a)		(0x200000 | (a) << 3)
    581#define NPC_AF_INTFX_LIDX_LTX_LDX_CFG(a, b, c, d) \
    582		(0x900000 | (a) << 16 | (b) << 12 | (c) << 5 | (d) << 3)
    583#define NPC_AF_INTFX_LDATAX_FLAGSX_CFG(a, b, c) \
    584		(0x980000 | (a) << 16 | (b) << 12 | (c) << 3)
    585#define NPC_AF_INTFX_MISS_STAT_ACT(a)	(0x1880040 + (a) * 0x8)
    586#define NPC_AF_INTFX_MISS_ACT(a)	(0x1a00000 | (a) << 4)
    587#define NPC_AF_INTFX_MISS_TAG_ACT(a)	(0x1b00008 | (a) << 4)
    588#define NPC_AF_MCAM_BANKX_HITX(a, b)	(0x1c80000 | (a) << 8 | (b) << 4)
    589#define NPC_AF_LKUP_CTL			(0x2000000)
    590#define NPC_AF_LKUP_DATAX(a)		(0x2000200 | (a) << 4)
    591#define NPC_AF_LKUP_RESULTX(a)		(0x2000400 | (a) << 4)
    592#define NPC_AF_INTFX_STAT(a)		(0x2000800 | (a) << 4)
    593#define NPC_AF_DBG_CTL			(0x3000000)
    594#define NPC_AF_DBG_STATUS		(0x3000010)
    595#define NPC_AF_KPUX_DBG(a)		(0x3000020 | (a) << 8)
    596#define NPC_AF_IKPU_ERR_CTL		(0x3000080)
    597#define NPC_AF_KPUX_ERR_CTL(a)		(0x30000a0 | (a) << 8)
    598#define NPC_AF_MCAM_DBG			(0x3001000)
    599#define NPC_AF_DBG_DATAX(a)		(0x3001400 | (a) << 4)
    600#define NPC_AF_DBG_RESULTX(a)		(0x3001800 | (a) << 4)
    601
    602#define NPC_AF_MCAMEX_BANKX_CAMX_INTF(a, b, c) ({			   \
    603	u64 offset;							   \
    604									   \
    605	offset = (0x1000000ull | (a) << 10 | (b) << 6 | (c) << 3);	   \
    606	if (rvu->hw->npc_ext_set)					   \
    607		offset = (0x8000000ull | (a) << 8 | (b) << 22 | (c) << 3); \
    608	offset; })
    609
    610#define NPC_AF_MCAMEX_BANKX_CAMX_W0(a, b, c) ({				   \
    611	u64 offset;							   \
    612									   \
    613	offset = (0x1000010ull | (a) << 10 | (b) << 6 | (c) << 3);	   \
    614	if (rvu->hw->npc_ext_set)					   \
    615		offset = (0x8000010ull | (a) << 8 | (b) << 22 | (c) << 3); \
    616	offset; })
    617
    618#define NPC_AF_MCAMEX_BANKX_CAMX_W1(a, b, c) ({				   \
    619	u64 offset;							   \
    620									   \
    621	offset = (0x1000020ull | (a) << 10 | (b) << 6 | (c) << 3);	   \
    622	if (rvu->hw->npc_ext_set)					   \
    623		offset = (0x8000020ull | (a) << 8 | (b) << 22 | (c) << 3); \
    624	offset; })
    625
    626#define NPC_AF_MCAMEX_BANKX_CFG(a, b) ({				   \
    627	u64 offset;							   \
    628									   \
    629	offset = (0x1800000ull | (a) << 8 | (b) << 4);			   \
    630	if (rvu->hw->npc_ext_set)					   \
    631		offset = (0x8000038ull | (a) << 8 | (b) << 22);		   \
    632	offset; })
    633
    634#define NPC_AF_MCAMEX_BANKX_ACTION(a, b) ({				   \
    635	u64 offset;							   \
    636									   \
    637	offset = (0x1900000ull | (a) << 8 | (b) << 4);			   \
    638	if (rvu->hw->npc_ext_set)					   \
    639		offset = (0x8000040ull | (a) << 8 | (b) << 22);		   \
    640	offset; })							   \
    641
    642#define NPC_AF_MCAMEX_BANKX_TAG_ACT(a, b) ({				   \
    643	u64 offset;							   \
    644									   \
    645	offset = (0x1900008ull | (a) << 8 | (b) << 4);			   \
    646	if (rvu->hw->npc_ext_set)					   \
    647		offset = (0x8000048ull | (a) << 8 | (b) << 22);		   \
    648	offset; })							   \
    649
    650#define NPC_AF_MCAMEX_BANKX_STAT_ACT(a, b) ({				   \
    651	u64 offset;							   \
    652									   \
    653	offset = (0x1880000ull | (a) << 8 | (b) << 4);			   \
    654	if (rvu->hw->npc_ext_set)					   \
    655		offset = (0x8000050ull | (a) << 8 | (b) << 22);		   \
    656	offset; })							   \
    657
    658#define NPC_AF_MATCH_STATX(a) ({					   \
    659	u64 offset;							   \
    660									   \
    661	offset = (0x1880008ull | (a) << 8);				   \
    662	if (rvu->hw->npc_ext_set)					   \
    663		offset = (0x8000078ull | (a) << 8);			   \
    664	offset; })							   \
    665
    666/* NDC */
    667#define NDC_AF_CONST			(0x00000)
    668#define NDC_AF_CLK_EN			(0x00020)
    669#define NDC_AF_CTL			(0x00030)
    670#define NDC_AF_BANK_CTL			(0x00040)
    671#define NDC_AF_BANK_CTL_DONE		(0x00048)
    672#define NDC_AF_INTR			(0x00058)
    673#define NDC_AF_INTR_W1S			(0x00060)
    674#define NDC_AF_INTR_ENA_W1S		(0x00068)
    675#define NDC_AF_INTR_ENA_W1C		(0x00070)
    676#define NDC_AF_ACTIVE_PC		(0x00078)
    677#define NDC_AF_BP_TEST_ENABLE		(0x001F8)
    678#define NDC_AF_BP_TEST(a)		(0x00200 | (a) << 3)
    679#define NDC_AF_BLK_RST			(0x002F0)
    680#define NDC_PRIV_AF_INT_CFG		(0x002F8)
    681#define NDC_AF_HASHX(a)			(0x00300 | (a) << 3)
    682#define NDC_AF_PORTX_RTX_RWX_REQ_PC(a, b, c) \
    683		(0x00C00 | (a) << 5 | (b) << 4 | (c) << 3)
    684#define NDC_AF_PORTX_RTX_RWX_OSTDN_PC(a, b, c) \
    685		(0x00D00 | (a) << 5 | (b) << 4 | (c) << 3)
    686#define NDC_AF_PORTX_RTX_RWX_LAT_PC(a, b, c) \
    687		(0x00E00 | (a) << 5 | (b) << 4 | (c) << 3)
    688#define NDC_AF_PORTX_RTX_CANT_ALLOC_PC(a, b) \
    689		(0x00F00 | (a) << 5 | (b) << 4)
    690#define NDC_AF_BANKX_HIT_PC(a)		(0x01000 | (a) << 3)
    691#define NDC_AF_BANKX_MISS_PC(a)		(0x01100 | (a) << 3)
    692
    693/* LBK */
    694#define LBK_CONST			(0x10ull)
    695#define LBK_LINK_CFG_P2X		(0x400ull)
    696#define LBK_LINK_CFG_X2P		(0x408ull)
    697#define LBK_CONST_CHANS			GENMASK_ULL(47, 32)
    698#define LBK_CONST_DST			GENMASK_ULL(31, 28)
    699#define LBK_CONST_SRC			GENMASK_ULL(27, 24)
    700#define LBK_CONST_BUF_SIZE		GENMASK_ULL(23, 0)
    701#define LBK_LINK_CFG_RANGE_MASK		GENMASK_ULL(19, 16)
    702#define LBK_LINK_CFG_ID_MASK		GENMASK_ULL(11, 6)
    703#define LBK_LINK_CFG_BASE_MASK		GENMASK_ULL(5, 0)
    704
    705/* APR */
    706#define	APR_AF_LMT_CFG			(0x000ull)
    707#define	APR_AF_LMT_MAP_BASE		(0x008ull)
    708#define	APR_AF_LMT_CTL			(0x010ull)
    709#define APR_LMT_MAP_ENT_DIS_SCH_CMP_SHIFT	23
    710#define APR_LMT_MAP_ENT_SCH_ENA_SHIFT		22
    711#define APR_LMT_MAP_ENT_DIS_LINE_PREF_SHIFT	21
    712
    713#endif /* RVU_REG_H */