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

t4_regs.h (101698B)


      1/*
      2 * This file is part of the Chelsio T4 Ethernet driver for Linux.
      3 *
      4 * Copyright (c) 2003-2014 Chelsio Communications, Inc. All rights reserved.
      5 *
      6 * This software is available to you under a choice of one of two
      7 * licenses.  You may choose to be licensed under the terms of the GNU
      8 * General Public License (GPL) Version 2, available from the file
      9 * COPYING in the main directory of this source tree, or the
     10 * OpenIB.org BSD license below:
     11 *
     12 *     Redistribution and use in source and binary forms, with or
     13 *     without modification, are permitted provided that the following
     14 *     conditions are met:
     15 *
     16 *      - Redistributions of source code must retain the above
     17 *        copyright notice, this list of conditions and the following
     18 *        disclaimer.
     19 *
     20 *      - Redistributions in binary form must reproduce the above
     21 *        copyright notice, this list of conditions and the following
     22 *        disclaimer in the documentation and/or other materials
     23 *        provided with the distribution.
     24 *
     25 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
     26 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
     27 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
     28 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
     29 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
     30 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
     31 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
     32 * SOFTWARE.
     33 */
     34
     35#ifndef __T4_REGS_H
     36#define __T4_REGS_H
     37
     38#define MYPF_BASE 0x1b000
     39#define MYPF_REG(reg_addr) (MYPF_BASE + (reg_addr))
     40
     41#define PF0_BASE 0x1e000
     42#define PF0_REG(reg_addr) (PF0_BASE + (reg_addr))
     43
     44#define PF_STRIDE 0x400
     45#define PF_BASE(idx) (PF0_BASE + (idx) * PF_STRIDE)
     46#define PF_REG(idx, reg) (PF_BASE(idx) + (reg))
     47
     48#define NUM_CIM_CTL_TSCH_CHANNEL_INSTANCES 4
     49#define NUM_CIM_CTL_TSCH_CHANNEL_TSCH_CLASS_INSTANCES 16
     50
     51#define MYPORT_BASE 0x1c000
     52#define MYPORT_REG(reg_addr) (MYPORT_BASE + (reg_addr))
     53
     54#define PORT0_BASE 0x20000
     55#define PORT0_REG(reg_addr) (PORT0_BASE + (reg_addr))
     56
     57#define PORT_STRIDE 0x2000
     58#define PORT_BASE(idx) (PORT0_BASE + (idx) * PORT_STRIDE)
     59#define PORT_REG(idx, reg) (PORT_BASE(idx) + (reg))
     60
     61#define EDC_STRIDE (EDC_1_BASE_ADDR - EDC_0_BASE_ADDR)
     62#define EDC_REG(reg, idx) (reg + EDC_STRIDE * idx)
     63
     64#define PCIE_MEM_ACCESS_REG(reg_addr, idx) ((reg_addr) + (idx) * 8)
     65#define PCIE_MAILBOX_REG(reg_addr, idx) ((reg_addr) + (idx) * 8)
     66#define MC_BIST_STATUS_REG(reg_addr, idx) ((reg_addr) + (idx) * 4)
     67#define EDC_BIST_STATUS_REG(reg_addr, idx) ((reg_addr) + (idx) * 4)
     68
     69#define PCIE_FW_REG(reg_addr, idx) ((reg_addr) + (idx) * 4)
     70
     71#define NUM_LE_DB_DBGI_REQ_DATA_INSTANCES 17
     72#define NUM_LE_DB_DBGI_RSP_DATA_INSTANCES 17
     73
     74#define SGE_PF_KDOORBELL_A 0x0
     75
     76#define QID_S    15
     77#define QID_V(x) ((x) << QID_S)
     78
     79#define DBPRIO_S    14
     80#define DBPRIO_V(x) ((x) << DBPRIO_S)
     81#define DBPRIO_F    DBPRIO_V(1U)
     82
     83#define PIDX_S    0
     84#define PIDX_V(x) ((x) << PIDX_S)
     85
     86#define SGE_VF_KDOORBELL_A 0x0
     87
     88#define DBTYPE_S    13
     89#define DBTYPE_V(x) ((x) << DBTYPE_S)
     90#define DBTYPE_F    DBTYPE_V(1U)
     91
     92#define PIDX_T5_S    0
     93#define PIDX_T5_M    0x1fffU
     94#define PIDX_T5_V(x) ((x) << PIDX_T5_S)
     95#define PIDX_T5_G(x) (((x) >> PIDX_T5_S) & PIDX_T5_M)
     96
     97#define SGE_PF_GTS_A 0x4
     98
     99#define INGRESSQID_S    16
    100#define INGRESSQID_V(x) ((x) << INGRESSQID_S)
    101
    102#define TIMERREG_S    13
    103#define TIMERREG_V(x) ((x) << TIMERREG_S)
    104
    105#define SEINTARM_S    12
    106#define SEINTARM_V(x) ((x) << SEINTARM_S)
    107
    108#define CIDXINC_S    0
    109#define CIDXINC_M    0xfffU
    110#define CIDXINC_V(x) ((x) << CIDXINC_S)
    111
    112#define SGE_CONTROL_A	0x1008
    113#define SGE_CONTROL2_A	0x1124
    114
    115#define RXPKTCPLMODE_S    18
    116#define RXPKTCPLMODE_V(x) ((x) << RXPKTCPLMODE_S)
    117#define RXPKTCPLMODE_F    RXPKTCPLMODE_V(1U)
    118
    119#define EGRSTATUSPAGESIZE_S    17
    120#define EGRSTATUSPAGESIZE_V(x) ((x) << EGRSTATUSPAGESIZE_S)
    121#define EGRSTATUSPAGESIZE_F    EGRSTATUSPAGESIZE_V(1U)
    122
    123#define PKTSHIFT_S    10
    124#define PKTSHIFT_M    0x7U
    125#define PKTSHIFT_V(x) ((x) << PKTSHIFT_S)
    126#define PKTSHIFT_G(x) (((x) >> PKTSHIFT_S) & PKTSHIFT_M)
    127
    128#define INGPCIEBOUNDARY_S    7
    129#define INGPCIEBOUNDARY_V(x) ((x) << INGPCIEBOUNDARY_S)
    130
    131#define INGPADBOUNDARY_S    4
    132#define INGPADBOUNDARY_M    0x7U
    133#define INGPADBOUNDARY_V(x) ((x) << INGPADBOUNDARY_S)
    134#define INGPADBOUNDARY_G(x) (((x) >> INGPADBOUNDARY_S) & INGPADBOUNDARY_M)
    135
    136#define EGRPCIEBOUNDARY_S    1
    137#define EGRPCIEBOUNDARY_V(x) ((x) << EGRPCIEBOUNDARY_S)
    138
    139#define  INGPACKBOUNDARY_S	16
    140#define  INGPACKBOUNDARY_M	0x7U
    141#define  INGPACKBOUNDARY_V(x)	((x) << INGPACKBOUNDARY_S)
    142#define  INGPACKBOUNDARY_G(x)	(((x) >> INGPACKBOUNDARY_S) \
    143				 & INGPACKBOUNDARY_M)
    144
    145#define VFIFO_ENABLE_S    10
    146#define VFIFO_ENABLE_V(x) ((x) << VFIFO_ENABLE_S)
    147#define VFIFO_ENABLE_F    VFIFO_ENABLE_V(1U)
    148
    149#define SGE_DBVFIFO_BADDR_A 0x1138
    150
    151#define DBVFIFO_SIZE_S    6
    152#define DBVFIFO_SIZE_M    0xfffU
    153#define DBVFIFO_SIZE_G(x) (((x) >> DBVFIFO_SIZE_S) & DBVFIFO_SIZE_M)
    154
    155#define T6_DBVFIFO_SIZE_S    0
    156#define T6_DBVFIFO_SIZE_M    0x1fffU
    157#define T6_DBVFIFO_SIZE_G(x) (((x) >> T6_DBVFIFO_SIZE_S) & T6_DBVFIFO_SIZE_M)
    158
    159#define SGE_CTXT_CMD_A 0x11fc
    160
    161#define BUSY_S    31
    162#define BUSY_V(x) ((x) << BUSY_S)
    163#define BUSY_F    BUSY_V(1U)
    164
    165#define CTXTTYPE_S    24
    166#define CTXTTYPE_M    0x3U
    167#define CTXTTYPE_V(x) ((x) << CTXTTYPE_S)
    168
    169#define CTXTQID_S    0
    170#define CTXTQID_M    0x1ffffU
    171#define CTXTQID_V(x) ((x) << CTXTQID_S)
    172
    173#define SGE_CTXT_DATA0_A 0x1200
    174#define SGE_CTXT_DATA5_A 0x1214
    175
    176#define GLOBALENABLE_S    0
    177#define GLOBALENABLE_V(x) ((x) << GLOBALENABLE_S)
    178#define GLOBALENABLE_F    GLOBALENABLE_V(1U)
    179
    180#define SGE_HOST_PAGE_SIZE_A 0x100c
    181
    182#define HOSTPAGESIZEPF7_S    28
    183#define HOSTPAGESIZEPF7_M    0xfU
    184#define HOSTPAGESIZEPF7_V(x) ((x) << HOSTPAGESIZEPF7_S)
    185#define HOSTPAGESIZEPF7_G(x) (((x) >> HOSTPAGESIZEPF7_S) & HOSTPAGESIZEPF7_M)
    186
    187#define HOSTPAGESIZEPF6_S    24
    188#define HOSTPAGESIZEPF6_M    0xfU
    189#define HOSTPAGESIZEPF6_V(x) ((x) << HOSTPAGESIZEPF6_S)
    190#define HOSTPAGESIZEPF6_G(x) (((x) >> HOSTPAGESIZEPF6_S) & HOSTPAGESIZEPF6_M)
    191
    192#define HOSTPAGESIZEPF5_S    20
    193#define HOSTPAGESIZEPF5_M    0xfU
    194#define HOSTPAGESIZEPF5_V(x) ((x) << HOSTPAGESIZEPF5_S)
    195#define HOSTPAGESIZEPF5_G(x) (((x) >> HOSTPAGESIZEPF5_S) & HOSTPAGESIZEPF5_M)
    196
    197#define HOSTPAGESIZEPF4_S    16
    198#define HOSTPAGESIZEPF4_M    0xfU
    199#define HOSTPAGESIZEPF4_V(x) ((x) << HOSTPAGESIZEPF4_S)
    200#define HOSTPAGESIZEPF4_G(x) (((x) >> HOSTPAGESIZEPF4_S) & HOSTPAGESIZEPF4_M)
    201
    202#define HOSTPAGESIZEPF3_S    12
    203#define HOSTPAGESIZEPF3_M    0xfU
    204#define HOSTPAGESIZEPF3_V(x) ((x) << HOSTPAGESIZEPF3_S)
    205#define HOSTPAGESIZEPF3_G(x) (((x) >> HOSTPAGESIZEPF3_S) & HOSTPAGESIZEPF3_M)
    206
    207#define HOSTPAGESIZEPF2_S    8
    208#define HOSTPAGESIZEPF2_M    0xfU
    209#define HOSTPAGESIZEPF2_V(x) ((x) << HOSTPAGESIZEPF2_S)
    210#define HOSTPAGESIZEPF2_G(x) (((x) >> HOSTPAGESIZEPF2_S) & HOSTPAGESIZEPF2_M)
    211
    212#define HOSTPAGESIZEPF1_S    4
    213#define HOSTPAGESIZEPF1_M    0xfU
    214#define HOSTPAGESIZEPF1_V(x) ((x) << HOSTPAGESIZEPF1_S)
    215#define HOSTPAGESIZEPF1_G(x) (((x) >> HOSTPAGESIZEPF1_S) & HOSTPAGESIZEPF1_M)
    216
    217#define HOSTPAGESIZEPF0_S    0
    218#define HOSTPAGESIZEPF0_M    0xfU
    219#define HOSTPAGESIZEPF0_V(x) ((x) << HOSTPAGESIZEPF0_S)
    220#define HOSTPAGESIZEPF0_G(x) (((x) >> HOSTPAGESIZEPF0_S) & HOSTPAGESIZEPF0_M)
    221
    222#define SGE_EGRESS_QUEUES_PER_PAGE_PF_A 0x1010
    223#define SGE_EGRESS_QUEUES_PER_PAGE_VF_A 0x1014
    224
    225#define QUEUESPERPAGEPF1_S    4
    226
    227#define QUEUESPERPAGEPF0_S    0
    228#define QUEUESPERPAGEPF0_M    0xfU
    229#define QUEUESPERPAGEPF0_V(x) ((x) << QUEUESPERPAGEPF0_S)
    230#define QUEUESPERPAGEPF0_G(x) (((x) >> QUEUESPERPAGEPF0_S) & QUEUESPERPAGEPF0_M)
    231
    232#define SGE_INT_CAUSE1_A	0x1024
    233#define SGE_INT_CAUSE2_A	0x1030
    234#define SGE_INT_CAUSE3_A	0x103c
    235
    236#define ERR_FLM_DBP_S    31
    237#define ERR_FLM_DBP_V(x) ((x) << ERR_FLM_DBP_S)
    238#define ERR_FLM_DBP_F    ERR_FLM_DBP_V(1U)
    239
    240#define ERR_FLM_IDMA1_S    30
    241#define ERR_FLM_IDMA1_V(x) ((x) << ERR_FLM_IDMA1_S)
    242#define ERR_FLM_IDMA1_F    ERR_FLM_IDMA1_V(1U)
    243
    244#define ERR_FLM_IDMA0_S    29
    245#define ERR_FLM_IDMA0_V(x) ((x) << ERR_FLM_IDMA0_S)
    246#define ERR_FLM_IDMA0_F    ERR_FLM_IDMA0_V(1U)
    247
    248#define ERR_FLM_HINT_S    28
    249#define ERR_FLM_HINT_V(x) ((x) << ERR_FLM_HINT_S)
    250#define ERR_FLM_HINT_F    ERR_FLM_HINT_V(1U)
    251
    252#define ERR_PCIE_ERROR3_S    27
    253#define ERR_PCIE_ERROR3_V(x) ((x) << ERR_PCIE_ERROR3_S)
    254#define ERR_PCIE_ERROR3_F    ERR_PCIE_ERROR3_V(1U)
    255
    256#define ERR_PCIE_ERROR2_S    26
    257#define ERR_PCIE_ERROR2_V(x) ((x) << ERR_PCIE_ERROR2_S)
    258#define ERR_PCIE_ERROR2_F    ERR_PCIE_ERROR2_V(1U)
    259
    260#define ERR_PCIE_ERROR1_S    25
    261#define ERR_PCIE_ERROR1_V(x) ((x) << ERR_PCIE_ERROR1_S)
    262#define ERR_PCIE_ERROR1_F    ERR_PCIE_ERROR1_V(1U)
    263
    264#define ERR_PCIE_ERROR0_S    24
    265#define ERR_PCIE_ERROR0_V(x) ((x) << ERR_PCIE_ERROR0_S)
    266#define ERR_PCIE_ERROR0_F    ERR_PCIE_ERROR0_V(1U)
    267
    268#define ERR_CPL_EXCEED_IQE_SIZE_S    22
    269#define ERR_CPL_EXCEED_IQE_SIZE_V(x) ((x) << ERR_CPL_EXCEED_IQE_SIZE_S)
    270#define ERR_CPL_EXCEED_IQE_SIZE_F    ERR_CPL_EXCEED_IQE_SIZE_V(1U)
    271
    272#define ERR_INVALID_CIDX_INC_S    21
    273#define ERR_INVALID_CIDX_INC_V(x) ((x) << ERR_INVALID_CIDX_INC_S)
    274#define ERR_INVALID_CIDX_INC_F    ERR_INVALID_CIDX_INC_V(1U)
    275
    276#define ERR_CPL_OPCODE_0_S    19
    277#define ERR_CPL_OPCODE_0_V(x) ((x) << ERR_CPL_OPCODE_0_S)
    278#define ERR_CPL_OPCODE_0_F    ERR_CPL_OPCODE_0_V(1U)
    279
    280#define ERR_DROPPED_DB_S    18
    281#define ERR_DROPPED_DB_V(x) ((x) << ERR_DROPPED_DB_S)
    282#define ERR_DROPPED_DB_F    ERR_DROPPED_DB_V(1U)
    283
    284#define ERR_DATA_CPL_ON_HIGH_QID1_S    17
    285#define ERR_DATA_CPL_ON_HIGH_QID1_V(x) ((x) << ERR_DATA_CPL_ON_HIGH_QID1_S)
    286#define ERR_DATA_CPL_ON_HIGH_QID1_F    ERR_DATA_CPL_ON_HIGH_QID1_V(1U)
    287
    288#define ERR_DATA_CPL_ON_HIGH_QID0_S    16
    289#define ERR_DATA_CPL_ON_HIGH_QID0_V(x) ((x) << ERR_DATA_CPL_ON_HIGH_QID0_S)
    290#define ERR_DATA_CPL_ON_HIGH_QID0_F    ERR_DATA_CPL_ON_HIGH_QID0_V(1U)
    291
    292#define ERR_BAD_DB_PIDX3_S    15
    293#define ERR_BAD_DB_PIDX3_V(x) ((x) << ERR_BAD_DB_PIDX3_S)
    294#define ERR_BAD_DB_PIDX3_F    ERR_BAD_DB_PIDX3_V(1U)
    295
    296#define ERR_BAD_DB_PIDX2_S    14
    297#define ERR_BAD_DB_PIDX2_V(x) ((x) << ERR_BAD_DB_PIDX2_S)
    298#define ERR_BAD_DB_PIDX2_F    ERR_BAD_DB_PIDX2_V(1U)
    299
    300#define ERR_BAD_DB_PIDX1_S    13
    301#define ERR_BAD_DB_PIDX1_V(x) ((x) << ERR_BAD_DB_PIDX1_S)
    302#define ERR_BAD_DB_PIDX1_F    ERR_BAD_DB_PIDX1_V(1U)
    303
    304#define ERR_BAD_DB_PIDX0_S    12
    305#define ERR_BAD_DB_PIDX0_V(x) ((x) << ERR_BAD_DB_PIDX0_S)
    306#define ERR_BAD_DB_PIDX0_F    ERR_BAD_DB_PIDX0_V(1U)
    307
    308#define ERR_ING_CTXT_PRIO_S    10
    309#define ERR_ING_CTXT_PRIO_V(x) ((x) << ERR_ING_CTXT_PRIO_S)
    310#define ERR_ING_CTXT_PRIO_F    ERR_ING_CTXT_PRIO_V(1U)
    311
    312#define ERR_EGR_CTXT_PRIO_S    9
    313#define ERR_EGR_CTXT_PRIO_V(x) ((x) << ERR_EGR_CTXT_PRIO_S)
    314#define ERR_EGR_CTXT_PRIO_F    ERR_EGR_CTXT_PRIO_V(1U)
    315
    316#define DBFIFO_HP_INT_S    8
    317#define DBFIFO_HP_INT_V(x) ((x) << DBFIFO_HP_INT_S)
    318#define DBFIFO_HP_INT_F    DBFIFO_HP_INT_V(1U)
    319
    320#define DBFIFO_LP_INT_S    7
    321#define DBFIFO_LP_INT_V(x) ((x) << DBFIFO_LP_INT_S)
    322#define DBFIFO_LP_INT_F    DBFIFO_LP_INT_V(1U)
    323
    324#define INGRESS_SIZE_ERR_S    5
    325#define INGRESS_SIZE_ERR_V(x) ((x) << INGRESS_SIZE_ERR_S)
    326#define INGRESS_SIZE_ERR_F    INGRESS_SIZE_ERR_V(1U)
    327
    328#define EGRESS_SIZE_ERR_S    4
    329#define EGRESS_SIZE_ERR_V(x) ((x) << EGRESS_SIZE_ERR_S)
    330#define EGRESS_SIZE_ERR_F    EGRESS_SIZE_ERR_V(1U)
    331
    332#define SGE_INT_ENABLE3_A 0x1040
    333#define SGE_FL_BUFFER_SIZE0_A 0x1044
    334#define SGE_FL_BUFFER_SIZE1_A 0x1048
    335#define SGE_FL_BUFFER_SIZE2_A 0x104c
    336#define SGE_FL_BUFFER_SIZE3_A 0x1050
    337#define SGE_FL_BUFFER_SIZE4_A 0x1054
    338#define SGE_FL_BUFFER_SIZE5_A 0x1058
    339#define SGE_FL_BUFFER_SIZE6_A 0x105c
    340#define SGE_FL_BUFFER_SIZE7_A 0x1060
    341#define SGE_FL_BUFFER_SIZE8_A 0x1064
    342
    343#define SGE_IMSG_CTXT_BADDR_A 0x1088
    344#define SGE_FLM_CACHE_BADDR_A 0x108c
    345#define SGE_FLM_CFG_A 0x1090
    346
    347#define NOHDR_S    18
    348#define NOHDR_V(x) ((x) << NOHDR_S)
    349#define NOHDR_F    NOHDR_V(1U)
    350
    351#define HDRSTARTFLQ_S    11
    352#define HDRSTARTFLQ_M    0x7U
    353#define HDRSTARTFLQ_G(x) (((x) >> HDRSTARTFLQ_S) & HDRSTARTFLQ_M)
    354
    355#define SGE_INGRESS_RX_THRESHOLD_A 0x10a0
    356
    357#define THRESHOLD_0_S    24
    358#define THRESHOLD_0_M    0x3fU
    359#define THRESHOLD_0_V(x) ((x) << THRESHOLD_0_S)
    360#define THRESHOLD_0_G(x) (((x) >> THRESHOLD_0_S) & THRESHOLD_0_M)
    361
    362#define THRESHOLD_1_S    16
    363#define THRESHOLD_1_M    0x3fU
    364#define THRESHOLD_1_V(x) ((x) << THRESHOLD_1_S)
    365#define THRESHOLD_1_G(x) (((x) >> THRESHOLD_1_S) & THRESHOLD_1_M)
    366
    367#define THRESHOLD_2_S    8
    368#define THRESHOLD_2_M    0x3fU
    369#define THRESHOLD_2_V(x) ((x) << THRESHOLD_2_S)
    370#define THRESHOLD_2_G(x) (((x) >> THRESHOLD_2_S) & THRESHOLD_2_M)
    371
    372#define THRESHOLD_3_S    0
    373#define THRESHOLD_3_M    0x3fU
    374#define THRESHOLD_3_V(x) ((x) << THRESHOLD_3_S)
    375#define THRESHOLD_3_G(x) (((x) >> THRESHOLD_3_S) & THRESHOLD_3_M)
    376
    377#define SGE_CONM_CTRL_A 0x1094
    378
    379#define EGRTHRESHOLD_S    8
    380#define EGRTHRESHOLD_M    0x3fU
    381#define EGRTHRESHOLD_V(x) ((x) << EGRTHRESHOLD_S)
    382#define EGRTHRESHOLD_G(x) (((x) >> EGRTHRESHOLD_S) & EGRTHRESHOLD_M)
    383
    384#define EGRTHRESHOLDPACKING_S    14
    385#define EGRTHRESHOLDPACKING_M    0x3fU
    386#define EGRTHRESHOLDPACKING_V(x) ((x) << EGRTHRESHOLDPACKING_S)
    387#define EGRTHRESHOLDPACKING_G(x) \
    388	(((x) >> EGRTHRESHOLDPACKING_S) & EGRTHRESHOLDPACKING_M)
    389
    390#define T6_EGRTHRESHOLDPACKING_S    16
    391#define T6_EGRTHRESHOLDPACKING_M    0xffU
    392#define T6_EGRTHRESHOLDPACKING_G(x) \
    393	(((x) >> T6_EGRTHRESHOLDPACKING_S) & T6_EGRTHRESHOLDPACKING_M)
    394
    395#define SGE_TIMESTAMP_LO_A 0x1098
    396#define SGE_TIMESTAMP_HI_A 0x109c
    397
    398#define TSOP_S    28
    399#define TSOP_M    0x3U
    400#define TSOP_V(x) ((x) << TSOP_S)
    401#define TSOP_G(x) (((x) >> TSOP_S) & TSOP_M)
    402
    403#define TSVAL_S    0
    404#define TSVAL_M    0xfffffffU
    405#define TSVAL_V(x) ((x) << TSVAL_S)
    406#define TSVAL_G(x) (((x) >> TSVAL_S) & TSVAL_M)
    407
    408#define SGE_DBFIFO_STATUS_A 0x10a4
    409#define SGE_DBVFIFO_SIZE_A 0x113c
    410
    411#define HP_INT_THRESH_S    28
    412#define HP_INT_THRESH_M    0xfU
    413#define HP_INT_THRESH_V(x) ((x) << HP_INT_THRESH_S)
    414
    415#define LP_INT_THRESH_S    12
    416#define LP_INT_THRESH_M    0xfU
    417#define LP_INT_THRESH_V(x) ((x) << LP_INT_THRESH_S)
    418
    419#define SGE_DOORBELL_CONTROL_A 0x10a8
    420
    421#define NOCOALESCE_S    26
    422#define NOCOALESCE_V(x) ((x) << NOCOALESCE_S)
    423#define NOCOALESCE_F    NOCOALESCE_V(1U)
    424
    425#define ENABLE_DROP_S    13
    426#define ENABLE_DROP_V(x) ((x) << ENABLE_DROP_S)
    427#define ENABLE_DROP_F    ENABLE_DROP_V(1U)
    428
    429#define SGE_TIMER_VALUE_0_AND_1_A 0x10b8
    430
    431#define TIMERVALUE0_S    16
    432#define TIMERVALUE0_M    0xffffU
    433#define TIMERVALUE0_V(x) ((x) << TIMERVALUE0_S)
    434#define TIMERVALUE0_G(x) (((x) >> TIMERVALUE0_S) & TIMERVALUE0_M)
    435
    436#define TIMERVALUE1_S    0
    437#define TIMERVALUE1_M    0xffffU
    438#define TIMERVALUE1_V(x) ((x) << TIMERVALUE1_S)
    439#define TIMERVALUE1_G(x) (((x) >> TIMERVALUE1_S) & TIMERVALUE1_M)
    440
    441#define SGE_TIMER_VALUE_2_AND_3_A 0x10bc
    442
    443#define TIMERVALUE2_S    16
    444#define TIMERVALUE2_M    0xffffU
    445#define TIMERVALUE2_V(x) ((x) << TIMERVALUE2_S)
    446#define TIMERVALUE2_G(x) (((x) >> TIMERVALUE2_S) & TIMERVALUE2_M)
    447
    448#define TIMERVALUE3_S    0
    449#define TIMERVALUE3_M    0xffffU
    450#define TIMERVALUE3_V(x) ((x) << TIMERVALUE3_S)
    451#define TIMERVALUE3_G(x) (((x) >> TIMERVALUE3_S) & TIMERVALUE3_M)
    452
    453#define SGE_TIMER_VALUE_4_AND_5_A 0x10c0
    454
    455#define TIMERVALUE4_S    16
    456#define TIMERVALUE4_M    0xffffU
    457#define TIMERVALUE4_V(x) ((x) << TIMERVALUE4_S)
    458#define TIMERVALUE4_G(x) (((x) >> TIMERVALUE4_S) & TIMERVALUE4_M)
    459
    460#define TIMERVALUE5_S    0
    461#define TIMERVALUE5_M    0xffffU
    462#define TIMERVALUE5_V(x) ((x) << TIMERVALUE5_S)
    463#define TIMERVALUE5_G(x) (((x) >> TIMERVALUE5_S) & TIMERVALUE5_M)
    464
    465#define SGE_DEBUG_INDEX_A 0x10cc
    466#define SGE_DEBUG_DATA_HIGH_A 0x10d0
    467#define SGE_DEBUG_DATA_LOW_A 0x10d4
    468
    469#define SGE_DEBUG_DATA_LOW_INDEX_2_A	0x12c8
    470#define SGE_DEBUG_DATA_LOW_INDEX_3_A	0x12cc
    471#define SGE_DEBUG_DATA_HIGH_INDEX_10_A	0x12a8
    472
    473#define SGE_INGRESS_QUEUES_PER_PAGE_PF_A 0x10f4
    474#define SGE_INGRESS_QUEUES_PER_PAGE_VF_A 0x10f8
    475
    476#define SGE_ERROR_STATS_A 0x1100
    477
    478#define UNCAPTURED_ERROR_S    18
    479#define UNCAPTURED_ERROR_V(x) ((x) << UNCAPTURED_ERROR_S)
    480#define UNCAPTURED_ERROR_F    UNCAPTURED_ERROR_V(1U)
    481
    482#define ERROR_QID_VALID_S    17
    483#define ERROR_QID_VALID_V(x) ((x) << ERROR_QID_VALID_S)
    484#define ERROR_QID_VALID_F    ERROR_QID_VALID_V(1U)
    485
    486#define ERROR_QID_S    0
    487#define ERROR_QID_M    0x1ffffU
    488#define ERROR_QID_G(x) (((x) >> ERROR_QID_S) & ERROR_QID_M)
    489
    490#define SGE_INT_CAUSE5_A        0x110c
    491
    492#define ERR_T_RXCRC_S    31
    493#define ERR_T_RXCRC_V(x) ((x) << ERR_T_RXCRC_S)
    494#define ERR_T_RXCRC_F    ERR_T_RXCRC_V(1U)
    495
    496#define HP_INT_THRESH_S    28
    497#define HP_INT_THRESH_M    0xfU
    498#define HP_INT_THRESH_V(x) ((x) << HP_INT_THRESH_S)
    499
    500#define HP_COUNT_S    16
    501#define HP_COUNT_M    0x7ffU
    502#define HP_COUNT_G(x) (((x) >> HP_COUNT_S) & HP_COUNT_M)
    503
    504#define LP_INT_THRESH_S    12
    505#define LP_INT_THRESH_M    0xfU
    506#define LP_INT_THRESH_V(x) ((x) << LP_INT_THRESH_S)
    507
    508#define LP_COUNT_S    0
    509#define LP_COUNT_M    0x7ffU
    510#define LP_COUNT_G(x) (((x) >> LP_COUNT_S) & LP_COUNT_M)
    511
    512#define LP_INT_THRESH_T5_S    18
    513#define LP_INT_THRESH_T5_M    0xfffU
    514#define LP_INT_THRESH_T5_V(x) ((x) << LP_INT_THRESH_T5_S)
    515
    516#define LP_COUNT_T5_S    0
    517#define LP_COUNT_T5_M    0x3ffffU
    518#define LP_COUNT_T5_G(x) (((x) >> LP_COUNT_T5_S) & LP_COUNT_T5_M)
    519
    520#define SGE_DOORBELL_CONTROL_A 0x10a8
    521
    522#define SGE_STAT_TOTAL_A	0x10e4
    523#define SGE_STAT_MATCH_A	0x10e8
    524#define SGE_STAT_CFG_A		0x10ec
    525
    526#define STATMODE_S    2
    527#define STATMODE_V(x) ((x) << STATMODE_S)
    528
    529#define STATSOURCE_T5_S    9
    530#define STATSOURCE_T5_M    0xfU
    531#define STATSOURCE_T5_V(x) ((x) << STATSOURCE_T5_S)
    532#define STATSOURCE_T5_G(x) (((x) >> STATSOURCE_T5_S) & STATSOURCE_T5_M)
    533
    534#define T6_STATMODE_S    0
    535#define T6_STATMODE_V(x) ((x) << T6_STATMODE_S)
    536
    537#define SGE_DBFIFO_STATUS2_A 0x1118
    538
    539#define HP_INT_THRESH_T5_S    10
    540#define HP_INT_THRESH_T5_M    0xfU
    541#define HP_INT_THRESH_T5_V(x) ((x) << HP_INT_THRESH_T5_S)
    542
    543#define HP_COUNT_T5_S    0
    544#define HP_COUNT_T5_M    0x3ffU
    545#define HP_COUNT_T5_G(x) (((x) >> HP_COUNT_T5_S) & HP_COUNT_T5_M)
    546
    547#define ENABLE_DROP_S    13
    548#define ENABLE_DROP_V(x) ((x) << ENABLE_DROP_S)
    549#define ENABLE_DROP_F    ENABLE_DROP_V(1U)
    550
    551#define DROPPED_DB_S    0
    552#define DROPPED_DB_V(x) ((x) << DROPPED_DB_S)
    553#define DROPPED_DB_F    DROPPED_DB_V(1U)
    554
    555#define SGE_CTXT_CMD_A 0x11fc
    556#define SGE_DBQ_CTXT_BADDR_A 0x1084
    557
    558/* registers for module PCIE */
    559#define PCIE_PF_CFG_A	0x40
    560
    561#define AIVEC_S    4
    562#define AIVEC_M    0x3ffU
    563#define AIVEC_V(x) ((x) << AIVEC_S)
    564
    565#define PCIE_PF_CLI_A	0x44
    566
    567#define PCIE_PF_EXPROM_OFST_A 0x4c
    568#define OFFSET_S    10
    569#define OFFSET_M    0x3fffU
    570#define OFFSET_G(x) (((x) >> OFFSET_S) & OFFSET_M)
    571
    572#define PCIE_INT_CAUSE_A	0x3004
    573
    574#define UNXSPLCPLERR_S    29
    575#define UNXSPLCPLERR_V(x) ((x) << UNXSPLCPLERR_S)
    576#define UNXSPLCPLERR_F    UNXSPLCPLERR_V(1U)
    577
    578#define PCIEPINT_S    28
    579#define PCIEPINT_V(x) ((x) << PCIEPINT_S)
    580#define PCIEPINT_F    PCIEPINT_V(1U)
    581
    582#define PCIESINT_S    27
    583#define PCIESINT_V(x) ((x) << PCIESINT_S)
    584#define PCIESINT_F    PCIESINT_V(1U)
    585
    586#define RPLPERR_S    26
    587#define RPLPERR_V(x) ((x) << RPLPERR_S)
    588#define RPLPERR_F    RPLPERR_V(1U)
    589
    590#define RXWRPERR_S    25
    591#define RXWRPERR_V(x) ((x) << RXWRPERR_S)
    592#define RXWRPERR_F    RXWRPERR_V(1U)
    593
    594#define RXCPLPERR_S    24
    595#define RXCPLPERR_V(x) ((x) << RXCPLPERR_S)
    596#define RXCPLPERR_F    RXCPLPERR_V(1U)
    597
    598#define PIOTAGPERR_S    23
    599#define PIOTAGPERR_V(x) ((x) << PIOTAGPERR_S)
    600#define PIOTAGPERR_F    PIOTAGPERR_V(1U)
    601
    602#define MATAGPERR_S    22
    603#define MATAGPERR_V(x) ((x) << MATAGPERR_S)
    604#define MATAGPERR_F    MATAGPERR_V(1U)
    605
    606#define INTXCLRPERR_S    21
    607#define INTXCLRPERR_V(x) ((x) << INTXCLRPERR_S)
    608#define INTXCLRPERR_F    INTXCLRPERR_V(1U)
    609
    610#define FIDPERR_S    20
    611#define FIDPERR_V(x) ((x) << FIDPERR_S)
    612#define FIDPERR_F    FIDPERR_V(1U)
    613
    614#define CFGSNPPERR_S    19
    615#define CFGSNPPERR_V(x) ((x) << CFGSNPPERR_S)
    616#define CFGSNPPERR_F    CFGSNPPERR_V(1U)
    617
    618#define HRSPPERR_S    18
    619#define HRSPPERR_V(x) ((x) << HRSPPERR_S)
    620#define HRSPPERR_F    HRSPPERR_V(1U)
    621
    622#define HREQPERR_S    17
    623#define HREQPERR_V(x) ((x) << HREQPERR_S)
    624#define HREQPERR_F    HREQPERR_V(1U)
    625
    626#define HCNTPERR_S    16
    627#define HCNTPERR_V(x) ((x) << HCNTPERR_S)
    628#define HCNTPERR_F    HCNTPERR_V(1U)
    629
    630#define DRSPPERR_S    15
    631#define DRSPPERR_V(x) ((x) << DRSPPERR_S)
    632#define DRSPPERR_F    DRSPPERR_V(1U)
    633
    634#define DREQPERR_S    14
    635#define DREQPERR_V(x) ((x) << DREQPERR_S)
    636#define DREQPERR_F    DREQPERR_V(1U)
    637
    638#define DCNTPERR_S    13
    639#define DCNTPERR_V(x) ((x) << DCNTPERR_S)
    640#define DCNTPERR_F    DCNTPERR_V(1U)
    641
    642#define CRSPPERR_S    12
    643#define CRSPPERR_V(x) ((x) << CRSPPERR_S)
    644#define CRSPPERR_F    CRSPPERR_V(1U)
    645
    646#define CREQPERR_S    11
    647#define CREQPERR_V(x) ((x) << CREQPERR_S)
    648#define CREQPERR_F    CREQPERR_V(1U)
    649
    650#define CCNTPERR_S    10
    651#define CCNTPERR_V(x) ((x) << CCNTPERR_S)
    652#define CCNTPERR_F    CCNTPERR_V(1U)
    653
    654#define TARTAGPERR_S    9
    655#define TARTAGPERR_V(x) ((x) << TARTAGPERR_S)
    656#define TARTAGPERR_F    TARTAGPERR_V(1U)
    657
    658#define PIOREQPERR_S    8
    659#define PIOREQPERR_V(x) ((x) << PIOREQPERR_S)
    660#define PIOREQPERR_F    PIOREQPERR_V(1U)
    661
    662#define PIOCPLPERR_S    7
    663#define PIOCPLPERR_V(x) ((x) << PIOCPLPERR_S)
    664#define PIOCPLPERR_F    PIOCPLPERR_V(1U)
    665
    666#define MSIXDIPERR_S    6
    667#define MSIXDIPERR_V(x) ((x) << MSIXDIPERR_S)
    668#define MSIXDIPERR_F    MSIXDIPERR_V(1U)
    669
    670#define MSIXDATAPERR_S    5
    671#define MSIXDATAPERR_V(x) ((x) << MSIXDATAPERR_S)
    672#define MSIXDATAPERR_F    MSIXDATAPERR_V(1U)
    673
    674#define MSIXADDRHPERR_S    4
    675#define MSIXADDRHPERR_V(x) ((x) << MSIXADDRHPERR_S)
    676#define MSIXADDRHPERR_F    MSIXADDRHPERR_V(1U)
    677
    678#define MSIXADDRLPERR_S    3
    679#define MSIXADDRLPERR_V(x) ((x) << MSIXADDRLPERR_S)
    680#define MSIXADDRLPERR_F    MSIXADDRLPERR_V(1U)
    681
    682#define MSIDATAPERR_S    2
    683#define MSIDATAPERR_V(x) ((x) << MSIDATAPERR_S)
    684#define MSIDATAPERR_F    MSIDATAPERR_V(1U)
    685
    686#define MSIADDRHPERR_S    1
    687#define MSIADDRHPERR_V(x) ((x) << MSIADDRHPERR_S)
    688#define MSIADDRHPERR_F    MSIADDRHPERR_V(1U)
    689
    690#define MSIADDRLPERR_S    0
    691#define MSIADDRLPERR_V(x) ((x) << MSIADDRLPERR_S)
    692#define MSIADDRLPERR_F    MSIADDRLPERR_V(1U)
    693
    694#define READRSPERR_S    29
    695#define READRSPERR_V(x) ((x) << READRSPERR_S)
    696#define READRSPERR_F    READRSPERR_V(1U)
    697
    698#define TRGT1GRPPERR_S    28
    699#define TRGT1GRPPERR_V(x) ((x) << TRGT1GRPPERR_S)
    700#define TRGT1GRPPERR_F    TRGT1GRPPERR_V(1U)
    701
    702#define IPSOTPERR_S    27
    703#define IPSOTPERR_V(x) ((x) << IPSOTPERR_S)
    704#define IPSOTPERR_F    IPSOTPERR_V(1U)
    705
    706#define IPRETRYPERR_S    26
    707#define IPRETRYPERR_V(x) ((x) << IPRETRYPERR_S)
    708#define IPRETRYPERR_F    IPRETRYPERR_V(1U)
    709
    710#define IPRXDATAGRPPERR_S    25
    711#define IPRXDATAGRPPERR_V(x) ((x) << IPRXDATAGRPPERR_S)
    712#define IPRXDATAGRPPERR_F    IPRXDATAGRPPERR_V(1U)
    713
    714#define IPRXHDRGRPPERR_S    24
    715#define IPRXHDRGRPPERR_V(x) ((x) << IPRXHDRGRPPERR_S)
    716#define IPRXHDRGRPPERR_F    IPRXHDRGRPPERR_V(1U)
    717
    718#define MAGRPPERR_S    22
    719#define MAGRPPERR_V(x) ((x) << MAGRPPERR_S)
    720#define MAGRPPERR_F    MAGRPPERR_V(1U)
    721
    722#define VFIDPERR_S    21
    723#define VFIDPERR_V(x) ((x) << VFIDPERR_S)
    724#define VFIDPERR_F    VFIDPERR_V(1U)
    725
    726#define HREQWRPERR_S    16
    727#define HREQWRPERR_V(x) ((x) << HREQWRPERR_S)
    728#define HREQWRPERR_F    HREQWRPERR_V(1U)
    729
    730#define DREQWRPERR_S    13
    731#define DREQWRPERR_V(x) ((x) << DREQWRPERR_S)
    732#define DREQWRPERR_F    DREQWRPERR_V(1U)
    733
    734#define CREQRDPERR_S    11
    735#define CREQRDPERR_V(x) ((x) << CREQRDPERR_S)
    736#define CREQRDPERR_F    CREQRDPERR_V(1U)
    737
    738#define MSTTAGQPERR_S    10
    739#define MSTTAGQPERR_V(x) ((x) << MSTTAGQPERR_S)
    740#define MSTTAGQPERR_F    MSTTAGQPERR_V(1U)
    741
    742#define PIOREQGRPPERR_S    8
    743#define PIOREQGRPPERR_V(x) ((x) << PIOREQGRPPERR_S)
    744#define PIOREQGRPPERR_F    PIOREQGRPPERR_V(1U)
    745
    746#define PIOCPLGRPPERR_S    7
    747#define PIOCPLGRPPERR_V(x) ((x) << PIOCPLGRPPERR_S)
    748#define PIOCPLGRPPERR_F    PIOCPLGRPPERR_V(1U)
    749
    750#define MSIXSTIPERR_S    2
    751#define MSIXSTIPERR_V(x) ((x) << MSIXSTIPERR_S)
    752#define MSIXSTIPERR_F    MSIXSTIPERR_V(1U)
    753
    754#define MSTTIMEOUTPERR_S    1
    755#define MSTTIMEOUTPERR_V(x) ((x) << MSTTIMEOUTPERR_S)
    756#define MSTTIMEOUTPERR_F    MSTTIMEOUTPERR_V(1U)
    757
    758#define MSTGRPPERR_S    0
    759#define MSTGRPPERR_V(x) ((x) << MSTGRPPERR_S)
    760#define MSTGRPPERR_F    MSTGRPPERR_V(1U)
    761
    762#define PCIE_NONFAT_ERR_A	0x3010
    763#define PCIE_CFG_SPACE_REQ_A	0x3060
    764#define PCIE_CFG_SPACE_DATA_A	0x3064
    765#define PCIE_MEM_ACCESS_BASE_WIN_A 0x3068
    766
    767#define PCIEOFST_S    10
    768#define PCIEOFST_M    0x3fffffU
    769#define PCIEOFST_G(x) (((x) >> PCIEOFST_S) & PCIEOFST_M)
    770
    771#define BIR_S    8
    772#define BIR_M    0x3U
    773#define BIR_V(x) ((x) << BIR_S)
    774#define BIR_G(x) (((x) >> BIR_S) & BIR_M)
    775
    776#define WINDOW_S    0
    777#define WINDOW_M    0xffU
    778#define WINDOW_V(x) ((x) << WINDOW_S)
    779#define WINDOW_G(x) (((x) >> WINDOW_S) & WINDOW_M)
    780
    781#define PCIE_MEM_ACCESS_OFFSET_A 0x306c
    782
    783#define ENABLE_S    30
    784#define ENABLE_V(x) ((x) << ENABLE_S)
    785#define ENABLE_F    ENABLE_V(1U)
    786
    787#define LOCALCFG_S    28
    788#define LOCALCFG_V(x) ((x) << LOCALCFG_S)
    789#define LOCALCFG_F    LOCALCFG_V(1U)
    790
    791#define FUNCTION_S    12
    792#define FUNCTION_V(x) ((x) << FUNCTION_S)
    793
    794#define REGISTER_S    0
    795#define REGISTER_V(x) ((x) << REGISTER_S)
    796
    797#define T6_ENABLE_S    31
    798#define T6_ENABLE_V(x) ((x) << T6_ENABLE_S)
    799#define T6_ENABLE_F    T6_ENABLE_V(1U)
    800
    801#define PFNUM_S    0
    802#define PFNUM_V(x) ((x) << PFNUM_S)
    803
    804#define PCIE_FW_A 0x30b8
    805#define PCIE_FW_PF_A 0x30bc
    806
    807#define PCIE_CORE_UTL_SYSTEM_BUS_AGENT_STATUS_A 0x5908
    808
    809#define RNPP_S    31
    810#define RNPP_V(x) ((x) << RNPP_S)
    811#define RNPP_F    RNPP_V(1U)
    812
    813#define RPCP_S    29
    814#define RPCP_V(x) ((x) << RPCP_S)
    815#define RPCP_F    RPCP_V(1U)
    816
    817#define RCIP_S    27
    818#define RCIP_V(x) ((x) << RCIP_S)
    819#define RCIP_F    RCIP_V(1U)
    820
    821#define RCCP_S    26
    822#define RCCP_V(x) ((x) << RCCP_S)
    823#define RCCP_F    RCCP_V(1U)
    824
    825#define RFTP_S    23
    826#define RFTP_V(x) ((x) << RFTP_S)
    827#define RFTP_F    RFTP_V(1U)
    828
    829#define PTRP_S    20
    830#define PTRP_V(x) ((x) << PTRP_S)
    831#define PTRP_F    PTRP_V(1U)
    832
    833#define PCIE_CORE_UTL_PCI_EXPRESS_PORT_STATUS_A 0x59a4
    834
    835#define TPCP_S    30
    836#define TPCP_V(x) ((x) << TPCP_S)
    837#define TPCP_F    TPCP_V(1U)
    838
    839#define TNPP_S    29
    840#define TNPP_V(x) ((x) << TNPP_S)
    841#define TNPP_F    TNPP_V(1U)
    842
    843#define TFTP_S    28
    844#define TFTP_V(x) ((x) << TFTP_S)
    845#define TFTP_F    TFTP_V(1U)
    846
    847#define TCAP_S    27
    848#define TCAP_V(x) ((x) << TCAP_S)
    849#define TCAP_F    TCAP_V(1U)
    850
    851#define TCIP_S    26
    852#define TCIP_V(x) ((x) << TCIP_S)
    853#define TCIP_F    TCIP_V(1U)
    854
    855#define RCAP_S    25
    856#define RCAP_V(x) ((x) << RCAP_S)
    857#define RCAP_F    RCAP_V(1U)
    858
    859#define PLUP_S    23
    860#define PLUP_V(x) ((x) << PLUP_S)
    861#define PLUP_F    PLUP_V(1U)
    862
    863#define PLDN_S    22
    864#define PLDN_V(x) ((x) << PLDN_S)
    865#define PLDN_F    PLDN_V(1U)
    866
    867#define OTDD_S    21
    868#define OTDD_V(x) ((x) << OTDD_S)
    869#define OTDD_F    OTDD_V(1U)
    870
    871#define GTRP_S    20
    872#define GTRP_V(x) ((x) << GTRP_S)
    873#define GTRP_F    GTRP_V(1U)
    874
    875#define RDPE_S    18
    876#define RDPE_V(x) ((x) << RDPE_S)
    877#define RDPE_F    RDPE_V(1U)
    878
    879#define TDCE_S    17
    880#define TDCE_V(x) ((x) << TDCE_S)
    881#define TDCE_F    TDCE_V(1U)
    882
    883#define TDUE_S    16
    884#define TDUE_V(x) ((x) << TDUE_S)
    885#define TDUE_F    TDUE_V(1U)
    886
    887/* SPARE2 register contains 32-bit value at offset 0x6 in Serial INIT
    888 * Configuration flashed on EEPROM. This value corresponds to 32-bit
    889 * Serial Configuration Version information.
    890 */
    891#define PCIE_STATIC_SPARE2_A	0x5bfc
    892
    893/* registers for module MC */
    894#define MC_INT_CAUSE_A		0x7518
    895#define MC_P_INT_CAUSE_A	0x41318
    896
    897#define ECC_UE_INT_CAUSE_S    2
    898#define ECC_UE_INT_CAUSE_V(x) ((x) << ECC_UE_INT_CAUSE_S)
    899#define ECC_UE_INT_CAUSE_F    ECC_UE_INT_CAUSE_V(1U)
    900
    901#define ECC_CE_INT_CAUSE_S    1
    902#define ECC_CE_INT_CAUSE_V(x) ((x) << ECC_CE_INT_CAUSE_S)
    903#define ECC_CE_INT_CAUSE_F    ECC_CE_INT_CAUSE_V(1U)
    904
    905#define PERR_INT_CAUSE_S    0
    906#define PERR_INT_CAUSE_V(x) ((x) << PERR_INT_CAUSE_S)
    907#define PERR_INT_CAUSE_F    PERR_INT_CAUSE_V(1U)
    908
    909#define DBG_GPIO_EN_A		0x6010
    910#define XGMAC_PORT_CFG_A	0x1000
    911#define MAC_PORT_CFG_A		0x800
    912
    913#define SIGNAL_DET_S    14
    914#define SIGNAL_DET_V(x) ((x) << SIGNAL_DET_S)
    915#define SIGNAL_DET_F    SIGNAL_DET_V(1U)
    916
    917#define MC_ECC_STATUS_A		0x751c
    918#define MC_P_ECC_STATUS_A	0x4131c
    919
    920#define ECC_CECNT_S    16
    921#define ECC_CECNT_M    0xffffU
    922#define ECC_CECNT_V(x) ((x) << ECC_CECNT_S)
    923#define ECC_CECNT_G(x) (((x) >> ECC_CECNT_S) & ECC_CECNT_M)
    924
    925#define ECC_UECNT_S    0
    926#define ECC_UECNT_M    0xffffU
    927#define ECC_UECNT_V(x) ((x) << ECC_UECNT_S)
    928#define ECC_UECNT_G(x) (((x) >> ECC_UECNT_S) & ECC_UECNT_M)
    929
    930#define MC_BIST_CMD_A 0x7600
    931
    932#define START_BIST_S    31
    933#define START_BIST_V(x) ((x) << START_BIST_S)
    934#define START_BIST_F    START_BIST_V(1U)
    935
    936#define BIST_CMD_GAP_S    8
    937#define BIST_CMD_GAP_V(x) ((x) << BIST_CMD_GAP_S)
    938
    939#define BIST_OPCODE_S    0
    940#define BIST_OPCODE_V(x) ((x) << BIST_OPCODE_S)
    941
    942#define MC_BIST_CMD_ADDR_A 0x7604
    943#define MC_BIST_CMD_LEN_A 0x7608
    944#define MC_BIST_DATA_PATTERN_A 0x760c
    945
    946#define MC_BIST_STATUS_RDATA_A 0x7688
    947
    948/* registers for module MA */
    949#define MA_EDRAM0_BAR_A 0x77c0
    950
    951#define EDRAM0_BASE_S    16
    952#define EDRAM0_BASE_M    0xfffU
    953#define EDRAM0_BASE_G(x) (((x) >> EDRAM0_BASE_S) & EDRAM0_BASE_M)
    954
    955#define EDRAM0_SIZE_S    0
    956#define EDRAM0_SIZE_M    0xfffU
    957#define EDRAM0_SIZE_V(x) ((x) << EDRAM0_SIZE_S)
    958#define EDRAM0_SIZE_G(x) (((x) >> EDRAM0_SIZE_S) & EDRAM0_SIZE_M)
    959
    960#define MA_EDRAM1_BAR_A 0x77c4
    961
    962#define EDRAM1_BASE_S    16
    963#define EDRAM1_BASE_M    0xfffU
    964#define EDRAM1_BASE_G(x) (((x) >> EDRAM1_BASE_S) & EDRAM1_BASE_M)
    965
    966#define EDRAM1_SIZE_S    0
    967#define EDRAM1_SIZE_M    0xfffU
    968#define EDRAM1_SIZE_V(x) ((x) << EDRAM1_SIZE_S)
    969#define EDRAM1_SIZE_G(x) (((x) >> EDRAM1_SIZE_S) & EDRAM1_SIZE_M)
    970
    971#define MA_EXT_MEMORY_BAR_A 0x77c8
    972
    973#define EXT_MEM_BASE_S    16
    974#define EXT_MEM_BASE_M    0xfffU
    975#define EXT_MEM_BASE_V(x) ((x) << EXT_MEM_BASE_S)
    976#define EXT_MEM_BASE_G(x) (((x) >> EXT_MEM_BASE_S) & EXT_MEM_BASE_M)
    977
    978#define EXT_MEM_SIZE_S    0
    979#define EXT_MEM_SIZE_M    0xfffU
    980#define EXT_MEM_SIZE_V(x) ((x) << EXT_MEM_SIZE_S)
    981#define EXT_MEM_SIZE_G(x) (((x) >> EXT_MEM_SIZE_S) & EXT_MEM_SIZE_M)
    982
    983#define MA_EXT_MEMORY1_BAR_A 0x7808
    984
    985#define HMA_MUX_S    5
    986#define HMA_MUX_V(x) ((x) << HMA_MUX_S)
    987#define HMA_MUX_F    HMA_MUX_V(1U)
    988
    989#define EXT_MEM1_BASE_S    16
    990#define EXT_MEM1_BASE_M    0xfffU
    991#define EXT_MEM1_BASE_G(x) (((x) >> EXT_MEM1_BASE_S) & EXT_MEM1_BASE_M)
    992
    993#define EXT_MEM1_SIZE_S    0
    994#define EXT_MEM1_SIZE_M    0xfffU
    995#define EXT_MEM1_SIZE_V(x) ((x) << EXT_MEM1_SIZE_S)
    996#define EXT_MEM1_SIZE_G(x) (((x) >> EXT_MEM1_SIZE_S) & EXT_MEM1_SIZE_M)
    997
    998#define MA_EXT_MEMORY0_BAR_A 0x77c8
    999
   1000#define EXT_MEM0_BASE_S    16
   1001#define EXT_MEM0_BASE_M    0xfffU
   1002#define EXT_MEM0_BASE_G(x) (((x) >> EXT_MEM0_BASE_S) & EXT_MEM0_BASE_M)
   1003
   1004#define EXT_MEM0_SIZE_S    0
   1005#define EXT_MEM0_SIZE_M    0xfffU
   1006#define EXT_MEM0_SIZE_V(x) ((x) << EXT_MEM0_SIZE_S)
   1007#define EXT_MEM0_SIZE_G(x) (((x) >> EXT_MEM0_SIZE_S) & EXT_MEM0_SIZE_M)
   1008
   1009#define MA_TARGET_MEM_ENABLE_A 0x77d8
   1010
   1011#define EXT_MEM_ENABLE_S    2
   1012#define EXT_MEM_ENABLE_V(x) ((x) << EXT_MEM_ENABLE_S)
   1013#define EXT_MEM_ENABLE_F    EXT_MEM_ENABLE_V(1U)
   1014
   1015#define EDRAM1_ENABLE_S    1
   1016#define EDRAM1_ENABLE_V(x) ((x) << EDRAM1_ENABLE_S)
   1017#define EDRAM1_ENABLE_F    EDRAM1_ENABLE_V(1U)
   1018
   1019#define EDRAM0_ENABLE_S    0
   1020#define EDRAM0_ENABLE_V(x) ((x) << EDRAM0_ENABLE_S)
   1021#define EDRAM0_ENABLE_F    EDRAM0_ENABLE_V(1U)
   1022
   1023#define EXT_MEM1_ENABLE_S    4
   1024#define EXT_MEM1_ENABLE_V(x) ((x) << EXT_MEM1_ENABLE_S)
   1025#define EXT_MEM1_ENABLE_F    EXT_MEM1_ENABLE_V(1U)
   1026
   1027#define EXT_MEM0_ENABLE_S    2
   1028#define EXT_MEM0_ENABLE_V(x) ((x) << EXT_MEM0_ENABLE_S)
   1029#define EXT_MEM0_ENABLE_F    EXT_MEM0_ENABLE_V(1U)
   1030
   1031#define MA_INT_CAUSE_A	0x77e0
   1032
   1033#define MEM_PERR_INT_CAUSE_S    1
   1034#define MEM_PERR_INT_CAUSE_V(x) ((x) << MEM_PERR_INT_CAUSE_S)
   1035#define MEM_PERR_INT_CAUSE_F    MEM_PERR_INT_CAUSE_V(1U)
   1036
   1037#define MEM_WRAP_INT_CAUSE_S    0
   1038#define MEM_WRAP_INT_CAUSE_V(x) ((x) << MEM_WRAP_INT_CAUSE_S)
   1039#define MEM_WRAP_INT_CAUSE_F    MEM_WRAP_INT_CAUSE_V(1U)
   1040
   1041#define MA_INT_WRAP_STATUS_A	0x77e4
   1042
   1043#define MEM_WRAP_ADDRESS_S    4
   1044#define MEM_WRAP_ADDRESS_M    0xfffffffU
   1045#define MEM_WRAP_ADDRESS_G(x) (((x) >> MEM_WRAP_ADDRESS_S) & MEM_WRAP_ADDRESS_M)
   1046
   1047#define MEM_WRAP_CLIENT_NUM_S    0
   1048#define MEM_WRAP_CLIENT_NUM_M    0xfU
   1049#define MEM_WRAP_CLIENT_NUM_G(x) \
   1050	(((x) >> MEM_WRAP_CLIENT_NUM_S) & MEM_WRAP_CLIENT_NUM_M)
   1051
   1052#define MA_PARITY_ERROR_STATUS_A	0x77f4
   1053#define MA_PARITY_ERROR_STATUS1_A	0x77f4
   1054#define MA_PARITY_ERROR_STATUS2_A	0x7804
   1055
   1056/* registers for module EDC_0 */
   1057#define EDC_0_BASE_ADDR		0x7900
   1058
   1059#define EDC_BIST_CMD_A		0x7904
   1060#define EDC_BIST_CMD_ADDR_A	0x7908
   1061#define EDC_BIST_CMD_LEN_A	0x790c
   1062#define EDC_BIST_DATA_PATTERN_A 0x7910
   1063#define EDC_BIST_STATUS_RDATA_A	0x7928
   1064#define EDC_INT_CAUSE_A		0x7978
   1065
   1066#define ECC_UE_PAR_S    5
   1067#define ECC_UE_PAR_V(x) ((x) << ECC_UE_PAR_S)
   1068#define ECC_UE_PAR_F    ECC_UE_PAR_V(1U)
   1069
   1070#define ECC_CE_PAR_S    4
   1071#define ECC_CE_PAR_V(x) ((x) << ECC_CE_PAR_S)
   1072#define ECC_CE_PAR_F    ECC_CE_PAR_V(1U)
   1073
   1074#define PERR_PAR_CAUSE_S    3
   1075#define PERR_PAR_CAUSE_V(x) ((x) << PERR_PAR_CAUSE_S)
   1076#define PERR_PAR_CAUSE_F    PERR_PAR_CAUSE_V(1U)
   1077
   1078#define EDC_ECC_STATUS_A	0x797c
   1079
   1080/* registers for module EDC_1 */
   1081#define EDC_1_BASE_ADDR	0x7980
   1082
   1083/* registers for module CIM */
   1084#define CIM_BOOT_CFG_A 0x7b00
   1085#define CIM_SDRAM_BASE_ADDR_A 0x7b14
   1086#define CIM_SDRAM_ADDR_SIZE_A 0x7b18
   1087#define CIM_EXTMEM2_BASE_ADDR_A 0x7b1c
   1088#define CIM_EXTMEM2_ADDR_SIZE_A 0x7b20
   1089#define CIM_PF_MAILBOX_CTRL_SHADOW_COPY_A 0x290
   1090
   1091#define  BOOTADDR_M	0xffffff00U
   1092
   1093#define UPCRST_S    0
   1094#define UPCRST_V(x) ((x) << UPCRST_S)
   1095#define UPCRST_F    UPCRST_V(1U)
   1096
   1097#define CIM_PF_MAILBOX_DATA_A 0x240
   1098#define CIM_PF_MAILBOX_CTRL_A 0x280
   1099
   1100#define MBMSGVALID_S    3
   1101#define MBMSGVALID_V(x) ((x) << MBMSGVALID_S)
   1102#define MBMSGVALID_F    MBMSGVALID_V(1U)
   1103
   1104#define MBINTREQ_S    2
   1105#define MBINTREQ_V(x) ((x) << MBINTREQ_S)
   1106#define MBINTREQ_F    MBINTREQ_V(1U)
   1107
   1108#define MBOWNER_S    0
   1109#define MBOWNER_M    0x3U
   1110#define MBOWNER_V(x) ((x) << MBOWNER_S)
   1111#define MBOWNER_G(x) (((x) >> MBOWNER_S) & MBOWNER_M)
   1112
   1113#define CIM_PF_HOST_INT_ENABLE_A 0x288
   1114
   1115#define MBMSGRDYINTEN_S    19
   1116#define MBMSGRDYINTEN_V(x) ((x) << MBMSGRDYINTEN_S)
   1117#define MBMSGRDYINTEN_F    MBMSGRDYINTEN_V(1U)
   1118
   1119#define CIM_PF_HOST_INT_CAUSE_A 0x28c
   1120
   1121#define MBMSGRDYINT_S    19
   1122#define MBMSGRDYINT_V(x) ((x) << MBMSGRDYINT_S)
   1123#define MBMSGRDYINT_F    MBMSGRDYINT_V(1U)
   1124
   1125#define CIM_HOST_INT_CAUSE_A 0x7b2c
   1126
   1127#define TIEQOUTPARERRINT_S    20
   1128#define TIEQOUTPARERRINT_V(x) ((x) << TIEQOUTPARERRINT_S)
   1129#define TIEQOUTPARERRINT_F    TIEQOUTPARERRINT_V(1U)
   1130
   1131#define TIEQINPARERRINT_S    19
   1132#define TIEQINPARERRINT_V(x) ((x) << TIEQINPARERRINT_S)
   1133#define TIEQINPARERRINT_F    TIEQINPARERRINT_V(1U)
   1134
   1135#define TIMER0INT_S    2
   1136#define TIMER0INT_V(x) ((x) << TIMER0INT_S)
   1137#define TIMER0INT_F    TIMER0INT_V(1U)
   1138
   1139#define PREFDROPINT_S    1
   1140#define PREFDROPINT_V(x) ((x) << PREFDROPINT_S)
   1141#define PREFDROPINT_F    PREFDROPINT_V(1U)
   1142
   1143#define UPACCNONZERO_S    0
   1144#define UPACCNONZERO_V(x) ((x) << UPACCNONZERO_S)
   1145#define UPACCNONZERO_F    UPACCNONZERO_V(1U)
   1146
   1147#define MBHOSTPARERR_S    18
   1148#define MBHOSTPARERR_V(x) ((x) << MBHOSTPARERR_S)
   1149#define MBHOSTPARERR_F    MBHOSTPARERR_V(1U)
   1150
   1151#define MBUPPARERR_S    17
   1152#define MBUPPARERR_V(x) ((x) << MBUPPARERR_S)
   1153#define MBUPPARERR_F    MBUPPARERR_V(1U)
   1154
   1155#define IBQTP0PARERR_S    16
   1156#define IBQTP0PARERR_V(x) ((x) << IBQTP0PARERR_S)
   1157#define IBQTP0PARERR_F    IBQTP0PARERR_V(1U)
   1158
   1159#define IBQTP1PARERR_S    15
   1160#define IBQTP1PARERR_V(x) ((x) << IBQTP1PARERR_S)
   1161#define IBQTP1PARERR_F    IBQTP1PARERR_V(1U)
   1162
   1163#define IBQULPPARERR_S    14
   1164#define IBQULPPARERR_V(x) ((x) << IBQULPPARERR_S)
   1165#define IBQULPPARERR_F    IBQULPPARERR_V(1U)
   1166
   1167#define IBQSGELOPARERR_S    13
   1168#define IBQSGELOPARERR_V(x) ((x) << IBQSGELOPARERR_S)
   1169#define IBQSGELOPARERR_F    IBQSGELOPARERR_V(1U)
   1170
   1171#define IBQSGEHIPARERR_S    12
   1172#define IBQSGEHIPARERR_V(x) ((x) << IBQSGEHIPARERR_S)
   1173#define IBQSGEHIPARERR_F    IBQSGEHIPARERR_V(1U)
   1174
   1175#define IBQNCSIPARERR_S    11
   1176#define IBQNCSIPARERR_V(x) ((x) << IBQNCSIPARERR_S)
   1177#define IBQNCSIPARERR_F    IBQNCSIPARERR_V(1U)
   1178
   1179#define OBQULP0PARERR_S    10
   1180#define OBQULP0PARERR_V(x) ((x) << OBQULP0PARERR_S)
   1181#define OBQULP0PARERR_F    OBQULP0PARERR_V(1U)
   1182
   1183#define OBQULP1PARERR_S    9
   1184#define OBQULP1PARERR_V(x) ((x) << OBQULP1PARERR_S)
   1185#define OBQULP1PARERR_F    OBQULP1PARERR_V(1U)
   1186
   1187#define OBQULP2PARERR_S    8
   1188#define OBQULP2PARERR_V(x) ((x) << OBQULP2PARERR_S)
   1189#define OBQULP2PARERR_F    OBQULP2PARERR_V(1U)
   1190
   1191#define OBQULP3PARERR_S    7
   1192#define OBQULP3PARERR_V(x) ((x) << OBQULP3PARERR_S)
   1193#define OBQULP3PARERR_F    OBQULP3PARERR_V(1U)
   1194
   1195#define OBQSGEPARERR_S    6
   1196#define OBQSGEPARERR_V(x) ((x) << OBQSGEPARERR_S)
   1197#define OBQSGEPARERR_F    OBQSGEPARERR_V(1U)
   1198
   1199#define OBQNCSIPARERR_S    5
   1200#define OBQNCSIPARERR_V(x) ((x) << OBQNCSIPARERR_S)
   1201#define OBQNCSIPARERR_F    OBQNCSIPARERR_V(1U)
   1202
   1203#define CIM_HOST_UPACC_INT_CAUSE_A 0x7b34
   1204
   1205#define EEPROMWRINT_S    30
   1206#define EEPROMWRINT_V(x) ((x) << EEPROMWRINT_S)
   1207#define EEPROMWRINT_F    EEPROMWRINT_V(1U)
   1208
   1209#define TIMEOUTMAINT_S    29
   1210#define TIMEOUTMAINT_V(x) ((x) << TIMEOUTMAINT_S)
   1211#define TIMEOUTMAINT_F    TIMEOUTMAINT_V(1U)
   1212
   1213#define TIMEOUTINT_S    28
   1214#define TIMEOUTINT_V(x) ((x) << TIMEOUTINT_S)
   1215#define TIMEOUTINT_F    TIMEOUTINT_V(1U)
   1216
   1217#define RSPOVRLOOKUPINT_S    27
   1218#define RSPOVRLOOKUPINT_V(x) ((x) << RSPOVRLOOKUPINT_S)
   1219#define RSPOVRLOOKUPINT_F    RSPOVRLOOKUPINT_V(1U)
   1220
   1221#define REQOVRLOOKUPINT_S    26
   1222#define REQOVRLOOKUPINT_V(x) ((x) << REQOVRLOOKUPINT_S)
   1223#define REQOVRLOOKUPINT_F    REQOVRLOOKUPINT_V(1U)
   1224
   1225#define BLKWRPLINT_S    25
   1226#define BLKWRPLINT_V(x) ((x) << BLKWRPLINT_S)
   1227#define BLKWRPLINT_F    BLKWRPLINT_V(1U)
   1228
   1229#define BLKRDPLINT_S    24
   1230#define BLKRDPLINT_V(x) ((x) << BLKRDPLINT_S)
   1231#define BLKRDPLINT_F    BLKRDPLINT_V(1U)
   1232
   1233#define SGLWRPLINT_S    23
   1234#define SGLWRPLINT_V(x) ((x) << SGLWRPLINT_S)
   1235#define SGLWRPLINT_F    SGLWRPLINT_V(1U)
   1236
   1237#define SGLRDPLINT_S    22
   1238#define SGLRDPLINT_V(x) ((x) << SGLRDPLINT_S)
   1239#define SGLRDPLINT_F    SGLRDPLINT_V(1U)
   1240
   1241#define BLKWRCTLINT_S    21
   1242#define BLKWRCTLINT_V(x) ((x) << BLKWRCTLINT_S)
   1243#define BLKWRCTLINT_F    BLKWRCTLINT_V(1U)
   1244
   1245#define BLKRDCTLINT_S    20
   1246#define BLKRDCTLINT_V(x) ((x) << BLKRDCTLINT_S)
   1247#define BLKRDCTLINT_F    BLKRDCTLINT_V(1U)
   1248
   1249#define SGLWRCTLINT_S    19
   1250#define SGLWRCTLINT_V(x) ((x) << SGLWRCTLINT_S)
   1251#define SGLWRCTLINT_F    SGLWRCTLINT_V(1U)
   1252
   1253#define SGLRDCTLINT_S    18
   1254#define SGLRDCTLINT_V(x) ((x) << SGLRDCTLINT_S)
   1255#define SGLRDCTLINT_F    SGLRDCTLINT_V(1U)
   1256
   1257#define BLKWREEPROMINT_S    17
   1258#define BLKWREEPROMINT_V(x) ((x) << BLKWREEPROMINT_S)
   1259#define BLKWREEPROMINT_F    BLKWREEPROMINT_V(1U)
   1260
   1261#define BLKRDEEPROMINT_S    16
   1262#define BLKRDEEPROMINT_V(x) ((x) << BLKRDEEPROMINT_S)
   1263#define BLKRDEEPROMINT_F    BLKRDEEPROMINT_V(1U)
   1264
   1265#define SGLWREEPROMINT_S    15
   1266#define SGLWREEPROMINT_V(x) ((x) << SGLWREEPROMINT_S)
   1267#define SGLWREEPROMINT_F    SGLWREEPROMINT_V(1U)
   1268
   1269#define SGLRDEEPROMINT_S    14
   1270#define SGLRDEEPROMINT_V(x) ((x) << SGLRDEEPROMINT_S)
   1271#define SGLRDEEPROMINT_F    SGLRDEEPROMINT_V(1U)
   1272
   1273#define BLKWRFLASHINT_S    13
   1274#define BLKWRFLASHINT_V(x) ((x) << BLKWRFLASHINT_S)
   1275#define BLKWRFLASHINT_F    BLKWRFLASHINT_V(1U)
   1276
   1277#define BLKRDFLASHINT_S    12
   1278#define BLKRDFLASHINT_V(x) ((x) << BLKRDFLASHINT_S)
   1279#define BLKRDFLASHINT_F    BLKRDFLASHINT_V(1U)
   1280
   1281#define SGLWRFLASHINT_S    11
   1282#define SGLWRFLASHINT_V(x) ((x) << SGLWRFLASHINT_S)
   1283#define SGLWRFLASHINT_F    SGLWRFLASHINT_V(1U)
   1284
   1285#define SGLRDFLASHINT_S    10
   1286#define SGLRDFLASHINT_V(x) ((x) << SGLRDFLASHINT_S)
   1287#define SGLRDFLASHINT_F    SGLRDFLASHINT_V(1U)
   1288
   1289#define BLKWRBOOTINT_S    9
   1290#define BLKWRBOOTINT_V(x) ((x) << BLKWRBOOTINT_S)
   1291#define BLKWRBOOTINT_F    BLKWRBOOTINT_V(1U)
   1292
   1293#define BLKRDBOOTINT_S    8
   1294#define BLKRDBOOTINT_V(x) ((x) << BLKRDBOOTINT_S)
   1295#define BLKRDBOOTINT_F    BLKRDBOOTINT_V(1U)
   1296
   1297#define SGLWRBOOTINT_S    7
   1298#define SGLWRBOOTINT_V(x) ((x) << SGLWRBOOTINT_S)
   1299#define SGLWRBOOTINT_F    SGLWRBOOTINT_V(1U)
   1300
   1301#define SGLRDBOOTINT_S    6
   1302#define SGLRDBOOTINT_V(x) ((x) << SGLRDBOOTINT_S)
   1303#define SGLRDBOOTINT_F    SGLRDBOOTINT_V(1U)
   1304
   1305#define ILLWRBEINT_S    5
   1306#define ILLWRBEINT_V(x) ((x) << ILLWRBEINT_S)
   1307#define ILLWRBEINT_F    ILLWRBEINT_V(1U)
   1308
   1309#define ILLRDBEINT_S    4
   1310#define ILLRDBEINT_V(x) ((x) << ILLRDBEINT_S)
   1311#define ILLRDBEINT_F    ILLRDBEINT_V(1U)
   1312
   1313#define ILLRDINT_S    3
   1314#define ILLRDINT_V(x) ((x) << ILLRDINT_S)
   1315#define ILLRDINT_F    ILLRDINT_V(1U)
   1316
   1317#define ILLWRINT_S    2
   1318#define ILLWRINT_V(x) ((x) << ILLWRINT_S)
   1319#define ILLWRINT_F    ILLWRINT_V(1U)
   1320
   1321#define ILLTRANSINT_S    1
   1322#define ILLTRANSINT_V(x) ((x) << ILLTRANSINT_S)
   1323#define ILLTRANSINT_F    ILLTRANSINT_V(1U)
   1324
   1325#define RSVDSPACEINT_S    0
   1326#define RSVDSPACEINT_V(x) ((x) << RSVDSPACEINT_S)
   1327#define RSVDSPACEINT_F    RSVDSPACEINT_V(1U)
   1328
   1329/* registers for module TP */
   1330#define DBGLAWHLF_S    23
   1331#define DBGLAWHLF_V(x) ((x) << DBGLAWHLF_S)
   1332#define DBGLAWHLF_F    DBGLAWHLF_V(1U)
   1333
   1334#define DBGLAWPTR_S    16
   1335#define DBGLAWPTR_M    0x7fU
   1336#define DBGLAWPTR_G(x) (((x) >> DBGLAWPTR_S) & DBGLAWPTR_M)
   1337
   1338#define DBGLAENABLE_S    12
   1339#define DBGLAENABLE_V(x) ((x) << DBGLAENABLE_S)
   1340#define DBGLAENABLE_F    DBGLAENABLE_V(1U)
   1341
   1342#define DBGLARPTR_S    0
   1343#define DBGLARPTR_M    0x7fU
   1344#define DBGLARPTR_V(x) ((x) << DBGLARPTR_S)
   1345
   1346#define CRXPKTENC_S    3
   1347#define CRXPKTENC_V(x) ((x) << CRXPKTENC_S)
   1348#define CRXPKTENC_F    CRXPKTENC_V(1U)
   1349
   1350#define TP_DBG_LA_DATAL_A	0x7ed8
   1351#define TP_DBG_LA_CONFIG_A	0x7ed4
   1352#define TP_OUT_CONFIG_A		0x7d04
   1353#define TP_GLOBAL_CONFIG_A	0x7d08
   1354
   1355#define ACTIVEFILTERCOUNTS_S    22
   1356#define ACTIVEFILTERCOUNTS_V(x) ((x) << ACTIVEFILTERCOUNTS_S)
   1357#define ACTIVEFILTERCOUNTS_F    ACTIVEFILTERCOUNTS_V(1U)
   1358
   1359#define TP_CMM_TCB_BASE_A 0x7d10
   1360#define TP_CMM_MM_BASE_A 0x7d14
   1361#define TP_CMM_TIMER_BASE_A 0x7d18
   1362#define TP_PMM_TX_BASE_A 0x7d20
   1363#define TP_PMM_RX_BASE_A 0x7d28
   1364#define TP_PMM_RX_PAGE_SIZE_A 0x7d2c
   1365#define TP_PMM_RX_MAX_PAGE_A 0x7d30
   1366#define TP_PMM_TX_PAGE_SIZE_A 0x7d34
   1367#define TP_PMM_TX_MAX_PAGE_A 0x7d38
   1368#define TP_CMM_MM_MAX_PSTRUCT_A 0x7e6c
   1369
   1370#define PMRXNUMCHN_S    31
   1371#define PMRXNUMCHN_V(x) ((x) << PMRXNUMCHN_S)
   1372#define PMRXNUMCHN_F    PMRXNUMCHN_V(1U)
   1373
   1374#define PMTXNUMCHN_S    30
   1375#define PMTXNUMCHN_M    0x3U
   1376#define PMTXNUMCHN_G(x) (((x) >> PMTXNUMCHN_S) & PMTXNUMCHN_M)
   1377
   1378#define PMTXMAXPAGE_S    0
   1379#define PMTXMAXPAGE_M    0x1fffffU
   1380#define PMTXMAXPAGE_G(x) (((x) >> PMTXMAXPAGE_S) & PMTXMAXPAGE_M)
   1381
   1382#define PMRXMAXPAGE_S    0
   1383#define PMRXMAXPAGE_M    0x1fffffU
   1384#define PMRXMAXPAGE_G(x) (((x) >> PMRXMAXPAGE_S) & PMRXMAXPAGE_M)
   1385
   1386#define DBGLAMODE_S	14
   1387#define DBGLAMODE_M	0x3U
   1388#define DBGLAMODE_G(x)	(((x) >> DBGLAMODE_S) & DBGLAMODE_M)
   1389
   1390#define FIVETUPLELOOKUP_S    17
   1391#define FIVETUPLELOOKUP_M    0x3U
   1392#define FIVETUPLELOOKUP_V(x) ((x) << FIVETUPLELOOKUP_S)
   1393#define FIVETUPLELOOKUP_G(x) (((x) >> FIVETUPLELOOKUP_S) & FIVETUPLELOOKUP_M)
   1394
   1395#define TP_PARA_REG2_A 0x7d68
   1396
   1397#define MAXRXDATA_S    16
   1398#define MAXRXDATA_M    0xffffU
   1399#define MAXRXDATA_G(x) (((x) >> MAXRXDATA_S) & MAXRXDATA_M)
   1400
   1401#define TP_TIMER_RESOLUTION_A 0x7d90
   1402
   1403#define TIMERRESOLUTION_S    16
   1404#define TIMERRESOLUTION_M    0xffU
   1405#define TIMERRESOLUTION_G(x) (((x) >> TIMERRESOLUTION_S) & TIMERRESOLUTION_M)
   1406
   1407#define TIMESTAMPRESOLUTION_S    8
   1408#define TIMESTAMPRESOLUTION_M    0xffU
   1409#define TIMESTAMPRESOLUTION_G(x) \
   1410	(((x) >> TIMESTAMPRESOLUTION_S) & TIMESTAMPRESOLUTION_M)
   1411
   1412#define DELAYEDACKRESOLUTION_S    0
   1413#define DELAYEDACKRESOLUTION_M    0xffU
   1414#define DELAYEDACKRESOLUTION_G(x) \
   1415	(((x) >> DELAYEDACKRESOLUTION_S) & DELAYEDACKRESOLUTION_M)
   1416
   1417#define TP_SHIFT_CNT_A 0x7dc0
   1418#define TP_RXT_MIN_A 0x7d98
   1419#define TP_RXT_MAX_A 0x7d9c
   1420#define TP_PERS_MIN_A 0x7da0
   1421#define TP_PERS_MAX_A 0x7da4
   1422#define TP_KEEP_IDLE_A 0x7da8
   1423#define TP_KEEP_INTVL_A 0x7dac
   1424#define TP_INIT_SRTT_A 0x7db0
   1425#define TP_DACK_TIMER_A 0x7db4
   1426#define TP_FINWAIT2_TIMER_A 0x7db8
   1427
   1428#define INITSRTT_S    0
   1429#define INITSRTT_M    0xffffU
   1430#define INITSRTT_G(x) (((x) >> INITSRTT_S) & INITSRTT_M)
   1431
   1432#define PERSMAX_S    0
   1433#define PERSMAX_M    0x3fffffffU
   1434#define PERSMAX_V(x) ((x) << PERSMAX_S)
   1435#define PERSMAX_G(x) (((x) >> PERSMAX_S) & PERSMAX_M)
   1436
   1437#define SYNSHIFTMAX_S    24
   1438#define SYNSHIFTMAX_M    0xffU
   1439#define SYNSHIFTMAX_V(x) ((x) << SYNSHIFTMAX_S)
   1440#define SYNSHIFTMAX_G(x) (((x) >> SYNSHIFTMAX_S) & SYNSHIFTMAX_M)
   1441
   1442#define RXTSHIFTMAXR1_S    20
   1443#define RXTSHIFTMAXR1_M    0xfU
   1444#define RXTSHIFTMAXR1_V(x) ((x) << RXTSHIFTMAXR1_S)
   1445#define RXTSHIFTMAXR1_G(x) (((x) >> RXTSHIFTMAXR1_S) & RXTSHIFTMAXR1_M)
   1446
   1447#define RXTSHIFTMAXR2_S    16
   1448#define RXTSHIFTMAXR2_M    0xfU
   1449#define RXTSHIFTMAXR2_V(x) ((x) << RXTSHIFTMAXR2_S)
   1450#define RXTSHIFTMAXR2_G(x) (((x) >> RXTSHIFTMAXR2_S) & RXTSHIFTMAXR2_M)
   1451
   1452#define PERSHIFTBACKOFFMAX_S    12
   1453#define PERSHIFTBACKOFFMAX_M    0xfU
   1454#define PERSHIFTBACKOFFMAX_V(x) ((x) << PERSHIFTBACKOFFMAX_S)
   1455#define PERSHIFTBACKOFFMAX_G(x) \
   1456	(((x) >> PERSHIFTBACKOFFMAX_S) & PERSHIFTBACKOFFMAX_M)
   1457
   1458#define PERSHIFTMAX_S    8
   1459#define PERSHIFTMAX_M    0xfU
   1460#define PERSHIFTMAX_V(x) ((x) << PERSHIFTMAX_S)
   1461#define PERSHIFTMAX_G(x) (((x) >> PERSHIFTMAX_S) & PERSHIFTMAX_M)
   1462
   1463#define KEEPALIVEMAXR1_S    4
   1464#define KEEPALIVEMAXR1_M    0xfU
   1465#define KEEPALIVEMAXR1_V(x) ((x) << KEEPALIVEMAXR1_S)
   1466#define KEEPALIVEMAXR1_G(x) (((x) >> KEEPALIVEMAXR1_S) & KEEPALIVEMAXR1_M)
   1467
   1468#define KEEPALIVEMAXR2_S    0
   1469#define KEEPALIVEMAXR2_M    0xfU
   1470#define KEEPALIVEMAXR2_V(x) ((x) << KEEPALIVEMAXR2_S)
   1471#define KEEPALIVEMAXR2_G(x) (((x) >> KEEPALIVEMAXR2_S) & KEEPALIVEMAXR2_M)
   1472
   1473#define ROWINDEX_S    16
   1474#define ROWINDEX_V(x) ((x) << ROWINDEX_S)
   1475
   1476#define TP_CCTRL_TABLE_A	0x7ddc
   1477#define TP_PACE_TABLE_A 0x7dd8
   1478#define TP_MTU_TABLE_A		0x7de4
   1479
   1480#define MTUINDEX_S    24
   1481#define MTUINDEX_V(x) ((x) << MTUINDEX_S)
   1482
   1483#define MTUWIDTH_S    16
   1484#define MTUWIDTH_M    0xfU
   1485#define MTUWIDTH_V(x) ((x) << MTUWIDTH_S)
   1486#define MTUWIDTH_G(x) (((x) >> MTUWIDTH_S) & MTUWIDTH_M)
   1487
   1488#define MTUVALUE_S    0
   1489#define MTUVALUE_M    0x3fffU
   1490#define MTUVALUE_V(x) ((x) << MTUVALUE_S)
   1491#define MTUVALUE_G(x) (((x) >> MTUVALUE_S) & MTUVALUE_M)
   1492
   1493#define TP_RSS_LKP_TABLE_A	0x7dec
   1494#define TP_CMM_MM_RX_FLST_BASE_A 0x7e60
   1495#define TP_CMM_MM_TX_FLST_BASE_A 0x7e64
   1496#define TP_CMM_MM_PS_FLST_BASE_A 0x7e68
   1497
   1498#define LKPTBLROWVLD_S    31
   1499#define LKPTBLROWVLD_V(x) ((x) << LKPTBLROWVLD_S)
   1500#define LKPTBLROWVLD_F    LKPTBLROWVLD_V(1U)
   1501
   1502#define LKPTBLQUEUE1_S    10
   1503#define LKPTBLQUEUE1_M    0x3ffU
   1504#define LKPTBLQUEUE1_G(x) (((x) >> LKPTBLQUEUE1_S) & LKPTBLQUEUE1_M)
   1505
   1506#define LKPTBLQUEUE0_S    0
   1507#define LKPTBLQUEUE0_M    0x3ffU
   1508#define LKPTBLQUEUE0_G(x) (((x) >> LKPTBLQUEUE0_S) & LKPTBLQUEUE0_M)
   1509
   1510#define TP_TM_PIO_ADDR_A 0x7e18
   1511#define TP_TM_PIO_DATA_A 0x7e1c
   1512#define TP_MOD_CONFIG_A 0x7e24
   1513
   1514#define TIMERMODE_S    8
   1515#define TIMERMODE_M    0xffU
   1516#define TIMERMODE_G(x) (((x) >> TIMERMODE_S) & TIMERMODE_M)
   1517
   1518#define TP_TX_MOD_Q1_Q0_TIMER_SEPARATOR_A 0x3
   1519#define TP_TX_MOD_Q1_Q0_RATE_LIMIT_A 0x8
   1520
   1521#define TP_PIO_ADDR_A	0x7e40
   1522#define TP_PIO_DATA_A	0x7e44
   1523#define TP_MIB_INDEX_A	0x7e50
   1524#define TP_MIB_DATA_A	0x7e54
   1525#define TP_INT_CAUSE_A	0x7e74
   1526
   1527#define TP_FLM_FREE_PS_CNT_A 0x7e80
   1528#define TP_FLM_FREE_RX_CNT_A 0x7e84
   1529
   1530#define FREEPSTRUCTCOUNT_S    0
   1531#define FREEPSTRUCTCOUNT_M    0x1fffffU
   1532#define FREEPSTRUCTCOUNT_G(x) (((x) >> FREEPSTRUCTCOUNT_S) & FREEPSTRUCTCOUNT_M)
   1533
   1534#define FREERXPAGECOUNT_S    0
   1535#define FREERXPAGECOUNT_M    0x1fffffU
   1536#define FREERXPAGECOUNT_V(x) ((x) << FREERXPAGECOUNT_S)
   1537#define FREERXPAGECOUNT_G(x) (((x) >> FREERXPAGECOUNT_S) & FREERXPAGECOUNT_M)
   1538
   1539#define TP_FLM_FREE_TX_CNT_A 0x7e88
   1540
   1541#define FREETXPAGECOUNT_S    0
   1542#define FREETXPAGECOUNT_M    0x1fffffU
   1543#define FREETXPAGECOUNT_V(x) ((x) << FREETXPAGECOUNT_S)
   1544#define FREETXPAGECOUNT_G(x) (((x) >> FREETXPAGECOUNT_S) & FREETXPAGECOUNT_M)
   1545
   1546#define FLMTXFLSTEMPTY_S    30
   1547#define FLMTXFLSTEMPTY_V(x) ((x) << FLMTXFLSTEMPTY_S)
   1548#define FLMTXFLSTEMPTY_F    FLMTXFLSTEMPTY_V(1U)
   1549
   1550#define TP_TX_ORATE_A 0x7ebc
   1551
   1552#define OFDRATE3_S    24
   1553#define OFDRATE3_M    0xffU
   1554#define OFDRATE3_G(x) (((x) >> OFDRATE3_S) & OFDRATE3_M)
   1555
   1556#define OFDRATE2_S    16
   1557#define OFDRATE2_M    0xffU
   1558#define OFDRATE2_G(x) (((x) >> OFDRATE2_S) & OFDRATE2_M)
   1559
   1560#define OFDRATE1_S    8
   1561#define OFDRATE1_M    0xffU
   1562#define OFDRATE1_G(x) (((x) >> OFDRATE1_S) & OFDRATE1_M)
   1563
   1564#define OFDRATE0_S    0
   1565#define OFDRATE0_M    0xffU
   1566#define OFDRATE0_G(x) (((x) >> OFDRATE0_S) & OFDRATE0_M)
   1567
   1568#define TP_TX_TRATE_A 0x7ed0
   1569
   1570#define TNLRATE3_S    24
   1571#define TNLRATE3_M    0xffU
   1572#define TNLRATE3_G(x) (((x) >> TNLRATE3_S) & TNLRATE3_M)
   1573
   1574#define TNLRATE2_S    16
   1575#define TNLRATE2_M    0xffU
   1576#define TNLRATE2_G(x) (((x) >> TNLRATE2_S) & TNLRATE2_M)
   1577
   1578#define TNLRATE1_S    8
   1579#define TNLRATE1_M    0xffU
   1580#define TNLRATE1_G(x) (((x) >> TNLRATE1_S) & TNLRATE1_M)
   1581
   1582#define TNLRATE0_S    0
   1583#define TNLRATE0_M    0xffU
   1584#define TNLRATE0_G(x) (((x) >> TNLRATE0_S) & TNLRATE0_M)
   1585
   1586#define TP_VLAN_PRI_MAP_A 0x140
   1587
   1588#define FRAGMENTATION_S    9
   1589#define FRAGMENTATION_V(x) ((x) << FRAGMENTATION_S)
   1590#define FRAGMENTATION_F    FRAGMENTATION_V(1U)
   1591
   1592#define MPSHITTYPE_S    8
   1593#define MPSHITTYPE_V(x) ((x) << MPSHITTYPE_S)
   1594#define MPSHITTYPE_F    MPSHITTYPE_V(1U)
   1595
   1596#define MACMATCH_S    7
   1597#define MACMATCH_V(x) ((x) << MACMATCH_S)
   1598#define MACMATCH_F    MACMATCH_V(1U)
   1599
   1600#define ETHERTYPE_S    6
   1601#define ETHERTYPE_V(x) ((x) << ETHERTYPE_S)
   1602#define ETHERTYPE_F    ETHERTYPE_V(1U)
   1603
   1604#define PROTOCOL_S    5
   1605#define PROTOCOL_V(x) ((x) << PROTOCOL_S)
   1606#define PROTOCOL_F    PROTOCOL_V(1U)
   1607
   1608#define TOS_S    4
   1609#define TOS_V(x) ((x) << TOS_S)
   1610#define TOS_F    TOS_V(1U)
   1611
   1612#define VLAN_S    3
   1613#define VLAN_V(x) ((x) << VLAN_S)
   1614#define VLAN_F    VLAN_V(1U)
   1615
   1616#define VNIC_ID_S    2
   1617#define VNIC_ID_V(x) ((x) << VNIC_ID_S)
   1618#define VNIC_ID_F    VNIC_ID_V(1U)
   1619
   1620#define PORT_S    1
   1621#define PORT_V(x) ((x) << PORT_S)
   1622#define PORT_F    PORT_V(1U)
   1623
   1624#define FCOE_S    0
   1625#define FCOE_V(x) ((x) << FCOE_S)
   1626#define FCOE_F    FCOE_V(1U)
   1627
   1628#define FILTERMODE_S    15
   1629#define FILTERMODE_V(x) ((x) << FILTERMODE_S)
   1630#define FILTERMODE_F    FILTERMODE_V(1U)
   1631
   1632#define FCOEMASK_S    14
   1633#define FCOEMASK_V(x) ((x) << FCOEMASK_S)
   1634#define FCOEMASK_F    FCOEMASK_V(1U)
   1635
   1636#define TP_INGRESS_CONFIG_A	0x141
   1637
   1638#define VNIC_S    11
   1639#define VNIC_V(x) ((x) << VNIC_S)
   1640#define VNIC_F    VNIC_V(1U)
   1641
   1642#define USE_ENC_IDX_S		13
   1643#define USE_ENC_IDX_V(x)	((x) << USE_ENC_IDX_S)
   1644#define USE_ENC_IDX_F		USE_ENC_IDX_V(1U)
   1645
   1646#define CSUM_HAS_PSEUDO_HDR_S    10
   1647#define CSUM_HAS_PSEUDO_HDR_V(x) ((x) << CSUM_HAS_PSEUDO_HDR_S)
   1648#define CSUM_HAS_PSEUDO_HDR_F    CSUM_HAS_PSEUDO_HDR_V(1U)
   1649
   1650#define TP_MIB_MAC_IN_ERR_0_A	0x0
   1651#define TP_MIB_HDR_IN_ERR_0_A	0x4
   1652#define TP_MIB_TCP_IN_ERR_0_A	0x8
   1653#define TP_MIB_TCP_OUT_RST_A	0xc
   1654#define TP_MIB_TCP_IN_SEG_HI_A	0x10
   1655#define TP_MIB_TCP_IN_SEG_LO_A	0x11
   1656#define TP_MIB_TCP_OUT_SEG_HI_A	0x12
   1657#define TP_MIB_TCP_OUT_SEG_LO_A 0x13
   1658#define TP_MIB_TCP_RXT_SEG_HI_A	0x14
   1659#define TP_MIB_TCP_RXT_SEG_LO_A	0x15
   1660#define TP_MIB_TNL_CNG_DROP_0_A 0x18
   1661#define TP_MIB_OFD_CHN_DROP_0_A 0x1c
   1662#define TP_MIB_TCP_V6IN_ERR_0_A 0x28
   1663#define TP_MIB_TCP_V6OUT_RST_A	0x2c
   1664#define TP_MIB_OFD_ARP_DROP_A	0x36
   1665#define TP_MIB_CPL_IN_REQ_0_A	0x38
   1666#define TP_MIB_CPL_OUT_RSP_0_A	0x3c
   1667#define TP_MIB_TNL_DROP_0_A	0x44
   1668#define TP_MIB_FCOE_DDP_0_A	0x48
   1669#define TP_MIB_FCOE_DROP_0_A	0x4c
   1670#define TP_MIB_FCOE_BYTE_0_HI_A	0x50
   1671#define TP_MIB_OFD_VLN_DROP_0_A	0x58
   1672#define TP_MIB_USM_PKTS_A	0x5c
   1673#define TP_MIB_RQE_DFR_PKT_A	0x64
   1674
   1675#define ULP_TX_INT_CAUSE_A	0x8dcc
   1676#define ULP_TX_TPT_LLIMIT_A	0x8dd4
   1677#define ULP_TX_TPT_ULIMIT_A	0x8dd8
   1678#define ULP_TX_PBL_LLIMIT_A	0x8ddc
   1679#define ULP_TX_PBL_ULIMIT_A	0x8de0
   1680#define ULP_TX_ERR_TABLE_BASE_A 0x8e04
   1681
   1682#define PBL_BOUND_ERR_CH3_S    31
   1683#define PBL_BOUND_ERR_CH3_V(x) ((x) << PBL_BOUND_ERR_CH3_S)
   1684#define PBL_BOUND_ERR_CH3_F    PBL_BOUND_ERR_CH3_V(1U)
   1685
   1686#define PBL_BOUND_ERR_CH2_S    30
   1687#define PBL_BOUND_ERR_CH2_V(x) ((x) << PBL_BOUND_ERR_CH2_S)
   1688#define PBL_BOUND_ERR_CH2_F    PBL_BOUND_ERR_CH2_V(1U)
   1689
   1690#define PBL_BOUND_ERR_CH1_S    29
   1691#define PBL_BOUND_ERR_CH1_V(x) ((x) << PBL_BOUND_ERR_CH1_S)
   1692#define PBL_BOUND_ERR_CH1_F    PBL_BOUND_ERR_CH1_V(1U)
   1693
   1694#define PBL_BOUND_ERR_CH0_S    28
   1695#define PBL_BOUND_ERR_CH0_V(x) ((x) << PBL_BOUND_ERR_CH0_S)
   1696#define PBL_BOUND_ERR_CH0_F    PBL_BOUND_ERR_CH0_V(1U)
   1697
   1698#define PM_RX_INT_CAUSE_A	0x8fdc
   1699#define PM_RX_STAT_CONFIG_A 0x8fc8
   1700#define PM_RX_STAT_COUNT_A 0x8fcc
   1701#define PM_RX_STAT_LSB_A 0x8fd0
   1702#define PM_RX_DBG_CTRL_A 0x8fd0
   1703#define PM_RX_DBG_DATA_A 0x8fd4
   1704#define PM_RX_DBG_STAT_MSB_A 0x10013
   1705
   1706#define PMRX_FRAMING_ERROR_F	0x003ffff0U
   1707
   1708#define ZERO_E_CMD_ERROR_S    22
   1709#define ZERO_E_CMD_ERROR_V(x) ((x) << ZERO_E_CMD_ERROR_S)
   1710#define ZERO_E_CMD_ERROR_F    ZERO_E_CMD_ERROR_V(1U)
   1711
   1712#define OCSPI_PAR_ERROR_S    3
   1713#define OCSPI_PAR_ERROR_V(x) ((x) << OCSPI_PAR_ERROR_S)
   1714#define OCSPI_PAR_ERROR_F    OCSPI_PAR_ERROR_V(1U)
   1715
   1716#define DB_OPTIONS_PAR_ERROR_S    2
   1717#define DB_OPTIONS_PAR_ERROR_V(x) ((x) << DB_OPTIONS_PAR_ERROR_S)
   1718#define DB_OPTIONS_PAR_ERROR_F    DB_OPTIONS_PAR_ERROR_V(1U)
   1719
   1720#define IESPI_PAR_ERROR_S    1
   1721#define IESPI_PAR_ERROR_V(x) ((x) << IESPI_PAR_ERROR_S)
   1722#define IESPI_PAR_ERROR_F    IESPI_PAR_ERROR_V(1U)
   1723
   1724#define ULP_TX_LA_RDPTR_0_A 0x8ec0
   1725#define ULP_TX_LA_RDDATA_0_A 0x8ec4
   1726#define ULP_TX_LA_WRPTR_0_A 0x8ec8
   1727#define ULP_TX_ASIC_DEBUG_CTRL_A 0x8f70
   1728
   1729#define ULP_TX_ASIC_DEBUG_0_A 0x8f74
   1730#define ULP_TX_ASIC_DEBUG_1_A 0x8f78
   1731#define ULP_TX_ASIC_DEBUG_2_A 0x8f7c
   1732#define ULP_TX_ASIC_DEBUG_3_A 0x8f80
   1733#define ULP_TX_ASIC_DEBUG_4_A 0x8f84
   1734
   1735/* registers for module PM_RX */
   1736#define PM_RX_BASE_ADDR 0x8fc0
   1737
   1738#define PMRX_E_PCMD_PAR_ERROR_S    0
   1739#define PMRX_E_PCMD_PAR_ERROR_V(x) ((x) << PMRX_E_PCMD_PAR_ERROR_S)
   1740#define PMRX_E_PCMD_PAR_ERROR_F    PMRX_E_PCMD_PAR_ERROR_V(1U)
   1741
   1742#define PM_TX_INT_CAUSE_A	0x8ffc
   1743#define PM_TX_STAT_CONFIG_A 0x8fe8
   1744#define PM_TX_STAT_COUNT_A 0x8fec
   1745#define PM_TX_STAT_LSB_A 0x8ff0
   1746#define PM_TX_DBG_CTRL_A 0x8ff0
   1747#define PM_TX_DBG_DATA_A 0x8ff4
   1748#define PM_TX_DBG_STAT_MSB_A 0x1001a
   1749
   1750#define PCMD_LEN_OVFL0_S    31
   1751#define PCMD_LEN_OVFL0_V(x) ((x) << PCMD_LEN_OVFL0_S)
   1752#define PCMD_LEN_OVFL0_F    PCMD_LEN_OVFL0_V(1U)
   1753
   1754#define PCMD_LEN_OVFL1_S    30
   1755#define PCMD_LEN_OVFL1_V(x) ((x) << PCMD_LEN_OVFL1_S)
   1756#define PCMD_LEN_OVFL1_F    PCMD_LEN_OVFL1_V(1U)
   1757
   1758#define PCMD_LEN_OVFL2_S    29
   1759#define PCMD_LEN_OVFL2_V(x) ((x) << PCMD_LEN_OVFL2_S)
   1760#define PCMD_LEN_OVFL2_F    PCMD_LEN_OVFL2_V(1U)
   1761
   1762#define ZERO_C_CMD_ERROR_S    28
   1763#define ZERO_C_CMD_ERROR_V(x) ((x) << ZERO_C_CMD_ERROR_S)
   1764#define ZERO_C_CMD_ERROR_F    ZERO_C_CMD_ERROR_V(1U)
   1765
   1766#define  PMTX_FRAMING_ERROR_F 0x0ffffff0U
   1767
   1768#define OESPI_PAR_ERROR_S    3
   1769#define OESPI_PAR_ERROR_V(x) ((x) << OESPI_PAR_ERROR_S)
   1770#define OESPI_PAR_ERROR_F    OESPI_PAR_ERROR_V(1U)
   1771
   1772#define ICSPI_PAR_ERROR_S    1
   1773#define ICSPI_PAR_ERROR_V(x) ((x) << ICSPI_PAR_ERROR_S)
   1774#define ICSPI_PAR_ERROR_F    ICSPI_PAR_ERROR_V(1U)
   1775
   1776#define PMTX_C_PCMD_PAR_ERROR_S    0
   1777#define PMTX_C_PCMD_PAR_ERROR_V(x) ((x) << PMTX_C_PCMD_PAR_ERROR_S)
   1778#define PMTX_C_PCMD_PAR_ERROR_F    PMTX_C_PCMD_PAR_ERROR_V(1U)
   1779
   1780#define MPS_PORT_STAT_TX_PORT_BYTES_L 0x400
   1781#define MPS_PORT_STAT_TX_PORT_BYTES_H 0x404
   1782#define MPS_PORT_STAT_TX_PORT_FRAMES_L 0x408
   1783#define MPS_PORT_STAT_TX_PORT_FRAMES_H 0x40c
   1784#define MPS_PORT_STAT_TX_PORT_BCAST_L 0x410
   1785#define MPS_PORT_STAT_TX_PORT_BCAST_H 0x414
   1786#define MPS_PORT_STAT_TX_PORT_MCAST_L 0x418
   1787#define MPS_PORT_STAT_TX_PORT_MCAST_H 0x41c
   1788#define MPS_PORT_STAT_TX_PORT_UCAST_L 0x420
   1789#define MPS_PORT_STAT_TX_PORT_UCAST_H 0x424
   1790#define MPS_PORT_STAT_TX_PORT_ERROR_L 0x428
   1791#define MPS_PORT_STAT_TX_PORT_ERROR_H 0x42c
   1792#define MPS_PORT_STAT_TX_PORT_64B_L 0x430
   1793#define MPS_PORT_STAT_TX_PORT_64B_H 0x434
   1794#define MPS_PORT_STAT_TX_PORT_65B_127B_L 0x438
   1795#define MPS_PORT_STAT_TX_PORT_65B_127B_H 0x43c
   1796#define MPS_PORT_STAT_TX_PORT_128B_255B_L 0x440
   1797#define MPS_PORT_STAT_TX_PORT_128B_255B_H 0x444
   1798#define MPS_PORT_STAT_TX_PORT_256B_511B_L 0x448
   1799#define MPS_PORT_STAT_TX_PORT_256B_511B_H 0x44c
   1800#define MPS_PORT_STAT_TX_PORT_512B_1023B_L 0x450
   1801#define MPS_PORT_STAT_TX_PORT_512B_1023B_H 0x454
   1802#define MPS_PORT_STAT_TX_PORT_1024B_1518B_L 0x458
   1803#define MPS_PORT_STAT_TX_PORT_1024B_1518B_H 0x45c
   1804#define MPS_PORT_STAT_TX_PORT_1519B_MAX_L 0x460
   1805#define MPS_PORT_STAT_TX_PORT_1519B_MAX_H 0x464
   1806#define MPS_PORT_STAT_TX_PORT_DROP_L 0x468
   1807#define MPS_PORT_STAT_TX_PORT_DROP_H 0x46c
   1808#define MPS_PORT_STAT_TX_PORT_PAUSE_L 0x470
   1809#define MPS_PORT_STAT_TX_PORT_PAUSE_H 0x474
   1810#define MPS_PORT_STAT_TX_PORT_PPP0_L 0x478
   1811#define MPS_PORT_STAT_TX_PORT_PPP0_H 0x47c
   1812#define MPS_PORT_STAT_TX_PORT_PPP1_L 0x480
   1813#define MPS_PORT_STAT_TX_PORT_PPP1_H 0x484
   1814#define MPS_PORT_STAT_TX_PORT_PPP2_L 0x488
   1815#define MPS_PORT_STAT_TX_PORT_PPP2_H 0x48c
   1816#define MPS_PORT_STAT_TX_PORT_PPP3_L 0x490
   1817#define MPS_PORT_STAT_TX_PORT_PPP3_H 0x494
   1818#define MPS_PORT_STAT_TX_PORT_PPP4_L 0x498
   1819#define MPS_PORT_STAT_TX_PORT_PPP4_H 0x49c
   1820#define MPS_PORT_STAT_TX_PORT_PPP5_L 0x4a0
   1821#define MPS_PORT_STAT_TX_PORT_PPP5_H 0x4a4
   1822#define MPS_PORT_STAT_TX_PORT_PPP6_L 0x4a8
   1823#define MPS_PORT_STAT_TX_PORT_PPP6_H 0x4ac
   1824#define MPS_PORT_STAT_TX_PORT_PPP7_L 0x4b0
   1825#define MPS_PORT_STAT_TX_PORT_PPP7_H 0x4b4
   1826#define MPS_PORT_STAT_LB_PORT_BYTES_L 0x4c0
   1827#define MPS_PORT_STAT_LB_PORT_BYTES_H 0x4c4
   1828#define MPS_PORT_STAT_LB_PORT_FRAMES_L 0x4c8
   1829#define MPS_PORT_STAT_LB_PORT_FRAMES_H 0x4cc
   1830#define MPS_PORT_STAT_LB_PORT_BCAST_L 0x4d0
   1831#define MPS_PORT_STAT_LB_PORT_BCAST_H 0x4d4
   1832#define MPS_PORT_STAT_LB_PORT_MCAST_L 0x4d8
   1833#define MPS_PORT_STAT_LB_PORT_MCAST_H 0x4dc
   1834#define MPS_PORT_STAT_LB_PORT_UCAST_L 0x4e0
   1835#define MPS_PORT_STAT_LB_PORT_UCAST_H 0x4e4
   1836#define MPS_PORT_STAT_LB_PORT_ERROR_L 0x4e8
   1837#define MPS_PORT_STAT_LB_PORT_ERROR_H 0x4ec
   1838#define MPS_PORT_STAT_LB_PORT_64B_L 0x4f0
   1839#define MPS_PORT_STAT_LB_PORT_64B_H 0x4f4
   1840#define MPS_PORT_STAT_LB_PORT_65B_127B_L 0x4f8
   1841#define MPS_PORT_STAT_LB_PORT_65B_127B_H 0x4fc
   1842#define MPS_PORT_STAT_LB_PORT_128B_255B_L 0x500
   1843#define MPS_PORT_STAT_LB_PORT_128B_255B_H 0x504
   1844#define MPS_PORT_STAT_LB_PORT_256B_511B_L 0x508
   1845#define MPS_PORT_STAT_LB_PORT_256B_511B_H 0x50c
   1846#define MPS_PORT_STAT_LB_PORT_512B_1023B_L 0x510
   1847#define MPS_PORT_STAT_LB_PORT_512B_1023B_H 0x514
   1848#define MPS_PORT_STAT_LB_PORT_1024B_1518B_L 0x518
   1849#define MPS_PORT_STAT_LB_PORT_1024B_1518B_H 0x51c
   1850#define MPS_PORT_STAT_LB_PORT_1519B_MAX_L 0x520
   1851#define MPS_PORT_STAT_LB_PORT_1519B_MAX_H 0x524
   1852#define MPS_PORT_STAT_LB_PORT_DROP_FRAMES 0x528
   1853#define MPS_PORT_STAT_LB_PORT_DROP_FRAMES_L 0x528
   1854#define MPS_PORT_STAT_RX_PORT_BYTES_L 0x540
   1855#define MPS_PORT_STAT_RX_PORT_BYTES_H 0x544
   1856#define MPS_PORT_STAT_RX_PORT_FRAMES_L 0x548
   1857#define MPS_PORT_STAT_RX_PORT_FRAMES_H 0x54c
   1858#define MPS_PORT_STAT_RX_PORT_BCAST_L 0x550
   1859#define MPS_PORT_STAT_RX_PORT_BCAST_H 0x554
   1860#define MPS_PORT_STAT_RX_PORT_MCAST_L 0x558
   1861#define MPS_PORT_STAT_RX_PORT_MCAST_H 0x55c
   1862#define MPS_PORT_STAT_RX_PORT_UCAST_L 0x560
   1863#define MPS_PORT_STAT_RX_PORT_UCAST_H 0x564
   1864#define MPS_PORT_STAT_RX_PORT_MTU_ERROR_L 0x568
   1865#define MPS_PORT_STAT_RX_PORT_MTU_ERROR_H 0x56c
   1866#define MPS_PORT_STAT_RX_PORT_MTU_CRC_ERROR_L 0x570
   1867#define MPS_PORT_STAT_RX_PORT_MTU_CRC_ERROR_H 0x574
   1868#define MPS_PORT_STAT_RX_PORT_CRC_ERROR_L 0x578
   1869#define MPS_PORT_STAT_RX_PORT_CRC_ERROR_H 0x57c
   1870#define MPS_PORT_STAT_RX_PORT_LEN_ERROR_L 0x580
   1871#define MPS_PORT_STAT_RX_PORT_LEN_ERROR_H 0x584
   1872#define MPS_PORT_STAT_RX_PORT_SYM_ERROR_L 0x588
   1873#define MPS_PORT_STAT_RX_PORT_SYM_ERROR_H 0x58c
   1874#define MPS_PORT_STAT_RX_PORT_64B_L 0x590
   1875#define MPS_PORT_STAT_RX_PORT_64B_H 0x594
   1876#define MPS_PORT_STAT_RX_PORT_65B_127B_L 0x598
   1877#define MPS_PORT_STAT_RX_PORT_65B_127B_H 0x59c
   1878#define MPS_PORT_STAT_RX_PORT_128B_255B_L 0x5a0
   1879#define MPS_PORT_STAT_RX_PORT_128B_255B_H 0x5a4
   1880#define MPS_PORT_STAT_RX_PORT_256B_511B_L 0x5a8
   1881#define MPS_PORT_STAT_RX_PORT_256B_511B_H 0x5ac
   1882#define MPS_PORT_STAT_RX_PORT_512B_1023B_L 0x5b0
   1883#define MPS_PORT_STAT_RX_PORT_512B_1023B_H 0x5b4
   1884#define MPS_PORT_STAT_RX_PORT_1024B_1518B_L 0x5b8
   1885#define MPS_PORT_STAT_RX_PORT_1024B_1518B_H 0x5bc
   1886#define MPS_PORT_STAT_RX_PORT_1519B_MAX_L 0x5c0
   1887#define MPS_PORT_STAT_RX_PORT_1519B_MAX_H 0x5c4
   1888#define MPS_PORT_STAT_RX_PORT_PAUSE_L 0x5c8
   1889#define MPS_PORT_STAT_RX_PORT_PAUSE_H 0x5cc
   1890#define MPS_PORT_STAT_RX_PORT_PPP0_L 0x5d0
   1891#define MPS_PORT_STAT_RX_PORT_PPP0_H 0x5d4
   1892#define MPS_PORT_STAT_RX_PORT_PPP1_L 0x5d8
   1893#define MPS_PORT_STAT_RX_PORT_PPP1_H 0x5dc
   1894#define MPS_PORT_STAT_RX_PORT_PPP2_L 0x5e0
   1895#define MPS_PORT_STAT_RX_PORT_PPP2_H 0x5e4
   1896#define MPS_PORT_STAT_RX_PORT_PPP3_L 0x5e8
   1897#define MPS_PORT_STAT_RX_PORT_PPP3_H 0x5ec
   1898#define MPS_PORT_STAT_RX_PORT_PPP4_L 0x5f0
   1899#define MPS_PORT_STAT_RX_PORT_PPP4_H 0x5f4
   1900#define MPS_PORT_STAT_RX_PORT_PPP5_L 0x5f8
   1901#define MPS_PORT_STAT_RX_PORT_PPP5_H 0x5fc
   1902#define MPS_PORT_STAT_RX_PORT_PPP6_L 0x600
   1903#define MPS_PORT_STAT_RX_PORT_PPP6_H 0x604
   1904#define MPS_PORT_STAT_RX_PORT_PPP7_L 0x608
   1905#define MPS_PORT_STAT_RX_PORT_PPP7_H 0x60c
   1906#define MPS_PORT_STAT_RX_PORT_LESS_64B_L 0x610
   1907#define MPS_PORT_STAT_RX_PORT_LESS_64B_H 0x614
   1908#define MAC_PORT_MAGIC_MACID_LO 0x824
   1909#define MAC_PORT_MAGIC_MACID_HI 0x828
   1910#define MAC_PORT_TX_TS_VAL_LO   0x928
   1911#define MAC_PORT_TX_TS_VAL_HI   0x92c
   1912
   1913#define MAC_PORT_EPIO_DATA0_A 0x8c0
   1914#define MAC_PORT_EPIO_DATA1_A 0x8c4
   1915#define MAC_PORT_EPIO_DATA2_A 0x8c8
   1916#define MAC_PORT_EPIO_DATA3_A 0x8cc
   1917#define MAC_PORT_EPIO_OP_A 0x8d0
   1918
   1919#define MAC_PORT_CFG2_A 0x818
   1920
   1921#define MAC_PORT_PTP_SUM_LO_A 0x990
   1922#define MAC_PORT_PTP_SUM_HI_A 0x994
   1923
   1924#define MPS_CMN_CTL_A	0x9000
   1925
   1926#define COUNTPAUSEMCRX_S    5
   1927#define COUNTPAUSEMCRX_V(x) ((x) << COUNTPAUSEMCRX_S)
   1928#define COUNTPAUSEMCRX_F    COUNTPAUSEMCRX_V(1U)
   1929
   1930#define COUNTPAUSESTATRX_S    4
   1931#define COUNTPAUSESTATRX_V(x) ((x) << COUNTPAUSESTATRX_S)
   1932#define COUNTPAUSESTATRX_F    COUNTPAUSESTATRX_V(1U)
   1933
   1934#define COUNTPAUSEMCTX_S    3
   1935#define COUNTPAUSEMCTX_V(x) ((x) << COUNTPAUSEMCTX_S)
   1936#define COUNTPAUSEMCTX_F    COUNTPAUSEMCTX_V(1U)
   1937
   1938#define COUNTPAUSESTATTX_S    2
   1939#define COUNTPAUSESTATTX_V(x) ((x) << COUNTPAUSESTATTX_S)
   1940#define COUNTPAUSESTATTX_F    COUNTPAUSESTATTX_V(1U)
   1941
   1942#define NUMPORTS_S    0
   1943#define NUMPORTS_M    0x3U
   1944#define NUMPORTS_G(x) (((x) >> NUMPORTS_S) & NUMPORTS_M)
   1945
   1946#define MPS_INT_CAUSE_A 0x9008
   1947#define MPS_TX_INT_CAUSE_A 0x9408
   1948#define MPS_STAT_CTL_A 0x9600
   1949
   1950#define FRMERR_S    15
   1951#define FRMERR_V(x) ((x) << FRMERR_S)
   1952#define FRMERR_F    FRMERR_V(1U)
   1953
   1954#define SECNTERR_S    14
   1955#define SECNTERR_V(x) ((x) << SECNTERR_S)
   1956#define SECNTERR_F    SECNTERR_V(1U)
   1957
   1958#define BUBBLE_S    13
   1959#define BUBBLE_V(x) ((x) << BUBBLE_S)
   1960#define BUBBLE_F    BUBBLE_V(1U)
   1961
   1962#define TXDESCFIFO_S    9
   1963#define TXDESCFIFO_M    0xfU
   1964#define TXDESCFIFO_V(x) ((x) << TXDESCFIFO_S)
   1965
   1966#define TXDATAFIFO_S    5
   1967#define TXDATAFIFO_M    0xfU
   1968#define TXDATAFIFO_V(x) ((x) << TXDATAFIFO_S)
   1969
   1970#define NCSIFIFO_S    4
   1971#define NCSIFIFO_V(x) ((x) << NCSIFIFO_S)
   1972#define NCSIFIFO_F    NCSIFIFO_V(1U)
   1973
   1974#define TPFIFO_S    0
   1975#define TPFIFO_M    0xfU
   1976#define TPFIFO_V(x) ((x) << TPFIFO_S)
   1977
   1978#define MPS_STAT_PERR_INT_CAUSE_SRAM_A		0x9614
   1979#define MPS_STAT_PERR_INT_CAUSE_TX_FIFO_A	0x9620
   1980#define MPS_STAT_PERR_INT_CAUSE_RX_FIFO_A	0x962c
   1981
   1982#define MPS_STAT_RX_BG_0_MAC_DROP_FRAME_L 0x9640
   1983#define MPS_STAT_RX_BG_0_MAC_DROP_FRAME_H 0x9644
   1984#define MPS_STAT_RX_BG_1_MAC_DROP_FRAME_L 0x9648
   1985#define MPS_STAT_RX_BG_1_MAC_DROP_FRAME_H 0x964c
   1986#define MPS_STAT_RX_BG_2_MAC_DROP_FRAME_L 0x9650
   1987#define MPS_STAT_RX_BG_2_MAC_DROP_FRAME_H 0x9654
   1988#define MPS_STAT_RX_BG_3_MAC_DROP_FRAME_L 0x9658
   1989#define MPS_STAT_RX_BG_3_MAC_DROP_FRAME_H 0x965c
   1990#define MPS_STAT_RX_BG_0_LB_DROP_FRAME_L 0x9660
   1991#define MPS_STAT_RX_BG_0_LB_DROP_FRAME_H 0x9664
   1992#define MPS_STAT_RX_BG_1_LB_DROP_FRAME_L 0x9668
   1993#define MPS_STAT_RX_BG_1_LB_DROP_FRAME_H 0x966c
   1994#define MPS_STAT_RX_BG_2_LB_DROP_FRAME_L 0x9670
   1995#define MPS_STAT_RX_BG_2_LB_DROP_FRAME_H 0x9674
   1996#define MPS_STAT_RX_BG_3_LB_DROP_FRAME_L 0x9678
   1997#define MPS_STAT_RX_BG_3_LB_DROP_FRAME_H 0x967c
   1998#define MPS_STAT_RX_BG_0_MAC_TRUNC_FRAME_L 0x9680
   1999#define MPS_STAT_RX_BG_0_MAC_TRUNC_FRAME_H 0x9684
   2000#define MPS_STAT_RX_BG_1_MAC_TRUNC_FRAME_L 0x9688
   2001#define MPS_STAT_RX_BG_1_MAC_TRUNC_FRAME_H 0x968c
   2002#define MPS_STAT_RX_BG_2_MAC_TRUNC_FRAME_L 0x9690
   2003#define MPS_STAT_RX_BG_2_MAC_TRUNC_FRAME_H 0x9694
   2004#define MPS_STAT_RX_BG_3_MAC_TRUNC_FRAME_L 0x9698
   2005#define MPS_STAT_RX_BG_3_MAC_TRUNC_FRAME_H 0x969c
   2006#define MPS_STAT_RX_BG_0_LB_TRUNC_FRAME_L 0x96a0
   2007#define MPS_STAT_RX_BG_0_LB_TRUNC_FRAME_H 0x96a4
   2008#define MPS_STAT_RX_BG_1_LB_TRUNC_FRAME_L 0x96a8
   2009#define MPS_STAT_RX_BG_1_LB_TRUNC_FRAME_H 0x96ac
   2010#define MPS_STAT_RX_BG_2_LB_TRUNC_FRAME_L 0x96b0
   2011#define MPS_STAT_RX_BG_2_LB_TRUNC_FRAME_H 0x96b4
   2012#define MPS_STAT_RX_BG_3_LB_TRUNC_FRAME_L 0x96b8
   2013#define MPS_STAT_RX_BG_3_LB_TRUNC_FRAME_H 0x96bc
   2014
   2015#define MPS_TRC_CFG_A 0x9800
   2016
   2017#define TRCFIFOEMPTY_S    4
   2018#define TRCFIFOEMPTY_V(x) ((x) << TRCFIFOEMPTY_S)
   2019#define TRCFIFOEMPTY_F    TRCFIFOEMPTY_V(1U)
   2020
   2021#define TRCIGNOREDROPINPUT_S    3
   2022#define TRCIGNOREDROPINPUT_V(x) ((x) << TRCIGNOREDROPINPUT_S)
   2023#define TRCIGNOREDROPINPUT_F    TRCIGNOREDROPINPUT_V(1U)
   2024
   2025#define TRCKEEPDUPLICATES_S    2
   2026#define TRCKEEPDUPLICATES_V(x) ((x) << TRCKEEPDUPLICATES_S)
   2027#define TRCKEEPDUPLICATES_F    TRCKEEPDUPLICATES_V(1U)
   2028
   2029#define TRCEN_S    1
   2030#define TRCEN_V(x) ((x) << TRCEN_S)
   2031#define TRCEN_F    TRCEN_V(1U)
   2032
   2033#define TRCMULTIFILTER_S    0
   2034#define TRCMULTIFILTER_V(x) ((x) << TRCMULTIFILTER_S)
   2035#define TRCMULTIFILTER_F    TRCMULTIFILTER_V(1U)
   2036
   2037#define MPS_TRC_RSS_CONTROL_A		0x9808
   2038#define MPS_TRC_FILTER1_RSS_CONTROL_A	0x9ff4
   2039#define MPS_TRC_FILTER2_RSS_CONTROL_A	0x9ffc
   2040#define MPS_TRC_FILTER3_RSS_CONTROL_A	0xa004
   2041#define MPS_T5_TRC_RSS_CONTROL_A	0xa00c
   2042
   2043#define RSSCONTROL_S    16
   2044#define RSSCONTROL_V(x) ((x) << RSSCONTROL_S)
   2045
   2046#define QUEUENUMBER_S    0
   2047#define QUEUENUMBER_V(x) ((x) << QUEUENUMBER_S)
   2048
   2049#define TFINVERTMATCH_S    24
   2050#define TFINVERTMATCH_V(x) ((x) << TFINVERTMATCH_S)
   2051#define TFINVERTMATCH_F    TFINVERTMATCH_V(1U)
   2052
   2053#define TFEN_S    22
   2054#define TFEN_V(x) ((x) << TFEN_S)
   2055#define TFEN_F    TFEN_V(1U)
   2056
   2057#define TFPORT_S    18
   2058#define TFPORT_M    0xfU
   2059#define TFPORT_V(x) ((x) << TFPORT_S)
   2060#define TFPORT_G(x) (((x) >> TFPORT_S) & TFPORT_M)
   2061
   2062#define TFLENGTH_S    8
   2063#define TFLENGTH_M    0x1fU
   2064#define TFLENGTH_V(x) ((x) << TFLENGTH_S)
   2065#define TFLENGTH_G(x) (((x) >> TFLENGTH_S) & TFLENGTH_M)
   2066
   2067#define TFOFFSET_S    0
   2068#define TFOFFSET_M    0x1fU
   2069#define TFOFFSET_V(x) ((x) << TFOFFSET_S)
   2070#define TFOFFSET_G(x) (((x) >> TFOFFSET_S) & TFOFFSET_M)
   2071
   2072#define T5_TFINVERTMATCH_S    25
   2073#define T5_TFINVERTMATCH_V(x) ((x) << T5_TFINVERTMATCH_S)
   2074#define T5_TFINVERTMATCH_F    T5_TFINVERTMATCH_V(1U)
   2075
   2076#define T5_TFEN_S    23
   2077#define T5_TFEN_V(x) ((x) << T5_TFEN_S)
   2078#define T5_TFEN_F    T5_TFEN_V(1U)
   2079
   2080#define T5_TFPORT_S    18
   2081#define T5_TFPORT_M    0x1fU
   2082#define T5_TFPORT_V(x) ((x) << T5_TFPORT_S)
   2083#define T5_TFPORT_G(x) (((x) >> T5_TFPORT_S) & T5_TFPORT_M)
   2084
   2085#define MPS_TRC_FILTER_MATCH_CTL_A_A 0x9810
   2086#define MPS_TRC_FILTER_MATCH_CTL_B_A 0x9820
   2087
   2088#define TFMINPKTSIZE_S    16
   2089#define TFMINPKTSIZE_M    0x1ffU
   2090#define TFMINPKTSIZE_V(x) ((x) << TFMINPKTSIZE_S)
   2091#define TFMINPKTSIZE_G(x) (((x) >> TFMINPKTSIZE_S) & TFMINPKTSIZE_M)
   2092
   2093#define TFCAPTUREMAX_S    0
   2094#define TFCAPTUREMAX_M    0x3fffU
   2095#define TFCAPTUREMAX_V(x) ((x) << TFCAPTUREMAX_S)
   2096#define TFCAPTUREMAX_G(x) (((x) >> TFCAPTUREMAX_S) & TFCAPTUREMAX_M)
   2097
   2098#define MPS_TRC_FILTER0_MATCH_A 0x9c00
   2099#define MPS_TRC_FILTER0_DONT_CARE_A 0x9c80
   2100#define MPS_TRC_FILTER1_MATCH_A 0x9d00
   2101
   2102#define TP_RSS_CONFIG_A 0x7df0
   2103
   2104#define TNL4TUPENIPV6_S    31
   2105#define TNL4TUPENIPV6_V(x) ((x) << TNL4TUPENIPV6_S)
   2106#define TNL4TUPENIPV6_F    TNL4TUPENIPV6_V(1U)
   2107
   2108#define TNL2TUPENIPV6_S    30
   2109#define TNL2TUPENIPV6_V(x) ((x) << TNL2TUPENIPV6_S)
   2110#define TNL2TUPENIPV6_F    TNL2TUPENIPV6_V(1U)
   2111
   2112#define TNL4TUPENIPV4_S    29
   2113#define TNL4TUPENIPV4_V(x) ((x) << TNL4TUPENIPV4_S)
   2114#define TNL4TUPENIPV4_F    TNL4TUPENIPV4_V(1U)
   2115
   2116#define TNL2TUPENIPV4_S    28
   2117#define TNL2TUPENIPV4_V(x) ((x) << TNL2TUPENIPV4_S)
   2118#define TNL2TUPENIPV4_F    TNL2TUPENIPV4_V(1U)
   2119
   2120#define TNLTCPSEL_S    27
   2121#define TNLTCPSEL_V(x) ((x) << TNLTCPSEL_S)
   2122#define TNLTCPSEL_F    TNLTCPSEL_V(1U)
   2123
   2124#define TNLIP6SEL_S    26
   2125#define TNLIP6SEL_V(x) ((x) << TNLIP6SEL_S)
   2126#define TNLIP6SEL_F    TNLIP6SEL_V(1U)
   2127
   2128#define TNLVRTSEL_S    25
   2129#define TNLVRTSEL_V(x) ((x) << TNLVRTSEL_S)
   2130#define TNLVRTSEL_F    TNLVRTSEL_V(1U)
   2131
   2132#define TNLMAPEN_S    24
   2133#define TNLMAPEN_V(x) ((x) << TNLMAPEN_S)
   2134#define TNLMAPEN_F    TNLMAPEN_V(1U)
   2135
   2136#define OFDHASHSAVE_S    19
   2137#define OFDHASHSAVE_V(x) ((x) << OFDHASHSAVE_S)
   2138#define OFDHASHSAVE_F    OFDHASHSAVE_V(1U)
   2139
   2140#define OFDVRTSEL_S    18
   2141#define OFDVRTSEL_V(x) ((x) << OFDVRTSEL_S)
   2142#define OFDVRTSEL_F    OFDVRTSEL_V(1U)
   2143
   2144#define OFDMAPEN_S    17
   2145#define OFDMAPEN_V(x) ((x) << OFDMAPEN_S)
   2146#define OFDMAPEN_F    OFDMAPEN_V(1U)
   2147
   2148#define OFDLKPEN_S    16
   2149#define OFDLKPEN_V(x) ((x) << OFDLKPEN_S)
   2150#define OFDLKPEN_F    OFDLKPEN_V(1U)
   2151
   2152#define SYN4TUPENIPV6_S    15
   2153#define SYN4TUPENIPV6_V(x) ((x) << SYN4TUPENIPV6_S)
   2154#define SYN4TUPENIPV6_F    SYN4TUPENIPV6_V(1U)
   2155
   2156#define SYN2TUPENIPV6_S    14
   2157#define SYN2TUPENIPV6_V(x) ((x) << SYN2TUPENIPV6_S)
   2158#define SYN2TUPENIPV6_F    SYN2TUPENIPV6_V(1U)
   2159
   2160#define SYN4TUPENIPV4_S    13
   2161#define SYN4TUPENIPV4_V(x) ((x) << SYN4TUPENIPV4_S)
   2162#define SYN4TUPENIPV4_F    SYN4TUPENIPV4_V(1U)
   2163
   2164#define SYN2TUPENIPV4_S    12
   2165#define SYN2TUPENIPV4_V(x) ((x) << SYN2TUPENIPV4_S)
   2166#define SYN2TUPENIPV4_F    SYN2TUPENIPV4_V(1U)
   2167
   2168#define SYNIP6SEL_S    11
   2169#define SYNIP6SEL_V(x) ((x) << SYNIP6SEL_S)
   2170#define SYNIP6SEL_F    SYNIP6SEL_V(1U)
   2171
   2172#define SYNVRTSEL_S    10
   2173#define SYNVRTSEL_V(x) ((x) << SYNVRTSEL_S)
   2174#define SYNVRTSEL_F    SYNVRTSEL_V(1U)
   2175
   2176#define SYNMAPEN_S    9
   2177#define SYNMAPEN_V(x) ((x) << SYNMAPEN_S)
   2178#define SYNMAPEN_F    SYNMAPEN_V(1U)
   2179
   2180#define SYNLKPEN_S    8
   2181#define SYNLKPEN_V(x) ((x) << SYNLKPEN_S)
   2182#define SYNLKPEN_F    SYNLKPEN_V(1U)
   2183
   2184#define CHANNELENABLE_S    7
   2185#define CHANNELENABLE_V(x) ((x) << CHANNELENABLE_S)
   2186#define CHANNELENABLE_F    CHANNELENABLE_V(1U)
   2187
   2188#define PORTENABLE_S    6
   2189#define PORTENABLE_V(x) ((x) << PORTENABLE_S)
   2190#define PORTENABLE_F    PORTENABLE_V(1U)
   2191
   2192#define TNLALLLOOKUP_S    5
   2193#define TNLALLLOOKUP_V(x) ((x) << TNLALLLOOKUP_S)
   2194#define TNLALLLOOKUP_F    TNLALLLOOKUP_V(1U)
   2195
   2196#define VIRTENABLE_S    4
   2197#define VIRTENABLE_V(x) ((x) << VIRTENABLE_S)
   2198#define VIRTENABLE_F    VIRTENABLE_V(1U)
   2199
   2200#define CONGESTIONENABLE_S    3
   2201#define CONGESTIONENABLE_V(x) ((x) << CONGESTIONENABLE_S)
   2202#define CONGESTIONENABLE_F    CONGESTIONENABLE_V(1U)
   2203
   2204#define HASHTOEPLITZ_S    2
   2205#define HASHTOEPLITZ_V(x) ((x) << HASHTOEPLITZ_S)
   2206#define HASHTOEPLITZ_F    HASHTOEPLITZ_V(1U)
   2207
   2208#define UDPENABLE_S    1
   2209#define UDPENABLE_V(x) ((x) << UDPENABLE_S)
   2210#define UDPENABLE_F    UDPENABLE_V(1U)
   2211
   2212#define DISABLE_S    0
   2213#define DISABLE_V(x) ((x) << DISABLE_S)
   2214#define DISABLE_F    DISABLE_V(1U)
   2215
   2216#define TP_RSS_CONFIG_TNL_A 0x7df4
   2217
   2218#define MASKSIZE_S    28
   2219#define MASKSIZE_M    0xfU
   2220#define MASKSIZE_V(x) ((x) << MASKSIZE_S)
   2221#define MASKSIZE_G(x) (((x) >> MASKSIZE_S) & MASKSIZE_M)
   2222
   2223#define MASKFILTER_S    16
   2224#define MASKFILTER_M    0x7ffU
   2225#define MASKFILTER_V(x) ((x) << MASKFILTER_S)
   2226#define MASKFILTER_G(x) (((x) >> MASKFILTER_S) & MASKFILTER_M)
   2227
   2228#define USEWIRECH_S    0
   2229#define USEWIRECH_V(x) ((x) << USEWIRECH_S)
   2230#define USEWIRECH_F    USEWIRECH_V(1U)
   2231
   2232#define HASHALL_S    2
   2233#define HASHALL_V(x) ((x) << HASHALL_S)
   2234#define HASHALL_F    HASHALL_V(1U)
   2235
   2236#define HASHETH_S    1
   2237#define HASHETH_V(x) ((x) << HASHETH_S)
   2238#define HASHETH_F    HASHETH_V(1U)
   2239
   2240#define TP_RSS_CONFIG_OFD_A 0x7df8
   2241
   2242#define RRCPLMAPEN_S    20
   2243#define RRCPLMAPEN_V(x) ((x) << RRCPLMAPEN_S)
   2244#define RRCPLMAPEN_F    RRCPLMAPEN_V(1U)
   2245
   2246#define RRCPLQUEWIDTH_S    16
   2247#define RRCPLQUEWIDTH_M    0xfU
   2248#define RRCPLQUEWIDTH_V(x) ((x) << RRCPLQUEWIDTH_S)
   2249#define RRCPLQUEWIDTH_G(x) (((x) >> RRCPLQUEWIDTH_S) & RRCPLQUEWIDTH_M)
   2250
   2251#define TP_RSS_CONFIG_SYN_A 0x7dfc
   2252#define TP_RSS_CONFIG_VRT_A 0x7e00
   2253
   2254#define VFRDRG_S    25
   2255#define VFRDRG_V(x) ((x) << VFRDRG_S)
   2256#define VFRDRG_F    VFRDRG_V(1U)
   2257
   2258#define VFRDEN_S    24
   2259#define VFRDEN_V(x) ((x) << VFRDEN_S)
   2260#define VFRDEN_F    VFRDEN_V(1U)
   2261
   2262#define VFPERREN_S    23
   2263#define VFPERREN_V(x) ((x) << VFPERREN_S)
   2264#define VFPERREN_F    VFPERREN_V(1U)
   2265
   2266#define KEYPERREN_S    22
   2267#define KEYPERREN_V(x) ((x) << KEYPERREN_S)
   2268#define KEYPERREN_F    KEYPERREN_V(1U)
   2269
   2270#define DISABLEVLAN_S    21
   2271#define DISABLEVLAN_V(x) ((x) << DISABLEVLAN_S)
   2272#define DISABLEVLAN_F    DISABLEVLAN_V(1U)
   2273
   2274#define ENABLEUP0_S    20
   2275#define ENABLEUP0_V(x) ((x) << ENABLEUP0_S)
   2276#define ENABLEUP0_F    ENABLEUP0_V(1U)
   2277
   2278#define HASHDELAY_S    16
   2279#define HASHDELAY_M    0xfU
   2280#define HASHDELAY_V(x) ((x) << HASHDELAY_S)
   2281#define HASHDELAY_G(x) (((x) >> HASHDELAY_S) & HASHDELAY_M)
   2282
   2283#define VFWRADDR_S    8
   2284#define VFWRADDR_M    0x7fU
   2285#define VFWRADDR_V(x) ((x) << VFWRADDR_S)
   2286#define VFWRADDR_G(x) (((x) >> VFWRADDR_S) & VFWRADDR_M)
   2287
   2288#define KEYMODE_S    6
   2289#define KEYMODE_M    0x3U
   2290#define KEYMODE_V(x) ((x) << KEYMODE_S)
   2291#define KEYMODE_G(x) (((x) >> KEYMODE_S) & KEYMODE_M)
   2292
   2293#define VFWREN_S    5
   2294#define VFWREN_V(x) ((x) << VFWREN_S)
   2295#define VFWREN_F    VFWREN_V(1U)
   2296
   2297#define KEYWREN_S    4
   2298#define KEYWREN_V(x) ((x) << KEYWREN_S)
   2299#define KEYWREN_F    KEYWREN_V(1U)
   2300
   2301#define KEYWRADDR_S    0
   2302#define KEYWRADDR_M    0xfU
   2303#define KEYWRADDR_V(x) ((x) << KEYWRADDR_S)
   2304#define KEYWRADDR_G(x) (((x) >> KEYWRADDR_S) & KEYWRADDR_M)
   2305
   2306#define KEYWRADDRX_S    30
   2307#define KEYWRADDRX_M    0x3U
   2308#define KEYWRADDRX_V(x) ((x) << KEYWRADDRX_S)
   2309#define KEYWRADDRX_G(x) (((x) >> KEYWRADDRX_S) & KEYWRADDRX_M)
   2310
   2311#define KEYEXTEND_S    26
   2312#define KEYEXTEND_V(x) ((x) << KEYEXTEND_S)
   2313#define KEYEXTEND_F    KEYEXTEND_V(1U)
   2314
   2315#define LKPIDXSIZE_S    24
   2316#define LKPIDXSIZE_M    0x3U
   2317#define LKPIDXSIZE_V(x) ((x) << LKPIDXSIZE_S)
   2318#define LKPIDXSIZE_G(x) (((x) >> LKPIDXSIZE_S) & LKPIDXSIZE_M)
   2319
   2320#define TP_RSS_VFL_CONFIG_A 0x3a
   2321#define TP_RSS_VFH_CONFIG_A 0x3b
   2322
   2323#define ENABLEUDPHASH_S    31
   2324#define ENABLEUDPHASH_V(x) ((x) << ENABLEUDPHASH_S)
   2325#define ENABLEUDPHASH_F    ENABLEUDPHASH_V(1U)
   2326
   2327#define VFUPEN_S    30
   2328#define VFUPEN_V(x) ((x) << VFUPEN_S)
   2329#define VFUPEN_F    VFUPEN_V(1U)
   2330
   2331#define VFVLNEX_S    28
   2332#define VFVLNEX_V(x) ((x) << VFVLNEX_S)
   2333#define VFVLNEX_F    VFVLNEX_V(1U)
   2334
   2335#define VFPRTEN_S    27
   2336#define VFPRTEN_V(x) ((x) << VFPRTEN_S)
   2337#define VFPRTEN_F    VFPRTEN_V(1U)
   2338
   2339#define VFCHNEN_S    26
   2340#define VFCHNEN_V(x) ((x) << VFCHNEN_S)
   2341#define VFCHNEN_F    VFCHNEN_V(1U)
   2342
   2343#define DEFAULTQUEUE_S    16
   2344#define DEFAULTQUEUE_M    0x3ffU
   2345#define DEFAULTQUEUE_G(x) (((x) >> DEFAULTQUEUE_S) & DEFAULTQUEUE_M)
   2346
   2347#define VFIP6TWOTUPEN_S    6
   2348#define VFIP6TWOTUPEN_V(x) ((x) << VFIP6TWOTUPEN_S)
   2349#define VFIP6TWOTUPEN_F    VFIP6TWOTUPEN_V(1U)
   2350
   2351#define VFIP4FOURTUPEN_S    5
   2352#define VFIP4FOURTUPEN_V(x) ((x) << VFIP4FOURTUPEN_S)
   2353#define VFIP4FOURTUPEN_F    VFIP4FOURTUPEN_V(1U)
   2354
   2355#define VFIP4TWOTUPEN_S    4
   2356#define VFIP4TWOTUPEN_V(x) ((x) << VFIP4TWOTUPEN_S)
   2357#define VFIP4TWOTUPEN_F    VFIP4TWOTUPEN_V(1U)
   2358
   2359#define KEYINDEX_S    0
   2360#define KEYINDEX_M    0xfU
   2361#define KEYINDEX_G(x) (((x) >> KEYINDEX_S) & KEYINDEX_M)
   2362
   2363#define MAPENABLE_S    31
   2364#define MAPENABLE_V(x) ((x) << MAPENABLE_S)
   2365#define MAPENABLE_F    MAPENABLE_V(1U)
   2366
   2367#define CHNENABLE_S    30
   2368#define CHNENABLE_V(x) ((x) << CHNENABLE_S)
   2369#define CHNENABLE_F    CHNENABLE_V(1U)
   2370
   2371#define LE_DB_DBGI_CONFIG_A 0x19cf0
   2372
   2373#define DBGICMDBUSY_S    3
   2374#define DBGICMDBUSY_V(x) ((x) << DBGICMDBUSY_S)
   2375#define DBGICMDBUSY_F    DBGICMDBUSY_V(1U)
   2376
   2377#define DBGICMDSTRT_S    2
   2378#define DBGICMDSTRT_V(x) ((x) << DBGICMDSTRT_S)
   2379#define DBGICMDSTRT_F    DBGICMDSTRT_V(1U)
   2380
   2381#define DBGICMDMODE_S    0
   2382#define DBGICMDMODE_M    0x3U
   2383#define DBGICMDMODE_V(x) ((x) << DBGICMDMODE_S)
   2384
   2385#define LE_DB_DBGI_REQ_TCAM_CMD_A 0x19cf4
   2386
   2387#define DBGICMD_S    20
   2388#define DBGICMD_M    0xfU
   2389#define DBGICMD_V(x) ((x) << DBGICMD_S)
   2390
   2391#define DBGITID_S    0
   2392#define DBGITID_M    0xfffffU
   2393#define DBGITID_V(x) ((x) << DBGITID_S)
   2394
   2395#define LE_DB_DBGI_REQ_DATA_A 0x19d00
   2396#define LE_DB_DBGI_RSP_STATUS_A 0x19d94
   2397
   2398#define LE_DB_DBGI_RSP_DATA_A 0x19da0
   2399
   2400#define PRTENABLE_S    29
   2401#define PRTENABLE_V(x) ((x) << PRTENABLE_S)
   2402#define PRTENABLE_F    PRTENABLE_V(1U)
   2403
   2404#define UDPFOURTUPEN_S    28
   2405#define UDPFOURTUPEN_V(x) ((x) << UDPFOURTUPEN_S)
   2406#define UDPFOURTUPEN_F    UDPFOURTUPEN_V(1U)
   2407
   2408#define IP6FOURTUPEN_S    27
   2409#define IP6FOURTUPEN_V(x) ((x) << IP6FOURTUPEN_S)
   2410#define IP6FOURTUPEN_F    IP6FOURTUPEN_V(1U)
   2411
   2412#define IP6TWOTUPEN_S    26
   2413#define IP6TWOTUPEN_V(x) ((x) << IP6TWOTUPEN_S)
   2414#define IP6TWOTUPEN_F    IP6TWOTUPEN_V(1U)
   2415
   2416#define IP4FOURTUPEN_S    25
   2417#define IP4FOURTUPEN_V(x) ((x) << IP4FOURTUPEN_S)
   2418#define IP4FOURTUPEN_F    IP4FOURTUPEN_V(1U)
   2419
   2420#define IP4TWOTUPEN_S    24
   2421#define IP4TWOTUPEN_V(x) ((x) << IP4TWOTUPEN_S)
   2422#define IP4TWOTUPEN_F    IP4TWOTUPEN_V(1U)
   2423
   2424#define IVFWIDTH_S    20
   2425#define IVFWIDTH_M    0xfU
   2426#define IVFWIDTH_V(x) ((x) << IVFWIDTH_S)
   2427#define IVFWIDTH_G(x) (((x) >> IVFWIDTH_S) & IVFWIDTH_M)
   2428
   2429#define CH1DEFAULTQUEUE_S    10
   2430#define CH1DEFAULTQUEUE_M    0x3ffU
   2431#define CH1DEFAULTQUEUE_V(x) ((x) << CH1DEFAULTQUEUE_S)
   2432#define CH1DEFAULTQUEUE_G(x) (((x) >> CH1DEFAULTQUEUE_S) & CH1DEFAULTQUEUE_M)
   2433
   2434#define CH0DEFAULTQUEUE_S    0
   2435#define CH0DEFAULTQUEUE_M    0x3ffU
   2436#define CH0DEFAULTQUEUE_V(x) ((x) << CH0DEFAULTQUEUE_S)
   2437#define CH0DEFAULTQUEUE_G(x) (((x) >> CH0DEFAULTQUEUE_S) & CH0DEFAULTQUEUE_M)
   2438
   2439#define VFLKPIDX_S    8
   2440#define VFLKPIDX_M    0xffU
   2441#define VFLKPIDX_G(x) (((x) >> VFLKPIDX_S) & VFLKPIDX_M)
   2442
   2443#define T6_VFWRADDR_S    8
   2444#define T6_VFWRADDR_M    0xffU
   2445#define T6_VFWRADDR_V(x) ((x) << T6_VFWRADDR_S)
   2446#define T6_VFWRADDR_G(x) (((x) >> T6_VFWRADDR_S) & T6_VFWRADDR_M)
   2447
   2448#define TP_RSS_CONFIG_CNG_A 0x7e04
   2449#define TP_RSS_SECRET_KEY0_A 0x40
   2450#define TP_RSS_PF0_CONFIG_A 0x30
   2451#define TP_RSS_PF_MAP_A 0x38
   2452#define TP_RSS_PF_MSK_A 0x39
   2453
   2454#define PF1LKPIDX_S    3
   2455
   2456#define PF0LKPIDX_M    0x7U
   2457
   2458#define PF1MSKSIZE_S    4
   2459#define PF1MSKSIZE_M    0xfU
   2460
   2461#define CHNCOUNT3_S    31
   2462#define CHNCOUNT3_V(x) ((x) << CHNCOUNT3_S)
   2463#define CHNCOUNT3_F    CHNCOUNT3_V(1U)
   2464
   2465#define CHNCOUNT2_S    30
   2466#define CHNCOUNT2_V(x) ((x) << CHNCOUNT2_S)
   2467#define CHNCOUNT2_F    CHNCOUNT2_V(1U)
   2468
   2469#define CHNCOUNT1_S    29
   2470#define CHNCOUNT1_V(x) ((x) << CHNCOUNT1_S)
   2471#define CHNCOUNT1_F    CHNCOUNT1_V(1U)
   2472
   2473#define CHNCOUNT0_S    28
   2474#define CHNCOUNT0_V(x) ((x) << CHNCOUNT0_S)
   2475#define CHNCOUNT0_F    CHNCOUNT0_V(1U)
   2476
   2477#define CHNUNDFLOW3_S    27
   2478#define CHNUNDFLOW3_V(x) ((x) << CHNUNDFLOW3_S)
   2479#define CHNUNDFLOW3_F    CHNUNDFLOW3_V(1U)
   2480
   2481#define CHNUNDFLOW2_S    26
   2482#define CHNUNDFLOW2_V(x) ((x) << CHNUNDFLOW2_S)
   2483#define CHNUNDFLOW2_F    CHNUNDFLOW2_V(1U)
   2484
   2485#define CHNUNDFLOW1_S    25
   2486#define CHNUNDFLOW1_V(x) ((x) << CHNUNDFLOW1_S)
   2487#define CHNUNDFLOW1_F    CHNUNDFLOW1_V(1U)
   2488
   2489#define CHNUNDFLOW0_S    24
   2490#define CHNUNDFLOW0_V(x) ((x) << CHNUNDFLOW0_S)
   2491#define CHNUNDFLOW0_F    CHNUNDFLOW0_V(1U)
   2492
   2493#define RSTCHN3_S    19
   2494#define RSTCHN3_V(x) ((x) << RSTCHN3_S)
   2495#define RSTCHN3_F    RSTCHN3_V(1U)
   2496
   2497#define RSTCHN2_S    18
   2498#define RSTCHN2_V(x) ((x) << RSTCHN2_S)
   2499#define RSTCHN2_F    RSTCHN2_V(1U)
   2500
   2501#define RSTCHN1_S    17
   2502#define RSTCHN1_V(x) ((x) << RSTCHN1_S)
   2503#define RSTCHN1_F    RSTCHN1_V(1U)
   2504
   2505#define RSTCHN0_S    16
   2506#define RSTCHN0_V(x) ((x) << RSTCHN0_S)
   2507#define RSTCHN0_F    RSTCHN0_V(1U)
   2508
   2509#define UPDVLD_S    15
   2510#define UPDVLD_V(x) ((x) << UPDVLD_S)
   2511#define UPDVLD_F    UPDVLD_V(1U)
   2512
   2513#define XOFF_S    14
   2514#define XOFF_V(x) ((x) << XOFF_S)
   2515#define XOFF_F    XOFF_V(1U)
   2516
   2517#define UPDCHN3_S    13
   2518#define UPDCHN3_V(x) ((x) << UPDCHN3_S)
   2519#define UPDCHN3_F    UPDCHN3_V(1U)
   2520
   2521#define UPDCHN2_S    12
   2522#define UPDCHN2_V(x) ((x) << UPDCHN2_S)
   2523#define UPDCHN2_F    UPDCHN2_V(1U)
   2524
   2525#define UPDCHN1_S    11
   2526#define UPDCHN1_V(x) ((x) << UPDCHN1_S)
   2527#define UPDCHN1_F    UPDCHN1_V(1U)
   2528
   2529#define UPDCHN0_S    10
   2530#define UPDCHN0_V(x) ((x) << UPDCHN0_S)
   2531#define UPDCHN0_F    UPDCHN0_V(1U)
   2532
   2533#define QUEUE_S    0
   2534#define QUEUE_M    0x3ffU
   2535#define QUEUE_V(x) ((x) << QUEUE_S)
   2536#define QUEUE_G(x) (((x) >> QUEUE_S) & QUEUE_M)
   2537
   2538#define MPS_TRC_INT_CAUSE_A	0x985c
   2539
   2540#define MISCPERR_S    8
   2541#define MISCPERR_V(x) ((x) << MISCPERR_S)
   2542#define MISCPERR_F    MISCPERR_V(1U)
   2543
   2544#define PKTFIFO_S    4
   2545#define PKTFIFO_M    0xfU
   2546#define PKTFIFO_V(x) ((x) << PKTFIFO_S)
   2547
   2548#define FILTMEM_S    0
   2549#define FILTMEM_M    0xfU
   2550#define FILTMEM_V(x) ((x) << FILTMEM_S)
   2551
   2552#define MPS_CLS_INT_CAUSE_A 0xd028
   2553
   2554#define HASHSRAM_S    2
   2555#define HASHSRAM_V(x) ((x) << HASHSRAM_S)
   2556#define HASHSRAM_F    HASHSRAM_V(1U)
   2557
   2558#define MATCHTCAM_S    1
   2559#define MATCHTCAM_V(x) ((x) << MATCHTCAM_S)
   2560#define MATCHTCAM_F    MATCHTCAM_V(1U)
   2561
   2562#define MATCHSRAM_S    0
   2563#define MATCHSRAM_V(x) ((x) << MATCHSRAM_S)
   2564#define MATCHSRAM_F    MATCHSRAM_V(1U)
   2565
   2566#define MPS_RX_PG_RSV0_A 0x11010
   2567#define MPS_RX_PG_RSV4_A 0x11020
   2568#define MPS_RX_PERR_INT_CAUSE_A 0x11074
   2569#define MPS_RX_MAC_BG_PG_CNT0_A 0x11208
   2570#define MPS_RX_LPBK_BG_PG_CNT0_A 0x11218
   2571
   2572#define MPS_RX_VXLAN_TYPE_A 0x11234
   2573
   2574#define VXLAN_EN_S    16
   2575#define VXLAN_EN_V(x) ((x) << VXLAN_EN_S)
   2576#define VXLAN_EN_F    VXLAN_EN_V(1U)
   2577
   2578#define VXLAN_S    0
   2579#define VXLAN_M    0xffffU
   2580#define VXLAN_V(x) ((x) << VXLAN_S)
   2581#define VXLAN_G(x) (((x) >> VXLAN_S) & VXLAN_M)
   2582
   2583#define MPS_RX_GENEVE_TYPE_A 0x11238
   2584
   2585#define GENEVE_EN_S    16
   2586#define GENEVE_EN_V(x) ((x) << GENEVE_EN_S)
   2587#define GENEVE_EN_F    GENEVE_EN_V(1U)
   2588
   2589#define GENEVE_S    0
   2590#define GENEVE_M    0xffffU
   2591#define GENEVE_V(x) ((x) << GENEVE_S)
   2592#define GENEVE_G(x) (((x) >> GENEVE_S) & GENEVE_M)
   2593
   2594#define MPS_CLS_TCAM_Y_L_A 0xf000
   2595#define MPS_CLS_TCAM_DATA0_A 0xf000
   2596#define MPS_CLS_TCAM_DATA1_A 0xf004
   2597
   2598#define CTLREQID_S    30
   2599#define CTLREQID_V(x) ((x) << CTLREQID_S)
   2600
   2601#define MPS_VF_RPLCT_MAP0_A 0x1111c
   2602#define MPS_VF_RPLCT_MAP1_A 0x11120
   2603#define MPS_VF_RPLCT_MAP2_A 0x11124
   2604#define MPS_VF_RPLCT_MAP3_A 0x11128
   2605#define MPS_VF_RPLCT_MAP4_A 0x11300
   2606#define MPS_VF_RPLCT_MAP5_A 0x11304
   2607#define MPS_VF_RPLCT_MAP6_A 0x11308
   2608#define MPS_VF_RPLCT_MAP7_A 0x1130c
   2609
   2610#define VIDL_S    16
   2611#define VIDL_M    0xffffU
   2612#define VIDL_G(x) (((x) >> VIDL_S) & VIDL_M)
   2613
   2614#define DATALKPTYPE_S    10
   2615#define DATALKPTYPE_M    0x3U
   2616#define DATALKPTYPE_G(x) (((x) >> DATALKPTYPE_S) & DATALKPTYPE_M)
   2617
   2618#define DATAPORTNUM_S    12
   2619#define DATAPORTNUM_M    0xfU
   2620#define DATAPORTNUM_V(x) ((x) << DATAPORTNUM_S)
   2621#define DATAPORTNUM_G(x) (((x) >> DATAPORTNUM_S) & DATAPORTNUM_M)
   2622
   2623#define DATALKPTYPE_S    10
   2624#define DATALKPTYPE_M    0x3U
   2625#define DATALKPTYPE_V(x) ((x) << DATALKPTYPE_S)
   2626#define DATALKPTYPE_G(x) (((x) >> DATALKPTYPE_S) & DATALKPTYPE_M)
   2627
   2628#define DATADIPHIT_S    8
   2629#define DATADIPHIT_V(x) ((x) << DATADIPHIT_S)
   2630#define DATADIPHIT_F    DATADIPHIT_V(1U)
   2631
   2632#define DATAVIDH2_S    7
   2633#define DATAVIDH2_V(x) ((x) << DATAVIDH2_S)
   2634#define DATAVIDH2_F    DATAVIDH2_V(1U)
   2635
   2636#define DATAVIDH1_S    0
   2637#define DATAVIDH1_M    0x7fU
   2638#define DATAVIDH1_G(x) (((x) >> DATAVIDH1_S) & DATAVIDH1_M)
   2639
   2640#define MPS_CLS_TCAM_RDATA0_REQ_ID1_A 0xf020
   2641#define MPS_CLS_TCAM_RDATA1_REQ_ID1_A 0xf024
   2642#define MPS_CLS_TCAM_RDATA2_REQ_ID1_A 0xf028
   2643
   2644#define USED_S    16
   2645#define USED_M    0x7ffU
   2646#define USED_G(x) (((x) >> USED_S) & USED_M)
   2647
   2648#define ALLOC_S    0
   2649#define ALLOC_M    0x7ffU
   2650#define ALLOC_G(x) (((x) >> ALLOC_S) & ALLOC_M)
   2651
   2652#define T5_USED_S    16
   2653#define T5_USED_M    0xfffU
   2654#define T5_USED_G(x) (((x) >> T5_USED_S) & T5_USED_M)
   2655
   2656#define T5_ALLOC_S    0
   2657#define T5_ALLOC_M    0xfffU
   2658#define T5_ALLOC_G(x) (((x) >> T5_ALLOC_S) & T5_ALLOC_M)
   2659
   2660#define DMACH_S    0
   2661#define DMACH_M    0xffffU
   2662#define DMACH_G(x) (((x) >> DMACH_S) & DMACH_M)
   2663
   2664#define MPS_CLS_TCAM_X_L_A 0xf008
   2665#define MPS_CLS_TCAM_DATA2_CTL_A 0xf008
   2666
   2667#define CTLCMDTYPE_S    31
   2668#define CTLCMDTYPE_V(x) ((x) << CTLCMDTYPE_S)
   2669#define CTLCMDTYPE_F    CTLCMDTYPE_V(1U)
   2670
   2671#define CTLTCAMSEL_S    25
   2672#define CTLTCAMSEL_V(x) ((x) << CTLTCAMSEL_S)
   2673
   2674#define CTLTCAMINDEX_S    17
   2675#define CTLTCAMINDEX_V(x) ((x) << CTLTCAMINDEX_S)
   2676
   2677#define CTLXYBITSEL_S    16
   2678#define CTLXYBITSEL_V(x) ((x) << CTLXYBITSEL_S)
   2679
   2680#define MPS_CLS_TCAM_Y_L(idx) (MPS_CLS_TCAM_Y_L_A + (idx) * 16)
   2681#define NUM_MPS_CLS_TCAM_Y_L_INSTANCES 512
   2682
   2683#define MPS_CLS_TCAM_X_L(idx) (MPS_CLS_TCAM_X_L_A + (idx) * 16)
   2684#define NUM_MPS_CLS_TCAM_X_L_INSTANCES 512
   2685
   2686#define MPS_CLS_SRAM_L_A 0xe000
   2687
   2688#define T6_MULTILISTEN0_S    26
   2689
   2690#define T6_SRAM_PRIO3_S    23
   2691#define T6_SRAM_PRIO3_M    0x7U
   2692#define T6_SRAM_PRIO3_G(x) (((x) >> T6_SRAM_PRIO3_S) & T6_SRAM_PRIO3_M)
   2693
   2694#define T6_SRAM_PRIO2_S    20
   2695#define T6_SRAM_PRIO2_M    0x7U
   2696#define T6_SRAM_PRIO2_G(x) (((x) >> T6_SRAM_PRIO2_S) & T6_SRAM_PRIO2_M)
   2697
   2698#define T6_SRAM_PRIO1_S    17
   2699#define T6_SRAM_PRIO1_M    0x7U
   2700#define T6_SRAM_PRIO1_G(x) (((x) >> T6_SRAM_PRIO1_S) & T6_SRAM_PRIO1_M)
   2701
   2702#define T6_SRAM_PRIO0_S    14
   2703#define T6_SRAM_PRIO0_M    0x7U
   2704#define T6_SRAM_PRIO0_G(x) (((x) >> T6_SRAM_PRIO0_S) & T6_SRAM_PRIO0_M)
   2705
   2706#define T6_SRAM_VLD_S    13
   2707#define T6_SRAM_VLD_V(x) ((x) << T6_SRAM_VLD_S)
   2708#define T6_SRAM_VLD_F    T6_SRAM_VLD_V(1U)
   2709
   2710#define T6_REPLICATE_S    12
   2711#define T6_REPLICATE_V(x) ((x) << T6_REPLICATE_S)
   2712#define T6_REPLICATE_F    T6_REPLICATE_V(1U)
   2713
   2714#define T6_PF_S    9
   2715#define T6_PF_M    0x7U
   2716#define T6_PF_G(x) (((x) >> T6_PF_S) & T6_PF_M)
   2717
   2718#define T6_VF_VALID_S    8
   2719#define T6_VF_VALID_V(x) ((x) << T6_VF_VALID_S)
   2720#define T6_VF_VALID_F    T6_VF_VALID_V(1U)
   2721
   2722#define T6_VF_S    0
   2723#define T6_VF_M    0xffU
   2724#define T6_VF_G(x) (((x) >> T6_VF_S) & T6_VF_M)
   2725
   2726#define MPS_CLS_SRAM_H_A 0xe004
   2727
   2728#define MPS_CLS_SRAM_L(idx) (MPS_CLS_SRAM_L_A + (idx) * 8)
   2729#define NUM_MPS_CLS_SRAM_L_INSTANCES 336
   2730
   2731#define MPS_CLS_SRAM_H(idx) (MPS_CLS_SRAM_H_A + (idx) * 8)
   2732#define NUM_MPS_CLS_SRAM_H_INSTANCES 336
   2733
   2734#define MULTILISTEN0_S    25
   2735
   2736#define REPLICATE_S    11
   2737#define REPLICATE_V(x) ((x) << REPLICATE_S)
   2738#define REPLICATE_F    REPLICATE_V(1U)
   2739
   2740#define PF_S    8
   2741#define PF_M    0x7U
   2742#define PF_G(x) (((x) >> PF_S) & PF_M)
   2743
   2744#define VF_VALID_S    7
   2745#define VF_VALID_V(x) ((x) << VF_VALID_S)
   2746#define VF_VALID_F    VF_VALID_V(1U)
   2747
   2748#define VF_S    0
   2749#define VF_M    0x7fU
   2750#define VF_G(x) (((x) >> VF_S) & VF_M)
   2751
   2752#define SRAM_PRIO3_S    22
   2753#define SRAM_PRIO3_M    0x7U
   2754#define SRAM_PRIO3_G(x) (((x) >> SRAM_PRIO3_S) & SRAM_PRIO3_M)
   2755
   2756#define SRAM_PRIO2_S    19
   2757#define SRAM_PRIO2_M    0x7U
   2758#define SRAM_PRIO2_G(x) (((x) >> SRAM_PRIO2_S) & SRAM_PRIO2_M)
   2759
   2760#define SRAM_PRIO1_S    16
   2761#define SRAM_PRIO1_M    0x7U
   2762#define SRAM_PRIO1_G(x) (((x) >> SRAM_PRIO1_S) & SRAM_PRIO1_M)
   2763
   2764#define SRAM_PRIO0_S    13
   2765#define SRAM_PRIO0_M    0x7U
   2766#define SRAM_PRIO0_G(x) (((x) >> SRAM_PRIO0_S) & SRAM_PRIO0_M)
   2767
   2768#define SRAM_VLD_S    12
   2769#define SRAM_VLD_V(x) ((x) << SRAM_VLD_S)
   2770#define SRAM_VLD_F    SRAM_VLD_V(1U)
   2771
   2772#define PORTMAP_S    0
   2773#define PORTMAP_M    0xfU
   2774#define PORTMAP_G(x) (((x) >> PORTMAP_S) & PORTMAP_M)
   2775
   2776#define CPL_INTR_CAUSE_A 0x19054
   2777
   2778#define CIM_OP_MAP_PERR_S    5
   2779#define CIM_OP_MAP_PERR_V(x) ((x) << CIM_OP_MAP_PERR_S)
   2780#define CIM_OP_MAP_PERR_F    CIM_OP_MAP_PERR_V(1U)
   2781
   2782#define CIM_OVFL_ERROR_S    4
   2783#define CIM_OVFL_ERROR_V(x) ((x) << CIM_OVFL_ERROR_S)
   2784#define CIM_OVFL_ERROR_F    CIM_OVFL_ERROR_V(1U)
   2785
   2786#define TP_FRAMING_ERROR_S    3
   2787#define TP_FRAMING_ERROR_V(x) ((x) << TP_FRAMING_ERROR_S)
   2788#define TP_FRAMING_ERROR_F    TP_FRAMING_ERROR_V(1U)
   2789
   2790#define SGE_FRAMING_ERROR_S    2
   2791#define SGE_FRAMING_ERROR_V(x) ((x) << SGE_FRAMING_ERROR_S)
   2792#define SGE_FRAMING_ERROR_F    SGE_FRAMING_ERROR_V(1U)
   2793
   2794#define CIM_FRAMING_ERROR_S    1
   2795#define CIM_FRAMING_ERROR_V(x) ((x) << CIM_FRAMING_ERROR_S)
   2796#define CIM_FRAMING_ERROR_F    CIM_FRAMING_ERROR_V(1U)
   2797
   2798#define ZERO_SWITCH_ERROR_S    0
   2799#define ZERO_SWITCH_ERROR_V(x) ((x) << ZERO_SWITCH_ERROR_S)
   2800#define ZERO_SWITCH_ERROR_F    ZERO_SWITCH_ERROR_V(1U)
   2801
   2802#define SMB_INT_CAUSE_A 0x19090
   2803
   2804#define MSTTXFIFOPARINT_S    21
   2805#define MSTTXFIFOPARINT_V(x) ((x) << MSTTXFIFOPARINT_S)
   2806#define MSTTXFIFOPARINT_F    MSTTXFIFOPARINT_V(1U)
   2807
   2808#define MSTRXFIFOPARINT_S    20
   2809#define MSTRXFIFOPARINT_V(x) ((x) << MSTRXFIFOPARINT_S)
   2810#define MSTRXFIFOPARINT_F    MSTRXFIFOPARINT_V(1U)
   2811
   2812#define SLVFIFOPARINT_S    19
   2813#define SLVFIFOPARINT_V(x) ((x) << SLVFIFOPARINT_S)
   2814#define SLVFIFOPARINT_F    SLVFIFOPARINT_V(1U)
   2815
   2816#define ULP_RX_INT_CAUSE_A 0x19158
   2817#define ULP_RX_ISCSI_LLIMIT_A 0x1915c
   2818#define ULP_RX_ISCSI_ULIMIT_A 0x19160
   2819#define ULP_RX_ISCSI_TAGMASK_A 0x19164
   2820#define ULP_RX_ISCSI_PSZ_A 0x19168
   2821#define ULP_RX_TDDP_LLIMIT_A 0x1916c
   2822#define ULP_RX_TDDP_ULIMIT_A 0x19170
   2823#define ULP_RX_STAG_LLIMIT_A 0x1917c
   2824#define ULP_RX_STAG_ULIMIT_A 0x19180
   2825#define ULP_RX_RQ_LLIMIT_A 0x19184
   2826#define ULP_RX_RQ_ULIMIT_A 0x19188
   2827#define ULP_RX_PBL_LLIMIT_A 0x1918c
   2828#define ULP_RX_PBL_ULIMIT_A 0x19190
   2829#define ULP_RX_CTX_BASE_A 0x19194
   2830#define ULP_RX_RQUDP_LLIMIT_A 0x191a4
   2831#define ULP_RX_RQUDP_ULIMIT_A 0x191a8
   2832#define ULP_RX_LA_CTL_A 0x1923c
   2833#define ULP_RX_LA_RDPTR_A 0x19240
   2834#define ULP_RX_LA_RDDATA_A 0x19244
   2835#define ULP_RX_LA_WRPTR_A 0x19248
   2836#define ULP_RX_TLS_KEY_LLIMIT_A 0x192ac
   2837#define ULP_RX_TLS_KEY_ULIMIT_A 0x192b0
   2838
   2839#define HPZ3_S    24
   2840#define HPZ3_V(x) ((x) << HPZ3_S)
   2841
   2842#define HPZ2_S    16
   2843#define HPZ2_V(x) ((x) << HPZ2_S)
   2844
   2845#define HPZ1_S    8
   2846#define HPZ1_V(x) ((x) << HPZ1_S)
   2847
   2848#define HPZ0_S    0
   2849#define HPZ0_V(x) ((x) << HPZ0_S)
   2850
   2851#define ULP_RX_TDDP_PSZ_A 0x19178
   2852
   2853/* registers for module SF */
   2854#define SF_DATA_A 0x193f8
   2855#define SF_OP_A 0x193fc
   2856
   2857#define SF_BUSY_S    31
   2858#define SF_BUSY_V(x) ((x) << SF_BUSY_S)
   2859#define SF_BUSY_F    SF_BUSY_V(1U)
   2860
   2861#define SF_LOCK_S    4
   2862#define SF_LOCK_V(x) ((x) << SF_LOCK_S)
   2863#define SF_LOCK_F    SF_LOCK_V(1U)
   2864
   2865#define SF_CONT_S    3
   2866#define SF_CONT_V(x) ((x) << SF_CONT_S)
   2867#define SF_CONT_F    SF_CONT_V(1U)
   2868
   2869#define BYTECNT_S    1
   2870#define BYTECNT_V(x) ((x) << BYTECNT_S)
   2871
   2872#define OP_S    0
   2873#define OP_V(x) ((x) << OP_S)
   2874#define OP_F    OP_V(1U)
   2875
   2876#define PL_PF_INT_CAUSE_A 0x3c0
   2877
   2878#define PFSW_S    3
   2879#define PFSW_V(x) ((x) << PFSW_S)
   2880#define PFSW_F    PFSW_V(1U)
   2881
   2882#define PFCIM_S    1
   2883#define PFCIM_V(x) ((x) << PFCIM_S)
   2884#define PFCIM_F    PFCIM_V(1U)
   2885
   2886#define PL_PF_INT_ENABLE_A 0x3c4
   2887#define PL_PF_CTL_A 0x3c8
   2888
   2889#define PL_WHOAMI_A 0x19400
   2890
   2891#define SOURCEPF_S    8
   2892#define SOURCEPF_M    0x7U
   2893#define SOURCEPF_G(x) (((x) >> SOURCEPF_S) & SOURCEPF_M)
   2894
   2895#define T6_SOURCEPF_S    9
   2896#define T6_SOURCEPF_M    0x7U
   2897#define T6_SOURCEPF_G(x) (((x) >> T6_SOURCEPF_S) & T6_SOURCEPF_M)
   2898
   2899#define PL_INT_CAUSE_A 0x1940c
   2900
   2901#define ULP_TX_S    27
   2902#define ULP_TX_V(x) ((x) << ULP_TX_S)
   2903#define ULP_TX_F    ULP_TX_V(1U)
   2904
   2905#define SGE_S    26
   2906#define SGE_V(x) ((x) << SGE_S)
   2907#define SGE_F    SGE_V(1U)
   2908
   2909#define CPL_SWITCH_S    24
   2910#define CPL_SWITCH_V(x) ((x) << CPL_SWITCH_S)
   2911#define CPL_SWITCH_F    CPL_SWITCH_V(1U)
   2912
   2913#define ULP_RX_S    23
   2914#define ULP_RX_V(x) ((x) << ULP_RX_S)
   2915#define ULP_RX_F    ULP_RX_V(1U)
   2916
   2917#define PM_RX_S    22
   2918#define PM_RX_V(x) ((x) << PM_RX_S)
   2919#define PM_RX_F    PM_RX_V(1U)
   2920
   2921#define PM_TX_S    21
   2922#define PM_TX_V(x) ((x) << PM_TX_S)
   2923#define PM_TX_F    PM_TX_V(1U)
   2924
   2925#define MA_S    20
   2926#define MA_V(x) ((x) << MA_S)
   2927#define MA_F    MA_V(1U)
   2928
   2929#define TP_S    19
   2930#define TP_V(x) ((x) << TP_S)
   2931#define TP_F    TP_V(1U)
   2932
   2933#define LE_S    18
   2934#define LE_V(x) ((x) << LE_S)
   2935#define LE_F    LE_V(1U)
   2936
   2937#define EDC1_S    17
   2938#define EDC1_V(x) ((x) << EDC1_S)
   2939#define EDC1_F    EDC1_V(1U)
   2940
   2941#define EDC0_S    16
   2942#define EDC0_V(x) ((x) << EDC0_S)
   2943#define EDC0_F    EDC0_V(1U)
   2944
   2945#define MC_S    15
   2946#define MC_V(x) ((x) << MC_S)
   2947#define MC_F    MC_V(1U)
   2948
   2949#define PCIE_S    14
   2950#define PCIE_V(x) ((x) << PCIE_S)
   2951#define PCIE_F    PCIE_V(1U)
   2952
   2953#define XGMAC_KR1_S    12
   2954#define XGMAC_KR1_V(x) ((x) << XGMAC_KR1_S)
   2955#define XGMAC_KR1_F    XGMAC_KR1_V(1U)
   2956
   2957#define XGMAC_KR0_S    11
   2958#define XGMAC_KR0_V(x) ((x) << XGMAC_KR0_S)
   2959#define XGMAC_KR0_F    XGMAC_KR0_V(1U)
   2960
   2961#define XGMAC1_S    10
   2962#define XGMAC1_V(x) ((x) << XGMAC1_S)
   2963#define XGMAC1_F    XGMAC1_V(1U)
   2964
   2965#define XGMAC0_S    9
   2966#define XGMAC0_V(x) ((x) << XGMAC0_S)
   2967#define XGMAC0_F    XGMAC0_V(1U)
   2968
   2969#define SMB_S    8
   2970#define SMB_V(x) ((x) << SMB_S)
   2971#define SMB_F    SMB_V(1U)
   2972
   2973#define SF_S    7
   2974#define SF_V(x) ((x) << SF_S)
   2975#define SF_F    SF_V(1U)
   2976
   2977#define PL_S    6
   2978#define PL_V(x) ((x) << PL_S)
   2979#define PL_F    PL_V(1U)
   2980
   2981#define NCSI_S    5
   2982#define NCSI_V(x) ((x) << NCSI_S)
   2983#define NCSI_F    NCSI_V(1U)
   2984
   2985#define MPS_S    4
   2986#define MPS_V(x) ((x) << MPS_S)
   2987#define MPS_F    MPS_V(1U)
   2988
   2989#define CIM_S    0
   2990#define CIM_V(x) ((x) << CIM_S)
   2991#define CIM_F    CIM_V(1U)
   2992
   2993#define MC1_S    31
   2994#define MC1_V(x) ((x) << MC1_S)
   2995#define MC1_F    MC1_V(1U)
   2996
   2997#define PL_INT_ENABLE_A 0x19410
   2998#define PL_INT_MAP0_A 0x19414
   2999#define PL_RST_A 0x19428
   3000
   3001#define PIORST_S    1
   3002#define PIORST_V(x) ((x) << PIORST_S)
   3003#define PIORST_F    PIORST_V(1U)
   3004
   3005#define PIORSTMODE_S    0
   3006#define PIORSTMODE_V(x) ((x) << PIORSTMODE_S)
   3007#define PIORSTMODE_F    PIORSTMODE_V(1U)
   3008
   3009#define PL_PL_INT_CAUSE_A 0x19430
   3010
   3011#define FATALPERR_S    4
   3012#define FATALPERR_V(x) ((x) << FATALPERR_S)
   3013#define FATALPERR_F    FATALPERR_V(1U)
   3014
   3015#define PERRVFID_S    0
   3016#define PERRVFID_V(x) ((x) << PERRVFID_S)
   3017#define PERRVFID_F    PERRVFID_V(1U)
   3018
   3019#define PL_REV_A 0x1943c
   3020
   3021#define REV_S    0
   3022#define REV_M    0xfU
   3023#define REV_V(x) ((x) << REV_S)
   3024#define REV_G(x) (((x) >> REV_S) & REV_M)
   3025
   3026#define HASHTBLMEMCRCERR_S    27
   3027#define HASHTBLMEMCRCERR_V(x) ((x) << HASHTBLMEMCRCERR_S)
   3028#define HASHTBLMEMCRCERR_F    HASHTBLMEMCRCERR_V(1U)
   3029
   3030#define CMDTIDERR_S    22
   3031#define CMDTIDERR_V(x) ((x) << CMDTIDERR_S)
   3032#define CMDTIDERR_F    CMDTIDERR_V(1U)
   3033
   3034#define T6_UNKNOWNCMD_S    3
   3035#define T6_UNKNOWNCMD_V(x) ((x) << T6_UNKNOWNCMD_S)
   3036#define T6_UNKNOWNCMD_F    T6_UNKNOWNCMD_V(1U)
   3037
   3038#define T6_LIP0_S    2
   3039#define T6_LIP0_V(x) ((x) << T6_LIP0_S)
   3040#define T6_LIP0_F    T6_LIP0_V(1U)
   3041
   3042#define T6_LIPMISS_S    1
   3043#define T6_LIPMISS_V(x) ((x) << T6_LIPMISS_S)
   3044#define T6_LIPMISS_F    T6_LIPMISS_V(1U)
   3045
   3046#define LE_DB_CONFIG_A 0x19c04
   3047#define LE_DB_ROUTING_TABLE_INDEX_A 0x19c10
   3048#define LE_DB_ACTIVE_TABLE_START_INDEX_A 0x19c10
   3049#define LE_DB_FILTER_TABLE_INDEX_A 0x19c14
   3050#define LE_DB_SERVER_INDEX_A 0x19c18
   3051#define LE_DB_SRVR_START_INDEX_A 0x19c18
   3052#define LE_DB_CLIP_TABLE_INDEX_A 0x19c1c
   3053#define LE_DB_ACT_CNT_IPV4_A 0x19c20
   3054#define LE_DB_ACT_CNT_IPV6_A 0x19c24
   3055#define LE_DB_HASH_CONFIG_A 0x19c28
   3056
   3057#define HASHTIDSIZE_S    16
   3058#define HASHTIDSIZE_M    0x3fU
   3059#define HASHTIDSIZE_G(x) (((x) >> HASHTIDSIZE_S) & HASHTIDSIZE_M)
   3060
   3061#define HASHTBLSIZE_S    3
   3062#define HASHTBLSIZE_M    0x1ffffU
   3063#define HASHTBLSIZE_G(x) (((x) >> HASHTBLSIZE_S) & HASHTBLSIZE_M)
   3064
   3065#define LE_DB_HASH_TID_BASE_A 0x19c30
   3066#define LE_DB_HASH_TBL_BASE_ADDR_A 0x19c30
   3067#define LE_DB_INT_CAUSE_A 0x19c3c
   3068#define LE_DB_CLCAM_TID_BASE_A 0x19df4
   3069#define LE_DB_TID_HASHBASE_A 0x19df8
   3070#define T6_LE_DB_HASH_TID_BASE_A 0x19df8
   3071
   3072#define HASHEN_S    20
   3073#define HASHEN_V(x) ((x) << HASHEN_S)
   3074#define HASHEN_F    HASHEN_V(1U)
   3075
   3076#define ASLIPCOMPEN_S    17
   3077#define ASLIPCOMPEN_V(x) ((x) << ASLIPCOMPEN_S)
   3078#define ASLIPCOMPEN_F    ASLIPCOMPEN_V(1U)
   3079
   3080#define REQQPARERR_S    16
   3081#define REQQPARERR_V(x) ((x) << REQQPARERR_S)
   3082#define REQQPARERR_F    REQQPARERR_V(1U)
   3083
   3084#define UNKNOWNCMD_S    15
   3085#define UNKNOWNCMD_V(x) ((x) << UNKNOWNCMD_S)
   3086#define UNKNOWNCMD_F    UNKNOWNCMD_V(1U)
   3087
   3088#define PARITYERR_S    6
   3089#define PARITYERR_V(x) ((x) << PARITYERR_S)
   3090#define PARITYERR_F    PARITYERR_V(1U)
   3091
   3092#define LIPMISS_S    5
   3093#define LIPMISS_V(x) ((x) << LIPMISS_S)
   3094#define LIPMISS_F    LIPMISS_V(1U)
   3095
   3096#define LIP0_S    4
   3097#define LIP0_V(x) ((x) << LIP0_S)
   3098#define LIP0_F    LIP0_V(1U)
   3099
   3100#define BASEADDR_S    3
   3101#define BASEADDR_M    0x1fffffffU
   3102#define BASEADDR_G(x) (((x) >> BASEADDR_S) & BASEADDR_M)
   3103
   3104#define TCAMINTPERR_S    13
   3105#define TCAMINTPERR_V(x) ((x) << TCAMINTPERR_S)
   3106#define TCAMINTPERR_F    TCAMINTPERR_V(1U)
   3107
   3108#define SSRAMINTPERR_S    10
   3109#define SSRAMINTPERR_V(x) ((x) << SSRAMINTPERR_S)
   3110#define SSRAMINTPERR_F    SSRAMINTPERR_V(1U)
   3111
   3112#define LE_DB_RSP_CODE_0_A	0x19c74
   3113
   3114#define TCAM_ACTV_HIT_S		0
   3115#define TCAM_ACTV_HIT_M		0x1fU
   3116#define TCAM_ACTV_HIT_V(x)	((x) << TCAM_ACTV_HIT_S)
   3117#define TCAM_ACTV_HIT_G(x)	(((x) >> TCAM_ACTV_HIT_S) & TCAM_ACTV_HIT_M)
   3118
   3119#define LE_DB_RSP_CODE_1_A     0x19c78
   3120
   3121#define HASH_ACTV_HIT_S		25
   3122#define HASH_ACTV_HIT_M		0x1fU
   3123#define HASH_ACTV_HIT_V(x)	((x) << HASH_ACTV_HIT_S)
   3124#define HASH_ACTV_HIT_G(x)	(((x) >> HASH_ACTV_HIT_S) & HASH_ACTV_HIT_M)
   3125
   3126#define LE_3_DB_HASH_MASK_GEN_IPV4_T6_A	0x19eac
   3127#define LE_4_DB_HASH_MASK_GEN_IPV4_T6_A	0x19eb0
   3128
   3129#define NCSI_INT_CAUSE_A 0x1a0d8
   3130
   3131#define CIM_DM_PRTY_ERR_S    8
   3132#define CIM_DM_PRTY_ERR_V(x) ((x) << CIM_DM_PRTY_ERR_S)
   3133#define CIM_DM_PRTY_ERR_F    CIM_DM_PRTY_ERR_V(1U)
   3134
   3135#define MPS_DM_PRTY_ERR_S    7
   3136#define MPS_DM_PRTY_ERR_V(x) ((x) << MPS_DM_PRTY_ERR_S)
   3137#define MPS_DM_PRTY_ERR_F    MPS_DM_PRTY_ERR_V(1U)
   3138
   3139#define TXFIFO_PRTY_ERR_S    1
   3140#define TXFIFO_PRTY_ERR_V(x) ((x) << TXFIFO_PRTY_ERR_S)
   3141#define TXFIFO_PRTY_ERR_F    TXFIFO_PRTY_ERR_V(1U)
   3142
   3143#define RXFIFO_PRTY_ERR_S    0
   3144#define RXFIFO_PRTY_ERR_V(x) ((x) << RXFIFO_PRTY_ERR_S)
   3145#define RXFIFO_PRTY_ERR_F    RXFIFO_PRTY_ERR_V(1U)
   3146
   3147#define XGMAC_PORT_CFG2_A 0x1018
   3148
   3149#define PATEN_S    18
   3150#define PATEN_V(x) ((x) << PATEN_S)
   3151#define PATEN_F    PATEN_V(1U)
   3152
   3153#define MAGICEN_S    17
   3154#define MAGICEN_V(x) ((x) << MAGICEN_S)
   3155#define MAGICEN_F    MAGICEN_V(1U)
   3156
   3157#define XGMAC_PORT_MAGIC_MACID_LO 0x1024
   3158#define XGMAC_PORT_MAGIC_MACID_HI 0x1028
   3159
   3160#define XGMAC_PORT_EPIO_DATA0_A 0x10c0
   3161#define XGMAC_PORT_EPIO_DATA1_A 0x10c4
   3162#define XGMAC_PORT_EPIO_DATA2_A 0x10c8
   3163#define XGMAC_PORT_EPIO_DATA3_A 0x10cc
   3164#define XGMAC_PORT_EPIO_OP_A 0x10d0
   3165
   3166#define EPIOWR_S    8
   3167#define EPIOWR_V(x) ((x) << EPIOWR_S)
   3168#define EPIOWR_F    EPIOWR_V(1U)
   3169
   3170#define ADDRESS_S    0
   3171#define ADDRESS_V(x) ((x) << ADDRESS_S)
   3172
   3173#define MAC_PORT_INT_CAUSE_A 0x8dc
   3174#define XGMAC_PORT_INT_CAUSE_A 0x10dc
   3175
   3176#define TP_TX_MOD_QUEUE_REQ_MAP_A 0x7e28
   3177
   3178#define TP_TX_MOD_QUEUE_WEIGHT0_A 0x7e30
   3179#define TP_TX_MOD_CHANNEL_WEIGHT_A 0x7e34
   3180
   3181#define TX_MOD_QUEUE_REQ_MAP_S    0
   3182#define TX_MOD_QUEUE_REQ_MAP_V(x) ((x) << TX_MOD_QUEUE_REQ_MAP_S)
   3183
   3184#define TX_MODQ_WEIGHT3_S    24
   3185#define TX_MODQ_WEIGHT3_V(x) ((x) << TX_MODQ_WEIGHT3_S)
   3186
   3187#define TX_MODQ_WEIGHT2_S    16
   3188#define TX_MODQ_WEIGHT2_V(x) ((x) << TX_MODQ_WEIGHT2_S)
   3189
   3190#define TX_MODQ_WEIGHT1_S    8
   3191#define TX_MODQ_WEIGHT1_V(x) ((x) << TX_MODQ_WEIGHT1_S)
   3192
   3193#define TX_MODQ_WEIGHT0_S    0
   3194#define TX_MODQ_WEIGHT0_V(x) ((x) << TX_MODQ_WEIGHT0_S)
   3195
   3196#define TP_TX_SCHED_HDR_A 0x23
   3197#define TP_TX_SCHED_FIFO_A 0x24
   3198#define TP_TX_SCHED_PCMD_A 0x25
   3199
   3200#define NUM_MPS_CLS_SRAM_L_INSTANCES 336
   3201#define NUM_MPS_T5_CLS_SRAM_L_INSTANCES 512
   3202
   3203#define T5_PORT0_BASE 0x30000
   3204#define T5_PORT_STRIDE 0x4000
   3205#define T5_PORT_BASE(idx) (T5_PORT0_BASE + (idx) * T5_PORT_STRIDE)
   3206#define T5_PORT_REG(idx, reg) (T5_PORT_BASE(idx) + (reg))
   3207
   3208#define MC_0_BASE_ADDR 0x40000
   3209#define MC_1_BASE_ADDR 0x48000
   3210#define MC_STRIDE (MC_1_BASE_ADDR - MC_0_BASE_ADDR)
   3211#define MC_REG(reg, idx) (reg + MC_STRIDE * idx)
   3212
   3213#define MC_P_BIST_CMD_A			0x41400
   3214#define MC_P_BIST_CMD_ADDR_A		0x41404
   3215#define MC_P_BIST_CMD_LEN_A		0x41408
   3216#define MC_P_BIST_DATA_PATTERN_A	0x4140c
   3217#define MC_P_BIST_STATUS_RDATA_A	0x41488
   3218
   3219#define EDC_T50_BASE_ADDR		0x50000
   3220
   3221#define EDC_H_BIST_CMD_A		0x50004
   3222#define EDC_H_BIST_CMD_ADDR_A		0x50008
   3223#define EDC_H_BIST_CMD_LEN_A		0x5000c
   3224#define EDC_H_BIST_DATA_PATTERN_A	0x50010
   3225#define EDC_H_BIST_STATUS_RDATA_A	0x50028
   3226
   3227#define EDC_H_ECC_ERR_ADDR_A		0x50084
   3228#define EDC_T51_BASE_ADDR		0x50800
   3229
   3230#define EDC_T5_STRIDE (EDC_T51_BASE_ADDR - EDC_T50_BASE_ADDR)
   3231#define EDC_T5_REG(reg, idx) (reg + EDC_T5_STRIDE * idx)
   3232
   3233#define PL_VF_REV_A 0x4
   3234#define PL_VF_WHOAMI_A 0x0
   3235#define PL_VF_REVISION_A 0x8
   3236
   3237/* registers for module CIM */
   3238#define CIM_HOST_ACC_CTRL_A	0x7b50
   3239#define CIM_HOST_ACC_DATA_A	0x7b54
   3240#define UP_UP_DBG_LA_CFG_A	0x140
   3241#define UP_UP_DBG_LA_DATA_A	0x144
   3242
   3243#define HOSTBUSY_S	17
   3244#define HOSTBUSY_V(x)	((x) << HOSTBUSY_S)
   3245#define HOSTBUSY_F	HOSTBUSY_V(1U)
   3246
   3247#define HOSTWRITE_S	16
   3248#define HOSTWRITE_V(x)	((x) << HOSTWRITE_S)
   3249#define HOSTWRITE_F	HOSTWRITE_V(1U)
   3250
   3251#define CIM_IBQ_DBG_CFG_A 0x7b60
   3252
   3253#define IBQDBGADDR_S    16
   3254#define IBQDBGADDR_M    0xfffU
   3255#define IBQDBGADDR_V(x) ((x) << IBQDBGADDR_S)
   3256#define IBQDBGADDR_G(x) (((x) >> IBQDBGADDR_S) & IBQDBGADDR_M)
   3257
   3258#define IBQDBGBUSY_S    1
   3259#define IBQDBGBUSY_V(x) ((x) << IBQDBGBUSY_S)
   3260#define IBQDBGBUSY_F    IBQDBGBUSY_V(1U)
   3261
   3262#define IBQDBGEN_S    0
   3263#define IBQDBGEN_V(x) ((x) << IBQDBGEN_S)
   3264#define IBQDBGEN_F    IBQDBGEN_V(1U)
   3265
   3266#define CIM_OBQ_DBG_CFG_A 0x7b64
   3267
   3268#define OBQDBGADDR_S    16
   3269#define OBQDBGADDR_M    0xfffU
   3270#define OBQDBGADDR_V(x) ((x) << OBQDBGADDR_S)
   3271#define OBQDBGADDR_G(x) (((x) >> OBQDBGADDR_S) & OBQDBGADDR_M)
   3272
   3273#define OBQDBGBUSY_S    1
   3274#define OBQDBGBUSY_V(x) ((x) << OBQDBGBUSY_S)
   3275#define OBQDBGBUSY_F    OBQDBGBUSY_V(1U)
   3276
   3277#define OBQDBGEN_S    0
   3278#define OBQDBGEN_V(x) ((x) << OBQDBGEN_S)
   3279#define OBQDBGEN_F    OBQDBGEN_V(1U)
   3280
   3281#define CIM_IBQ_DBG_DATA_A 0x7b68
   3282#define CIM_OBQ_DBG_DATA_A 0x7b6c
   3283#define CIM_DEBUGCFG_A 0x7b70
   3284#define CIM_DEBUGSTS_A 0x7b74
   3285
   3286#define POLADBGRDPTR_S		23
   3287#define POLADBGRDPTR_M		0x1ffU
   3288#define POLADBGRDPTR_V(x)	((x) << POLADBGRDPTR_S)
   3289
   3290#define POLADBGWRPTR_S		16
   3291#define POLADBGWRPTR_M		0x1ffU
   3292#define POLADBGWRPTR_G(x)	(((x) >> POLADBGWRPTR_S) & POLADBGWRPTR_M)
   3293
   3294#define PILADBGRDPTR_S		14
   3295#define PILADBGRDPTR_M		0x1ffU
   3296#define PILADBGRDPTR_V(x)	((x) << PILADBGRDPTR_S)
   3297
   3298#define PILADBGWRPTR_S		0
   3299#define PILADBGWRPTR_M		0x1ffU
   3300#define PILADBGWRPTR_G(x)	(((x) >> PILADBGWRPTR_S) & PILADBGWRPTR_M)
   3301
   3302#define LADBGEN_S	12
   3303#define LADBGEN_V(x)	((x) << LADBGEN_S)
   3304#define LADBGEN_F	LADBGEN_V(1U)
   3305
   3306#define CIM_PO_LA_DEBUGDATA_A 0x7b78
   3307#define CIM_PI_LA_DEBUGDATA_A 0x7b7c
   3308#define CIM_PO_LA_MADEBUGDATA_A	0x7b80
   3309#define CIM_PI_LA_MADEBUGDATA_A	0x7b84
   3310
   3311#define UPDBGLARDEN_S		1
   3312#define UPDBGLARDEN_V(x)	((x) << UPDBGLARDEN_S)
   3313#define UPDBGLARDEN_F		UPDBGLARDEN_V(1U)
   3314
   3315#define UPDBGLAEN_S	0
   3316#define UPDBGLAEN_V(x)	((x) << UPDBGLAEN_S)
   3317#define UPDBGLAEN_F	UPDBGLAEN_V(1U)
   3318
   3319#define UPDBGLARDPTR_S		2
   3320#define UPDBGLARDPTR_M		0xfffU
   3321#define UPDBGLARDPTR_V(x)	((x) << UPDBGLARDPTR_S)
   3322
   3323#define UPDBGLAWRPTR_S    16
   3324#define UPDBGLAWRPTR_M    0xfffU
   3325#define UPDBGLAWRPTR_G(x) (((x) >> UPDBGLAWRPTR_S) & UPDBGLAWRPTR_M)
   3326
   3327#define UPDBGLACAPTPCONLY_S	30
   3328#define UPDBGLACAPTPCONLY_V(x)	((x) << UPDBGLACAPTPCONLY_S)
   3329#define UPDBGLACAPTPCONLY_F	UPDBGLACAPTPCONLY_V(1U)
   3330
   3331#define CIM_QUEUE_CONFIG_REF_A 0x7b48
   3332#define CIM_QUEUE_CONFIG_CTRL_A 0x7b4c
   3333
   3334#define CIMQSIZE_S    24
   3335#define CIMQSIZE_M    0x3fU
   3336#define CIMQSIZE_G(x) (((x) >> CIMQSIZE_S) & CIMQSIZE_M)
   3337
   3338#define CIMQBASE_S    16
   3339#define CIMQBASE_M    0x3fU
   3340#define CIMQBASE_G(x) (((x) >> CIMQBASE_S) & CIMQBASE_M)
   3341
   3342#define QUEFULLTHRSH_S    0
   3343#define QUEFULLTHRSH_M    0x1ffU
   3344#define QUEFULLTHRSH_G(x) (((x) >> QUEFULLTHRSH_S) & QUEFULLTHRSH_M)
   3345
   3346#define UP_IBQ_0_RDADDR_A 0x10
   3347#define UP_IBQ_0_SHADOW_RDADDR_A 0x280
   3348#define UP_OBQ_0_REALADDR_A 0x104
   3349#define UP_OBQ_0_SHADOW_REALADDR_A 0x394
   3350
   3351#define IBQRDADDR_S    0
   3352#define IBQRDADDR_M    0x1fffU
   3353#define IBQRDADDR_G(x) (((x) >> IBQRDADDR_S) & IBQRDADDR_M)
   3354
   3355#define IBQWRADDR_S    0
   3356#define IBQWRADDR_M    0x1fffU
   3357#define IBQWRADDR_G(x) (((x) >> IBQWRADDR_S) & IBQWRADDR_M)
   3358
   3359#define QUERDADDR_S    0
   3360#define QUERDADDR_M    0x7fffU
   3361#define QUERDADDR_G(x) (((x) >> QUERDADDR_S) & QUERDADDR_M)
   3362
   3363#define QUEREMFLITS_S    0
   3364#define QUEREMFLITS_M    0x7ffU
   3365#define QUEREMFLITS_G(x) (((x) >> QUEREMFLITS_S) & QUEREMFLITS_M)
   3366
   3367#define QUEEOPCNT_S    16
   3368#define QUEEOPCNT_M    0xfffU
   3369#define QUEEOPCNT_G(x) (((x) >> QUEEOPCNT_S) & QUEEOPCNT_M)
   3370
   3371#define QUESOPCNT_S    0
   3372#define QUESOPCNT_M    0xfffU
   3373#define QUESOPCNT_G(x) (((x) >> QUESOPCNT_S) & QUESOPCNT_M)
   3374
   3375#define OBQSELECT_S    4
   3376#define OBQSELECT_V(x) ((x) << OBQSELECT_S)
   3377#define OBQSELECT_F    OBQSELECT_V(1U)
   3378
   3379#define IBQSELECT_S    3
   3380#define IBQSELECT_V(x) ((x) << IBQSELECT_S)
   3381#define IBQSELECT_F    IBQSELECT_V(1U)
   3382
   3383#define QUENUMSELECT_S    0
   3384#define QUENUMSELECT_V(x) ((x) << QUENUMSELECT_S)
   3385
   3386#endif /* __T4_REGS_H */