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

cvmx-pci-defs.h (43270B)


      1/***********************license start***************
      2 * Author: Cavium Networks
      3 *
      4 * Contact: support@caviumnetworks.com
      5 * This file is part of the OCTEON SDK
      6 *
      7 * Copyright (c) 2003-2012 Cavium Networks
      8 *
      9 * This file is free software; you can redistribute it and/or modify
     10 * it under the terms of the GNU General Public License, Version 2, as
     11 * published by the Free Software Foundation.
     12 *
     13 * This file is distributed in the hope that it will be useful, but
     14 * AS-IS and WITHOUT ANY WARRANTY; without even the implied warranty
     15 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, TITLE, or
     16 * NONINFRINGEMENT.  See the GNU General Public License for more
     17 * details.
     18 *
     19 * You should have received a copy of the GNU General Public License
     20 * along with this file; if not, write to the Free Software
     21 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
     22 * or visit http://www.gnu.org/licenses/.
     23 *
     24 * This file may also be available under a different license from Cavium.
     25 * Contact Cavium Networks for more information
     26 ***********************license end**************************************/
     27
     28#ifndef __CVMX_PCI_DEFS_H__
     29#define __CVMX_PCI_DEFS_H__
     30
     31#define CVMX_PCI_BAR1_INDEXX(offset) (0x0000000000000100ull + ((offset) & 31) * 4)
     32#define CVMX_PCI_BIST_REG (0x00000000000001C0ull)
     33#define CVMX_PCI_CFG00 (0x0000000000000000ull)
     34#define CVMX_PCI_CFG01 (0x0000000000000004ull)
     35#define CVMX_PCI_CFG02 (0x0000000000000008ull)
     36#define CVMX_PCI_CFG03 (0x000000000000000Cull)
     37#define CVMX_PCI_CFG04 (0x0000000000000010ull)
     38#define CVMX_PCI_CFG05 (0x0000000000000014ull)
     39#define CVMX_PCI_CFG06 (0x0000000000000018ull)
     40#define CVMX_PCI_CFG07 (0x000000000000001Cull)
     41#define CVMX_PCI_CFG08 (0x0000000000000020ull)
     42#define CVMX_PCI_CFG09 (0x0000000000000024ull)
     43#define CVMX_PCI_CFG10 (0x0000000000000028ull)
     44#define CVMX_PCI_CFG11 (0x000000000000002Cull)
     45#define CVMX_PCI_CFG12 (0x0000000000000030ull)
     46#define CVMX_PCI_CFG13 (0x0000000000000034ull)
     47#define CVMX_PCI_CFG15 (0x000000000000003Cull)
     48#define CVMX_PCI_CFG16 (0x0000000000000040ull)
     49#define CVMX_PCI_CFG17 (0x0000000000000044ull)
     50#define CVMX_PCI_CFG18 (0x0000000000000048ull)
     51#define CVMX_PCI_CFG19 (0x000000000000004Cull)
     52#define CVMX_PCI_CFG20 (0x0000000000000050ull)
     53#define CVMX_PCI_CFG21 (0x0000000000000054ull)
     54#define CVMX_PCI_CFG22 (0x0000000000000058ull)
     55#define CVMX_PCI_CFG56 (0x00000000000000E0ull)
     56#define CVMX_PCI_CFG57 (0x00000000000000E4ull)
     57#define CVMX_PCI_CFG58 (0x00000000000000E8ull)
     58#define CVMX_PCI_CFG59 (0x00000000000000ECull)
     59#define CVMX_PCI_CFG60 (0x00000000000000F0ull)
     60#define CVMX_PCI_CFG61 (0x00000000000000F4ull)
     61#define CVMX_PCI_CFG62 (0x00000000000000F8ull)
     62#define CVMX_PCI_CFG63 (0x00000000000000FCull)
     63#define CVMX_PCI_CNT_REG (0x00000000000001B8ull)
     64#define CVMX_PCI_CTL_STATUS_2 (0x000000000000018Cull)
     65#define CVMX_PCI_DBELL_X(offset) (0x0000000000000080ull + ((offset) & 3) * 8)
     66#define CVMX_PCI_DMA_CNT0 CVMX_PCI_DMA_CNTX(0)
     67#define CVMX_PCI_DMA_CNT1 CVMX_PCI_DMA_CNTX(1)
     68#define CVMX_PCI_DMA_CNTX(offset) (0x00000000000000A0ull + ((offset) & 1) * 8)
     69#define CVMX_PCI_DMA_INT_LEV0 CVMX_PCI_DMA_INT_LEVX(0)
     70#define CVMX_PCI_DMA_INT_LEV1 CVMX_PCI_DMA_INT_LEVX(1)
     71#define CVMX_PCI_DMA_INT_LEVX(offset) (0x00000000000000A4ull + ((offset) & 1) * 8)
     72#define CVMX_PCI_DMA_TIME0 CVMX_PCI_DMA_TIMEX(0)
     73#define CVMX_PCI_DMA_TIME1 CVMX_PCI_DMA_TIMEX(1)
     74#define CVMX_PCI_DMA_TIMEX(offset) (0x00000000000000B0ull + ((offset) & 1) * 4)
     75#define CVMX_PCI_INSTR_COUNT0 CVMX_PCI_INSTR_COUNTX(0)
     76#define CVMX_PCI_INSTR_COUNT1 CVMX_PCI_INSTR_COUNTX(1)
     77#define CVMX_PCI_INSTR_COUNT2 CVMX_PCI_INSTR_COUNTX(2)
     78#define CVMX_PCI_INSTR_COUNT3 CVMX_PCI_INSTR_COUNTX(3)
     79#define CVMX_PCI_INSTR_COUNTX(offset) (0x0000000000000084ull + ((offset) & 3) * 8)
     80#define CVMX_PCI_INT_ENB (0x0000000000000038ull)
     81#define CVMX_PCI_INT_ENB2 (0x00000000000001A0ull)
     82#define CVMX_PCI_INT_SUM (0x0000000000000030ull)
     83#define CVMX_PCI_INT_SUM2 (0x0000000000000198ull)
     84#define CVMX_PCI_MSI_RCV (0x00000000000000F0ull)
     85#define CVMX_PCI_PKTS_SENT0 CVMX_PCI_PKTS_SENTX(0)
     86#define CVMX_PCI_PKTS_SENT1 CVMX_PCI_PKTS_SENTX(1)
     87#define CVMX_PCI_PKTS_SENT2 CVMX_PCI_PKTS_SENTX(2)
     88#define CVMX_PCI_PKTS_SENT3 CVMX_PCI_PKTS_SENTX(3)
     89#define CVMX_PCI_PKTS_SENTX(offset) (0x0000000000000040ull + ((offset) & 3) * 16)
     90#define CVMX_PCI_PKTS_SENT_INT_LEV0 CVMX_PCI_PKTS_SENT_INT_LEVX(0)
     91#define CVMX_PCI_PKTS_SENT_INT_LEV1 CVMX_PCI_PKTS_SENT_INT_LEVX(1)
     92#define CVMX_PCI_PKTS_SENT_INT_LEV2 CVMX_PCI_PKTS_SENT_INT_LEVX(2)
     93#define CVMX_PCI_PKTS_SENT_INT_LEV3 CVMX_PCI_PKTS_SENT_INT_LEVX(3)
     94#define CVMX_PCI_PKTS_SENT_INT_LEVX(offset) (0x0000000000000048ull + ((offset) & 3) * 16)
     95#define CVMX_PCI_PKTS_SENT_TIME0 CVMX_PCI_PKTS_SENT_TIMEX(0)
     96#define CVMX_PCI_PKTS_SENT_TIME1 CVMX_PCI_PKTS_SENT_TIMEX(1)
     97#define CVMX_PCI_PKTS_SENT_TIME2 CVMX_PCI_PKTS_SENT_TIMEX(2)
     98#define CVMX_PCI_PKTS_SENT_TIME3 CVMX_PCI_PKTS_SENT_TIMEX(3)
     99#define CVMX_PCI_PKTS_SENT_TIMEX(offset) (0x000000000000004Cull + ((offset) & 3) * 16)
    100#define CVMX_PCI_PKT_CREDITS0 CVMX_PCI_PKT_CREDITSX(0)
    101#define CVMX_PCI_PKT_CREDITS1 CVMX_PCI_PKT_CREDITSX(1)
    102#define CVMX_PCI_PKT_CREDITS2 CVMX_PCI_PKT_CREDITSX(2)
    103#define CVMX_PCI_PKT_CREDITS3 CVMX_PCI_PKT_CREDITSX(3)
    104#define CVMX_PCI_PKT_CREDITSX(offset) (0x0000000000000044ull + ((offset) & 3) * 16)
    105#define CVMX_PCI_READ_CMD_6 (0x0000000000000180ull)
    106#define CVMX_PCI_READ_CMD_C (0x0000000000000184ull)
    107#define CVMX_PCI_READ_CMD_E (0x0000000000000188ull)
    108#define CVMX_PCI_READ_TIMEOUT (CVMX_ADD_IO_SEG(0x00011F00000000B0ull))
    109#define CVMX_PCI_SCM_REG (0x00000000000001A8ull)
    110#define CVMX_PCI_TSR_REG (0x00000000000001B0ull)
    111#define CVMX_PCI_WIN_RD_ADDR (0x0000000000000008ull)
    112#define CVMX_PCI_WIN_RD_DATA (0x0000000000000020ull)
    113#define CVMX_PCI_WIN_WR_ADDR (0x0000000000000000ull)
    114#define CVMX_PCI_WIN_WR_DATA (0x0000000000000010ull)
    115#define CVMX_PCI_WIN_WR_MASK (0x0000000000000018ull)
    116
    117union cvmx_pci_bar1_indexx {
    118	uint32_t u32;
    119	struct cvmx_pci_bar1_indexx_s {
    120#ifdef __BIG_ENDIAN_BITFIELD
    121		uint32_t reserved_18_31:14;
    122		uint32_t addr_idx:14;
    123		uint32_t ca:1;
    124		uint32_t end_swp:2;
    125		uint32_t addr_v:1;
    126#else
    127		uint32_t addr_v:1;
    128		uint32_t end_swp:2;
    129		uint32_t ca:1;
    130		uint32_t addr_idx:14;
    131		uint32_t reserved_18_31:14;
    132#endif
    133	} s;
    134};
    135
    136union cvmx_pci_bist_reg {
    137	uint64_t u64;
    138	struct cvmx_pci_bist_reg_s {
    139#ifdef __BIG_ENDIAN_BITFIELD
    140		uint64_t reserved_10_63:54;
    141		uint64_t rsp_bs:1;
    142		uint64_t dma0_bs:1;
    143		uint64_t cmd0_bs:1;
    144		uint64_t cmd_bs:1;
    145		uint64_t csr2p_bs:1;
    146		uint64_t csrr_bs:1;
    147		uint64_t rsp2p_bs:1;
    148		uint64_t csr2n_bs:1;
    149		uint64_t dat2n_bs:1;
    150		uint64_t dbg2n_bs:1;
    151#else
    152		uint64_t dbg2n_bs:1;
    153		uint64_t dat2n_bs:1;
    154		uint64_t csr2n_bs:1;
    155		uint64_t rsp2p_bs:1;
    156		uint64_t csrr_bs:1;
    157		uint64_t csr2p_bs:1;
    158		uint64_t cmd_bs:1;
    159		uint64_t cmd0_bs:1;
    160		uint64_t dma0_bs:1;
    161		uint64_t rsp_bs:1;
    162		uint64_t reserved_10_63:54;
    163#endif
    164	} s;
    165};
    166
    167union cvmx_pci_cfg00 {
    168	uint32_t u32;
    169	struct cvmx_pci_cfg00_s {
    170#ifdef __BIG_ENDIAN_BITFIELD
    171		uint32_t devid:16;
    172		uint32_t vendid:16;
    173#else
    174		uint32_t vendid:16;
    175		uint32_t devid:16;
    176#endif
    177	} s;
    178};
    179
    180union cvmx_pci_cfg01 {
    181	uint32_t u32;
    182	struct cvmx_pci_cfg01_s {
    183#ifdef __BIG_ENDIAN_BITFIELD
    184		uint32_t dpe:1;
    185		uint32_t sse:1;
    186		uint32_t rma:1;
    187		uint32_t rta:1;
    188		uint32_t sta:1;
    189		uint32_t devt:2;
    190		uint32_t mdpe:1;
    191		uint32_t fbb:1;
    192		uint32_t reserved_22_22:1;
    193		uint32_t m66:1;
    194		uint32_t cle:1;
    195		uint32_t i_stat:1;
    196		uint32_t reserved_11_18:8;
    197		uint32_t i_dis:1;
    198		uint32_t fbbe:1;
    199		uint32_t see:1;
    200		uint32_t ads:1;
    201		uint32_t pee:1;
    202		uint32_t vps:1;
    203		uint32_t mwice:1;
    204		uint32_t scse:1;
    205		uint32_t me:1;
    206		uint32_t msae:1;
    207		uint32_t isae:1;
    208#else
    209		uint32_t isae:1;
    210		uint32_t msae:1;
    211		uint32_t me:1;
    212		uint32_t scse:1;
    213		uint32_t mwice:1;
    214		uint32_t vps:1;
    215		uint32_t pee:1;
    216		uint32_t ads:1;
    217		uint32_t see:1;
    218		uint32_t fbbe:1;
    219		uint32_t i_dis:1;
    220		uint32_t reserved_11_18:8;
    221		uint32_t i_stat:1;
    222		uint32_t cle:1;
    223		uint32_t m66:1;
    224		uint32_t reserved_22_22:1;
    225		uint32_t fbb:1;
    226		uint32_t mdpe:1;
    227		uint32_t devt:2;
    228		uint32_t sta:1;
    229		uint32_t rta:1;
    230		uint32_t rma:1;
    231		uint32_t sse:1;
    232		uint32_t dpe:1;
    233#endif
    234	} s;
    235};
    236
    237union cvmx_pci_cfg02 {
    238	uint32_t u32;
    239	struct cvmx_pci_cfg02_s {
    240#ifdef __BIG_ENDIAN_BITFIELD
    241		uint32_t cc:24;
    242		uint32_t rid:8;
    243#else
    244		uint32_t rid:8;
    245		uint32_t cc:24;
    246#endif
    247	} s;
    248};
    249
    250union cvmx_pci_cfg03 {
    251	uint32_t u32;
    252	struct cvmx_pci_cfg03_s {
    253#ifdef __BIG_ENDIAN_BITFIELD
    254		uint32_t bcap:1;
    255		uint32_t brb:1;
    256		uint32_t reserved_28_29:2;
    257		uint32_t bcod:4;
    258		uint32_t ht:8;
    259		uint32_t lt:8;
    260		uint32_t cls:8;
    261#else
    262		uint32_t cls:8;
    263		uint32_t lt:8;
    264		uint32_t ht:8;
    265		uint32_t bcod:4;
    266		uint32_t reserved_28_29:2;
    267		uint32_t brb:1;
    268		uint32_t bcap:1;
    269#endif
    270	} s;
    271};
    272
    273union cvmx_pci_cfg04 {
    274	uint32_t u32;
    275	struct cvmx_pci_cfg04_s {
    276#ifdef __BIG_ENDIAN_BITFIELD
    277		uint32_t lbase:20;
    278		uint32_t lbasez:8;
    279		uint32_t pf:1;
    280		uint32_t typ:2;
    281		uint32_t mspc:1;
    282#else
    283		uint32_t mspc:1;
    284		uint32_t typ:2;
    285		uint32_t pf:1;
    286		uint32_t lbasez:8;
    287		uint32_t lbase:20;
    288#endif
    289	} s;
    290};
    291
    292union cvmx_pci_cfg05 {
    293	uint32_t u32;
    294	struct cvmx_pci_cfg05_s {
    295#ifdef __BIG_ENDIAN_BITFIELD
    296		uint32_t hbase:32;
    297#else
    298		uint32_t hbase:32;
    299#endif
    300	} s;
    301};
    302
    303union cvmx_pci_cfg06 {
    304	uint32_t u32;
    305	struct cvmx_pci_cfg06_s {
    306#ifdef __BIG_ENDIAN_BITFIELD
    307		uint32_t lbase:5;
    308		uint32_t lbasez:23;
    309		uint32_t pf:1;
    310		uint32_t typ:2;
    311		uint32_t mspc:1;
    312#else
    313		uint32_t mspc:1;
    314		uint32_t typ:2;
    315		uint32_t pf:1;
    316		uint32_t lbasez:23;
    317		uint32_t lbase:5;
    318#endif
    319	} s;
    320};
    321
    322union cvmx_pci_cfg07 {
    323	uint32_t u32;
    324	struct cvmx_pci_cfg07_s {
    325#ifdef __BIG_ENDIAN_BITFIELD
    326		uint32_t hbase:32;
    327#else
    328		uint32_t hbase:32;
    329#endif
    330	} s;
    331};
    332
    333union cvmx_pci_cfg08 {
    334	uint32_t u32;
    335	struct cvmx_pci_cfg08_s {
    336#ifdef __BIG_ENDIAN_BITFIELD
    337		uint32_t lbasez:28;
    338		uint32_t pf:1;
    339		uint32_t typ:2;
    340		uint32_t mspc:1;
    341#else
    342		uint32_t mspc:1;
    343		uint32_t typ:2;
    344		uint32_t pf:1;
    345		uint32_t lbasez:28;
    346#endif
    347	} s;
    348};
    349
    350union cvmx_pci_cfg09 {
    351	uint32_t u32;
    352	struct cvmx_pci_cfg09_s {
    353#ifdef __BIG_ENDIAN_BITFIELD
    354		uint32_t hbase:25;
    355		uint32_t hbasez:7;
    356#else
    357		uint32_t hbasez:7;
    358		uint32_t hbase:25;
    359#endif
    360	} s;
    361};
    362
    363union cvmx_pci_cfg10 {
    364	uint32_t u32;
    365	struct cvmx_pci_cfg10_s {
    366#ifdef __BIG_ENDIAN_BITFIELD
    367		uint32_t cisp:32;
    368#else
    369		uint32_t cisp:32;
    370#endif
    371	} s;
    372};
    373
    374union cvmx_pci_cfg11 {
    375	uint32_t u32;
    376	struct cvmx_pci_cfg11_s {
    377#ifdef __BIG_ENDIAN_BITFIELD
    378		uint32_t ssid:16;
    379		uint32_t ssvid:16;
    380#else
    381		uint32_t ssvid:16;
    382		uint32_t ssid:16;
    383#endif
    384	} s;
    385};
    386
    387union cvmx_pci_cfg12 {
    388	uint32_t u32;
    389	struct cvmx_pci_cfg12_s {
    390#ifdef __BIG_ENDIAN_BITFIELD
    391		uint32_t erbar:16;
    392		uint32_t erbarz:5;
    393		uint32_t reserved_1_10:10;
    394		uint32_t erbar_en:1;
    395#else
    396		uint32_t erbar_en:1;
    397		uint32_t reserved_1_10:10;
    398		uint32_t erbarz:5;
    399		uint32_t erbar:16;
    400#endif
    401	} s;
    402};
    403
    404union cvmx_pci_cfg13 {
    405	uint32_t u32;
    406	struct cvmx_pci_cfg13_s {
    407#ifdef __BIG_ENDIAN_BITFIELD
    408		uint32_t reserved_8_31:24;
    409		uint32_t cp:8;
    410#else
    411		uint32_t cp:8;
    412		uint32_t reserved_8_31:24;
    413#endif
    414	} s;
    415};
    416
    417union cvmx_pci_cfg15 {
    418	uint32_t u32;
    419	struct cvmx_pci_cfg15_s {
    420#ifdef __BIG_ENDIAN_BITFIELD
    421		uint32_t ml:8;
    422		uint32_t mg:8;
    423		uint32_t inta:8;
    424		uint32_t il:8;
    425#else
    426		uint32_t il:8;
    427		uint32_t inta:8;
    428		uint32_t mg:8;
    429		uint32_t ml:8;
    430#endif
    431	} s;
    432};
    433
    434union cvmx_pci_cfg16 {
    435	uint32_t u32;
    436	struct cvmx_pci_cfg16_s {
    437#ifdef __BIG_ENDIAN_BITFIELD
    438		uint32_t trdnpr:1;
    439		uint32_t trdard:1;
    440		uint32_t rdsati:1;
    441		uint32_t trdrs:1;
    442		uint32_t trtae:1;
    443		uint32_t twsei:1;
    444		uint32_t twsen:1;
    445		uint32_t twtae:1;
    446		uint32_t tmae:1;
    447		uint32_t tslte:3;
    448		uint32_t tilt:4;
    449		uint32_t pbe:12;
    450		uint32_t dppmr:1;
    451		uint32_t reserved_2_2:1;
    452		uint32_t tswc:1;
    453		uint32_t mltd:1;
    454#else
    455		uint32_t mltd:1;
    456		uint32_t tswc:1;
    457		uint32_t reserved_2_2:1;
    458		uint32_t dppmr:1;
    459		uint32_t pbe:12;
    460		uint32_t tilt:4;
    461		uint32_t tslte:3;
    462		uint32_t tmae:1;
    463		uint32_t twtae:1;
    464		uint32_t twsen:1;
    465		uint32_t twsei:1;
    466		uint32_t trtae:1;
    467		uint32_t trdrs:1;
    468		uint32_t rdsati:1;
    469		uint32_t trdard:1;
    470		uint32_t trdnpr:1;
    471#endif
    472	} s;
    473};
    474
    475union cvmx_pci_cfg17 {
    476	uint32_t u32;
    477	struct cvmx_pci_cfg17_s {
    478#ifdef __BIG_ENDIAN_BITFIELD
    479		uint32_t tscme:32;
    480#else
    481		uint32_t tscme:32;
    482#endif
    483	} s;
    484};
    485
    486union cvmx_pci_cfg18 {
    487	uint32_t u32;
    488	struct cvmx_pci_cfg18_s {
    489#ifdef __BIG_ENDIAN_BITFIELD
    490		uint32_t tdsrps:32;
    491#else
    492		uint32_t tdsrps:32;
    493#endif
    494	} s;
    495};
    496
    497union cvmx_pci_cfg19 {
    498	uint32_t u32;
    499	struct cvmx_pci_cfg19_s {
    500#ifdef __BIG_ENDIAN_BITFIELD
    501		uint32_t mrbcm:1;
    502		uint32_t mrbci:1;
    503		uint32_t mdwe:1;
    504		uint32_t mdre:1;
    505		uint32_t mdrimc:1;
    506		uint32_t mdrrmc:3;
    507		uint32_t tmes:8;
    508		uint32_t teci:1;
    509		uint32_t tmei:1;
    510		uint32_t tmse:1;
    511		uint32_t tmdpes:1;
    512		uint32_t tmapes:1;
    513		uint32_t reserved_9_10:2;
    514		uint32_t tibcd:1;
    515		uint32_t tibde:1;
    516		uint32_t reserved_6_6:1;
    517		uint32_t tidomc:1;
    518		uint32_t tdomc:5;
    519#else
    520		uint32_t tdomc:5;
    521		uint32_t tidomc:1;
    522		uint32_t reserved_6_6:1;
    523		uint32_t tibde:1;
    524		uint32_t tibcd:1;
    525		uint32_t reserved_9_10:2;
    526		uint32_t tmapes:1;
    527		uint32_t tmdpes:1;
    528		uint32_t tmse:1;
    529		uint32_t tmei:1;
    530		uint32_t teci:1;
    531		uint32_t tmes:8;
    532		uint32_t mdrrmc:3;
    533		uint32_t mdrimc:1;
    534		uint32_t mdre:1;
    535		uint32_t mdwe:1;
    536		uint32_t mrbci:1;
    537		uint32_t mrbcm:1;
    538#endif
    539	} s;
    540};
    541
    542union cvmx_pci_cfg20 {
    543	uint32_t u32;
    544	struct cvmx_pci_cfg20_s {
    545#ifdef __BIG_ENDIAN_BITFIELD
    546		uint32_t mdsp:32;
    547#else
    548		uint32_t mdsp:32;
    549#endif
    550	} s;
    551};
    552
    553union cvmx_pci_cfg21 {
    554	uint32_t u32;
    555	struct cvmx_pci_cfg21_s {
    556#ifdef __BIG_ENDIAN_BITFIELD
    557		uint32_t scmre:32;
    558#else
    559		uint32_t scmre:32;
    560#endif
    561	} s;
    562};
    563
    564union cvmx_pci_cfg22 {
    565	uint32_t u32;
    566	struct cvmx_pci_cfg22_s {
    567#ifdef __BIG_ENDIAN_BITFIELD
    568		uint32_t mac:7;
    569		uint32_t reserved_19_24:6;
    570		uint32_t flush:1;
    571		uint32_t mra:1;
    572		uint32_t mtta:1;
    573		uint32_t mrv:8;
    574		uint32_t mttv:8;
    575#else
    576		uint32_t mttv:8;
    577		uint32_t mrv:8;
    578		uint32_t mtta:1;
    579		uint32_t mra:1;
    580		uint32_t flush:1;
    581		uint32_t reserved_19_24:6;
    582		uint32_t mac:7;
    583#endif
    584	} s;
    585};
    586
    587union cvmx_pci_cfg56 {
    588	uint32_t u32;
    589	struct cvmx_pci_cfg56_s {
    590#ifdef __BIG_ENDIAN_BITFIELD
    591		uint32_t reserved_23_31:9;
    592		uint32_t most:3;
    593		uint32_t mmbc:2;
    594		uint32_t roe:1;
    595		uint32_t dpere:1;
    596		uint32_t ncp:8;
    597		uint32_t pxcid:8;
    598#else
    599		uint32_t pxcid:8;
    600		uint32_t ncp:8;
    601		uint32_t dpere:1;
    602		uint32_t roe:1;
    603		uint32_t mmbc:2;
    604		uint32_t most:3;
    605		uint32_t reserved_23_31:9;
    606#endif
    607	} s;
    608};
    609
    610union cvmx_pci_cfg57 {
    611	uint32_t u32;
    612	struct cvmx_pci_cfg57_s {
    613#ifdef __BIG_ENDIAN_BITFIELD
    614		uint32_t reserved_30_31:2;
    615		uint32_t scemr:1;
    616		uint32_t mcrsd:3;
    617		uint32_t mostd:3;
    618		uint32_t mmrbcd:2;
    619		uint32_t dc:1;
    620		uint32_t usc:1;
    621		uint32_t scd:1;
    622		uint32_t m133:1;
    623		uint32_t w64:1;
    624		uint32_t bn:8;
    625		uint32_t dn:5;
    626		uint32_t fn:3;
    627#else
    628		uint32_t fn:3;
    629		uint32_t dn:5;
    630		uint32_t bn:8;
    631		uint32_t w64:1;
    632		uint32_t m133:1;
    633		uint32_t scd:1;
    634		uint32_t usc:1;
    635		uint32_t dc:1;
    636		uint32_t mmrbcd:2;
    637		uint32_t mostd:3;
    638		uint32_t mcrsd:3;
    639		uint32_t scemr:1;
    640		uint32_t reserved_30_31:2;
    641#endif
    642	} s;
    643};
    644
    645union cvmx_pci_cfg58 {
    646	uint32_t u32;
    647	struct cvmx_pci_cfg58_s {
    648#ifdef __BIG_ENDIAN_BITFIELD
    649		uint32_t pmes:5;
    650		uint32_t d2s:1;
    651		uint32_t d1s:1;
    652		uint32_t auxc:3;
    653		uint32_t dsi:1;
    654		uint32_t reserved_20_20:1;
    655		uint32_t pmec:1;
    656		uint32_t pcimiv:3;
    657		uint32_t ncp:8;
    658		uint32_t pmcid:8;
    659#else
    660		uint32_t pmcid:8;
    661		uint32_t ncp:8;
    662		uint32_t pcimiv:3;
    663		uint32_t pmec:1;
    664		uint32_t reserved_20_20:1;
    665		uint32_t dsi:1;
    666		uint32_t auxc:3;
    667		uint32_t d1s:1;
    668		uint32_t d2s:1;
    669		uint32_t pmes:5;
    670#endif
    671	} s;
    672};
    673
    674union cvmx_pci_cfg59 {
    675	uint32_t u32;
    676	struct cvmx_pci_cfg59_s {
    677#ifdef __BIG_ENDIAN_BITFIELD
    678		uint32_t pmdia:8;
    679		uint32_t bpccen:1;
    680		uint32_t bd3h:1;
    681		uint32_t reserved_16_21:6;
    682		uint32_t pmess:1;
    683		uint32_t pmedsia:2;
    684		uint32_t pmds:4;
    685		uint32_t pmeens:1;
    686		uint32_t reserved_2_7:6;
    687		uint32_t ps:2;
    688#else
    689		uint32_t ps:2;
    690		uint32_t reserved_2_7:6;
    691		uint32_t pmeens:1;
    692		uint32_t pmds:4;
    693		uint32_t pmedsia:2;
    694		uint32_t pmess:1;
    695		uint32_t reserved_16_21:6;
    696		uint32_t bd3h:1;
    697		uint32_t bpccen:1;
    698		uint32_t pmdia:8;
    699#endif
    700	} s;
    701};
    702
    703union cvmx_pci_cfg60 {
    704	uint32_t u32;
    705	struct cvmx_pci_cfg60_s {
    706#ifdef __BIG_ENDIAN_BITFIELD
    707		uint32_t reserved_24_31:8;
    708		uint32_t m64:1;
    709		uint32_t mme:3;
    710		uint32_t mmc:3;
    711		uint32_t msien:1;
    712		uint32_t ncp:8;
    713		uint32_t msicid:8;
    714#else
    715		uint32_t msicid:8;
    716		uint32_t ncp:8;
    717		uint32_t msien:1;
    718		uint32_t mmc:3;
    719		uint32_t mme:3;
    720		uint32_t m64:1;
    721		uint32_t reserved_24_31:8;
    722#endif
    723	} s;
    724};
    725
    726union cvmx_pci_cfg61 {
    727	uint32_t u32;
    728	struct cvmx_pci_cfg61_s {
    729#ifdef __BIG_ENDIAN_BITFIELD
    730		uint32_t msi31t2:30;
    731		uint32_t reserved_0_1:2;
    732#else
    733		uint32_t reserved_0_1:2;
    734		uint32_t msi31t2:30;
    735#endif
    736	} s;
    737};
    738
    739union cvmx_pci_cfg62 {
    740	uint32_t u32;
    741	struct cvmx_pci_cfg62_s {
    742#ifdef __BIG_ENDIAN_BITFIELD
    743		uint32_t msi:32;
    744#else
    745		uint32_t msi:32;
    746#endif
    747	} s;
    748};
    749
    750union cvmx_pci_cfg63 {
    751	uint32_t u32;
    752	struct cvmx_pci_cfg63_s {
    753#ifdef __BIG_ENDIAN_BITFIELD
    754		uint32_t reserved_16_31:16;
    755		uint32_t msimd:16;
    756#else
    757		uint32_t msimd:16;
    758		uint32_t reserved_16_31:16;
    759#endif
    760	} s;
    761};
    762
    763union cvmx_pci_cnt_reg {
    764	uint64_t u64;
    765	struct cvmx_pci_cnt_reg_s {
    766#ifdef __BIG_ENDIAN_BITFIELD
    767		uint64_t reserved_38_63:26;
    768		uint64_t hm_pcix:1;
    769		uint64_t hm_speed:2;
    770		uint64_t ap_pcix:1;
    771		uint64_t ap_speed:2;
    772		uint64_t pcicnt:32;
    773#else
    774		uint64_t pcicnt:32;
    775		uint64_t ap_speed:2;
    776		uint64_t ap_pcix:1;
    777		uint64_t hm_speed:2;
    778		uint64_t hm_pcix:1;
    779		uint64_t reserved_38_63:26;
    780#endif
    781	} s;
    782};
    783
    784union cvmx_pci_ctl_status_2 {
    785	uint32_t u32;
    786	struct cvmx_pci_ctl_status_2_s {
    787#ifdef __BIG_ENDIAN_BITFIELD
    788		uint32_t reserved_29_31:3;
    789		uint32_t bb1_hole:3;
    790		uint32_t bb1_siz:1;
    791		uint32_t bb_ca:1;
    792		uint32_t bb_es:2;
    793		uint32_t bb1:1;
    794		uint32_t bb0:1;
    795		uint32_t erst_n:1;
    796		uint32_t bar2pres:1;
    797		uint32_t scmtyp:1;
    798		uint32_t scm:1;
    799		uint32_t en_wfilt:1;
    800		uint32_t reserved_14_14:1;
    801		uint32_t ap_pcix:1;
    802		uint32_t ap_64ad:1;
    803		uint32_t b12_bist:1;
    804		uint32_t pmo_amod:1;
    805		uint32_t pmo_fpc:3;
    806		uint32_t tsr_hwm:3;
    807		uint32_t bar2_enb:1;
    808		uint32_t bar2_esx:2;
    809		uint32_t bar2_cax:1;
    810#else
    811		uint32_t bar2_cax:1;
    812		uint32_t bar2_esx:2;
    813		uint32_t bar2_enb:1;
    814		uint32_t tsr_hwm:3;
    815		uint32_t pmo_fpc:3;
    816		uint32_t pmo_amod:1;
    817		uint32_t b12_bist:1;
    818		uint32_t ap_64ad:1;
    819		uint32_t ap_pcix:1;
    820		uint32_t reserved_14_14:1;
    821		uint32_t en_wfilt:1;
    822		uint32_t scm:1;
    823		uint32_t scmtyp:1;
    824		uint32_t bar2pres:1;
    825		uint32_t erst_n:1;
    826		uint32_t bb0:1;
    827		uint32_t bb1:1;
    828		uint32_t bb_es:2;
    829		uint32_t bb_ca:1;
    830		uint32_t bb1_siz:1;
    831		uint32_t bb1_hole:3;
    832		uint32_t reserved_29_31:3;
    833#endif
    834	} s;
    835	struct cvmx_pci_ctl_status_2_cn31xx {
    836#ifdef __BIG_ENDIAN_BITFIELD
    837		uint32_t reserved_20_31:12;
    838		uint32_t erst_n:1;
    839		uint32_t bar2pres:1;
    840		uint32_t scmtyp:1;
    841		uint32_t scm:1;
    842		uint32_t en_wfilt:1;
    843		uint32_t reserved_14_14:1;
    844		uint32_t ap_pcix:1;
    845		uint32_t ap_64ad:1;
    846		uint32_t b12_bist:1;
    847		uint32_t pmo_amod:1;
    848		uint32_t pmo_fpc:3;
    849		uint32_t tsr_hwm:3;
    850		uint32_t bar2_enb:1;
    851		uint32_t bar2_esx:2;
    852		uint32_t bar2_cax:1;
    853#else
    854		uint32_t bar2_cax:1;
    855		uint32_t bar2_esx:2;
    856		uint32_t bar2_enb:1;
    857		uint32_t tsr_hwm:3;
    858		uint32_t pmo_fpc:3;
    859		uint32_t pmo_amod:1;
    860		uint32_t b12_bist:1;
    861		uint32_t ap_64ad:1;
    862		uint32_t ap_pcix:1;
    863		uint32_t reserved_14_14:1;
    864		uint32_t en_wfilt:1;
    865		uint32_t scm:1;
    866		uint32_t scmtyp:1;
    867		uint32_t bar2pres:1;
    868		uint32_t erst_n:1;
    869		uint32_t reserved_20_31:12;
    870#endif
    871	} cn31xx;
    872};
    873
    874union cvmx_pci_dbellx {
    875	uint32_t u32;
    876	struct cvmx_pci_dbellx_s {
    877#ifdef __BIG_ENDIAN_BITFIELD
    878		uint32_t reserved_16_31:16;
    879		uint32_t inc_val:16;
    880#else
    881		uint32_t inc_val:16;
    882		uint32_t reserved_16_31:16;
    883#endif
    884	} s;
    885};
    886
    887union cvmx_pci_dma_cntx {
    888	uint32_t u32;
    889	struct cvmx_pci_dma_cntx_s {
    890#ifdef __BIG_ENDIAN_BITFIELD
    891		uint32_t dma_cnt:32;
    892#else
    893		uint32_t dma_cnt:32;
    894#endif
    895	} s;
    896};
    897
    898union cvmx_pci_dma_int_levx {
    899	uint32_t u32;
    900	struct cvmx_pci_dma_int_levx_s {
    901#ifdef __BIG_ENDIAN_BITFIELD
    902		uint32_t pkt_cnt:32;
    903#else
    904		uint32_t pkt_cnt:32;
    905#endif
    906	} s;
    907};
    908
    909union cvmx_pci_dma_timex {
    910	uint32_t u32;
    911	struct cvmx_pci_dma_timex_s {
    912#ifdef __BIG_ENDIAN_BITFIELD
    913		uint32_t dma_time:32;
    914#else
    915		uint32_t dma_time:32;
    916#endif
    917	} s;
    918};
    919
    920union cvmx_pci_instr_countx {
    921	uint32_t u32;
    922	struct cvmx_pci_instr_countx_s {
    923#ifdef __BIG_ENDIAN_BITFIELD
    924		uint32_t icnt:32;
    925#else
    926		uint32_t icnt:32;
    927#endif
    928	} s;
    929};
    930
    931union cvmx_pci_int_enb {
    932	uint64_t u64;
    933	struct cvmx_pci_int_enb_s {
    934#ifdef __BIG_ENDIAN_BITFIELD
    935		uint64_t reserved_34_63:30;
    936		uint64_t ill_rd:1;
    937		uint64_t ill_wr:1;
    938		uint64_t win_wr:1;
    939		uint64_t dma1_fi:1;
    940		uint64_t dma0_fi:1;
    941		uint64_t idtime1:1;
    942		uint64_t idtime0:1;
    943		uint64_t idcnt1:1;
    944		uint64_t idcnt0:1;
    945		uint64_t iptime3:1;
    946		uint64_t iptime2:1;
    947		uint64_t iptime1:1;
    948		uint64_t iptime0:1;
    949		uint64_t ipcnt3:1;
    950		uint64_t ipcnt2:1;
    951		uint64_t ipcnt1:1;
    952		uint64_t ipcnt0:1;
    953		uint64_t irsl_int:1;
    954		uint64_t ill_rrd:1;
    955		uint64_t ill_rwr:1;
    956		uint64_t idperr:1;
    957		uint64_t iaperr:1;
    958		uint64_t iserr:1;
    959		uint64_t itsr_abt:1;
    960		uint64_t imsc_msg:1;
    961		uint64_t imsi_mabt:1;
    962		uint64_t imsi_tabt:1;
    963		uint64_t imsi_per:1;
    964		uint64_t imr_tto:1;
    965		uint64_t imr_abt:1;
    966		uint64_t itr_abt:1;
    967		uint64_t imr_wtto:1;
    968		uint64_t imr_wabt:1;
    969		uint64_t itr_wabt:1;
    970#else
    971		uint64_t itr_wabt:1;
    972		uint64_t imr_wabt:1;
    973		uint64_t imr_wtto:1;
    974		uint64_t itr_abt:1;
    975		uint64_t imr_abt:1;
    976		uint64_t imr_tto:1;
    977		uint64_t imsi_per:1;
    978		uint64_t imsi_tabt:1;
    979		uint64_t imsi_mabt:1;
    980		uint64_t imsc_msg:1;
    981		uint64_t itsr_abt:1;
    982		uint64_t iserr:1;
    983		uint64_t iaperr:1;
    984		uint64_t idperr:1;
    985		uint64_t ill_rwr:1;
    986		uint64_t ill_rrd:1;
    987		uint64_t irsl_int:1;
    988		uint64_t ipcnt0:1;
    989		uint64_t ipcnt1:1;
    990		uint64_t ipcnt2:1;
    991		uint64_t ipcnt3:1;
    992		uint64_t iptime0:1;
    993		uint64_t iptime1:1;
    994		uint64_t iptime2:1;
    995		uint64_t iptime3:1;
    996		uint64_t idcnt0:1;
    997		uint64_t idcnt1:1;
    998		uint64_t idtime0:1;
    999		uint64_t idtime1:1;
   1000		uint64_t dma0_fi:1;
   1001		uint64_t dma1_fi:1;
   1002		uint64_t win_wr:1;
   1003		uint64_t ill_wr:1;
   1004		uint64_t ill_rd:1;
   1005		uint64_t reserved_34_63:30;
   1006#endif
   1007	} s;
   1008	struct cvmx_pci_int_enb_cn30xx {
   1009#ifdef __BIG_ENDIAN_BITFIELD
   1010		uint64_t reserved_34_63:30;
   1011		uint64_t ill_rd:1;
   1012		uint64_t ill_wr:1;
   1013		uint64_t win_wr:1;
   1014		uint64_t dma1_fi:1;
   1015		uint64_t dma0_fi:1;
   1016		uint64_t idtime1:1;
   1017		uint64_t idtime0:1;
   1018		uint64_t idcnt1:1;
   1019		uint64_t idcnt0:1;
   1020		uint64_t reserved_22_24:3;
   1021		uint64_t iptime0:1;
   1022		uint64_t reserved_18_20:3;
   1023		uint64_t ipcnt0:1;
   1024		uint64_t irsl_int:1;
   1025		uint64_t ill_rrd:1;
   1026		uint64_t ill_rwr:1;
   1027		uint64_t idperr:1;
   1028		uint64_t iaperr:1;
   1029		uint64_t iserr:1;
   1030		uint64_t itsr_abt:1;
   1031		uint64_t imsc_msg:1;
   1032		uint64_t imsi_mabt:1;
   1033		uint64_t imsi_tabt:1;
   1034		uint64_t imsi_per:1;
   1035		uint64_t imr_tto:1;
   1036		uint64_t imr_abt:1;
   1037		uint64_t itr_abt:1;
   1038		uint64_t imr_wtto:1;
   1039		uint64_t imr_wabt:1;
   1040		uint64_t itr_wabt:1;
   1041#else
   1042		uint64_t itr_wabt:1;
   1043		uint64_t imr_wabt:1;
   1044		uint64_t imr_wtto:1;
   1045		uint64_t itr_abt:1;
   1046		uint64_t imr_abt:1;
   1047		uint64_t imr_tto:1;
   1048		uint64_t imsi_per:1;
   1049		uint64_t imsi_tabt:1;
   1050		uint64_t imsi_mabt:1;
   1051		uint64_t imsc_msg:1;
   1052		uint64_t itsr_abt:1;
   1053		uint64_t iserr:1;
   1054		uint64_t iaperr:1;
   1055		uint64_t idperr:1;
   1056		uint64_t ill_rwr:1;
   1057		uint64_t ill_rrd:1;
   1058		uint64_t irsl_int:1;
   1059		uint64_t ipcnt0:1;
   1060		uint64_t reserved_18_20:3;
   1061		uint64_t iptime0:1;
   1062		uint64_t reserved_22_24:3;
   1063		uint64_t idcnt0:1;
   1064		uint64_t idcnt1:1;
   1065		uint64_t idtime0:1;
   1066		uint64_t idtime1:1;
   1067		uint64_t dma0_fi:1;
   1068		uint64_t dma1_fi:1;
   1069		uint64_t win_wr:1;
   1070		uint64_t ill_wr:1;
   1071		uint64_t ill_rd:1;
   1072		uint64_t reserved_34_63:30;
   1073#endif
   1074	} cn30xx;
   1075	struct cvmx_pci_int_enb_cn31xx {
   1076#ifdef __BIG_ENDIAN_BITFIELD
   1077		uint64_t reserved_34_63:30;
   1078		uint64_t ill_rd:1;
   1079		uint64_t ill_wr:1;
   1080		uint64_t win_wr:1;
   1081		uint64_t dma1_fi:1;
   1082		uint64_t dma0_fi:1;
   1083		uint64_t idtime1:1;
   1084		uint64_t idtime0:1;
   1085		uint64_t idcnt1:1;
   1086		uint64_t idcnt0:1;
   1087		uint64_t reserved_23_24:2;
   1088		uint64_t iptime1:1;
   1089		uint64_t iptime0:1;
   1090		uint64_t reserved_19_20:2;
   1091		uint64_t ipcnt1:1;
   1092		uint64_t ipcnt0:1;
   1093		uint64_t irsl_int:1;
   1094		uint64_t ill_rrd:1;
   1095		uint64_t ill_rwr:1;
   1096		uint64_t idperr:1;
   1097		uint64_t iaperr:1;
   1098		uint64_t iserr:1;
   1099		uint64_t itsr_abt:1;
   1100		uint64_t imsc_msg:1;
   1101		uint64_t imsi_mabt:1;
   1102		uint64_t imsi_tabt:1;
   1103		uint64_t imsi_per:1;
   1104		uint64_t imr_tto:1;
   1105		uint64_t imr_abt:1;
   1106		uint64_t itr_abt:1;
   1107		uint64_t imr_wtto:1;
   1108		uint64_t imr_wabt:1;
   1109		uint64_t itr_wabt:1;
   1110#else
   1111		uint64_t itr_wabt:1;
   1112		uint64_t imr_wabt:1;
   1113		uint64_t imr_wtto:1;
   1114		uint64_t itr_abt:1;
   1115		uint64_t imr_abt:1;
   1116		uint64_t imr_tto:1;
   1117		uint64_t imsi_per:1;
   1118		uint64_t imsi_tabt:1;
   1119		uint64_t imsi_mabt:1;
   1120		uint64_t imsc_msg:1;
   1121		uint64_t itsr_abt:1;
   1122		uint64_t iserr:1;
   1123		uint64_t iaperr:1;
   1124		uint64_t idperr:1;
   1125		uint64_t ill_rwr:1;
   1126		uint64_t ill_rrd:1;
   1127		uint64_t irsl_int:1;
   1128		uint64_t ipcnt0:1;
   1129		uint64_t ipcnt1:1;
   1130		uint64_t reserved_19_20:2;
   1131		uint64_t iptime0:1;
   1132		uint64_t iptime1:1;
   1133		uint64_t reserved_23_24:2;
   1134		uint64_t idcnt0:1;
   1135		uint64_t idcnt1:1;
   1136		uint64_t idtime0:1;
   1137		uint64_t idtime1:1;
   1138		uint64_t dma0_fi:1;
   1139		uint64_t dma1_fi:1;
   1140		uint64_t win_wr:1;
   1141		uint64_t ill_wr:1;
   1142		uint64_t ill_rd:1;
   1143		uint64_t reserved_34_63:30;
   1144#endif
   1145	} cn31xx;
   1146};
   1147
   1148union cvmx_pci_int_enb2 {
   1149	uint64_t u64;
   1150	struct cvmx_pci_int_enb2_s {
   1151#ifdef __BIG_ENDIAN_BITFIELD
   1152		uint64_t reserved_34_63:30;
   1153		uint64_t ill_rd:1;
   1154		uint64_t ill_wr:1;
   1155		uint64_t win_wr:1;
   1156		uint64_t dma1_fi:1;
   1157		uint64_t dma0_fi:1;
   1158		uint64_t rdtime1:1;
   1159		uint64_t rdtime0:1;
   1160		uint64_t rdcnt1:1;
   1161		uint64_t rdcnt0:1;
   1162		uint64_t rptime3:1;
   1163		uint64_t rptime2:1;
   1164		uint64_t rptime1:1;
   1165		uint64_t rptime0:1;
   1166		uint64_t rpcnt3:1;
   1167		uint64_t rpcnt2:1;
   1168		uint64_t rpcnt1:1;
   1169		uint64_t rpcnt0:1;
   1170		uint64_t rrsl_int:1;
   1171		uint64_t ill_rrd:1;
   1172		uint64_t ill_rwr:1;
   1173		uint64_t rdperr:1;
   1174		uint64_t raperr:1;
   1175		uint64_t rserr:1;
   1176		uint64_t rtsr_abt:1;
   1177		uint64_t rmsc_msg:1;
   1178		uint64_t rmsi_mabt:1;
   1179		uint64_t rmsi_tabt:1;
   1180		uint64_t rmsi_per:1;
   1181		uint64_t rmr_tto:1;
   1182		uint64_t rmr_abt:1;
   1183		uint64_t rtr_abt:1;
   1184		uint64_t rmr_wtto:1;
   1185		uint64_t rmr_wabt:1;
   1186		uint64_t rtr_wabt:1;
   1187#else
   1188		uint64_t rtr_wabt:1;
   1189		uint64_t rmr_wabt:1;
   1190		uint64_t rmr_wtto:1;
   1191		uint64_t rtr_abt:1;
   1192		uint64_t rmr_abt:1;
   1193		uint64_t rmr_tto:1;
   1194		uint64_t rmsi_per:1;
   1195		uint64_t rmsi_tabt:1;
   1196		uint64_t rmsi_mabt:1;
   1197		uint64_t rmsc_msg:1;
   1198		uint64_t rtsr_abt:1;
   1199		uint64_t rserr:1;
   1200		uint64_t raperr:1;
   1201		uint64_t rdperr:1;
   1202		uint64_t ill_rwr:1;
   1203		uint64_t ill_rrd:1;
   1204		uint64_t rrsl_int:1;
   1205		uint64_t rpcnt0:1;
   1206		uint64_t rpcnt1:1;
   1207		uint64_t rpcnt2:1;
   1208		uint64_t rpcnt3:1;
   1209		uint64_t rptime0:1;
   1210		uint64_t rptime1:1;
   1211		uint64_t rptime2:1;
   1212		uint64_t rptime3:1;
   1213		uint64_t rdcnt0:1;
   1214		uint64_t rdcnt1:1;
   1215		uint64_t rdtime0:1;
   1216		uint64_t rdtime1:1;
   1217		uint64_t dma0_fi:1;
   1218		uint64_t dma1_fi:1;
   1219		uint64_t win_wr:1;
   1220		uint64_t ill_wr:1;
   1221		uint64_t ill_rd:1;
   1222		uint64_t reserved_34_63:30;
   1223#endif
   1224	} s;
   1225	struct cvmx_pci_int_enb2_cn30xx {
   1226#ifdef __BIG_ENDIAN_BITFIELD
   1227		uint64_t reserved_34_63:30;
   1228		uint64_t ill_rd:1;
   1229		uint64_t ill_wr:1;
   1230		uint64_t win_wr:1;
   1231		uint64_t dma1_fi:1;
   1232		uint64_t dma0_fi:1;
   1233		uint64_t rdtime1:1;
   1234		uint64_t rdtime0:1;
   1235		uint64_t rdcnt1:1;
   1236		uint64_t rdcnt0:1;
   1237		uint64_t reserved_22_24:3;
   1238		uint64_t rptime0:1;
   1239		uint64_t reserved_18_20:3;
   1240		uint64_t rpcnt0:1;
   1241		uint64_t rrsl_int:1;
   1242		uint64_t ill_rrd:1;
   1243		uint64_t ill_rwr:1;
   1244		uint64_t rdperr:1;
   1245		uint64_t raperr:1;
   1246		uint64_t rserr:1;
   1247		uint64_t rtsr_abt:1;
   1248		uint64_t rmsc_msg:1;
   1249		uint64_t rmsi_mabt:1;
   1250		uint64_t rmsi_tabt:1;
   1251		uint64_t rmsi_per:1;
   1252		uint64_t rmr_tto:1;
   1253		uint64_t rmr_abt:1;
   1254		uint64_t rtr_abt:1;
   1255		uint64_t rmr_wtto:1;
   1256		uint64_t rmr_wabt:1;
   1257		uint64_t rtr_wabt:1;
   1258#else
   1259		uint64_t rtr_wabt:1;
   1260		uint64_t rmr_wabt:1;
   1261		uint64_t rmr_wtto:1;
   1262		uint64_t rtr_abt:1;
   1263		uint64_t rmr_abt:1;
   1264		uint64_t rmr_tto:1;
   1265		uint64_t rmsi_per:1;
   1266		uint64_t rmsi_tabt:1;
   1267		uint64_t rmsi_mabt:1;
   1268		uint64_t rmsc_msg:1;
   1269		uint64_t rtsr_abt:1;
   1270		uint64_t rserr:1;
   1271		uint64_t raperr:1;
   1272		uint64_t rdperr:1;
   1273		uint64_t ill_rwr:1;
   1274		uint64_t ill_rrd:1;
   1275		uint64_t rrsl_int:1;
   1276		uint64_t rpcnt0:1;
   1277		uint64_t reserved_18_20:3;
   1278		uint64_t rptime0:1;
   1279		uint64_t reserved_22_24:3;
   1280		uint64_t rdcnt0:1;
   1281		uint64_t rdcnt1:1;
   1282		uint64_t rdtime0:1;
   1283		uint64_t rdtime1:1;
   1284		uint64_t dma0_fi:1;
   1285		uint64_t dma1_fi:1;
   1286		uint64_t win_wr:1;
   1287		uint64_t ill_wr:1;
   1288		uint64_t ill_rd:1;
   1289		uint64_t reserved_34_63:30;
   1290#endif
   1291	} cn30xx;
   1292	struct cvmx_pci_int_enb2_cn31xx {
   1293#ifdef __BIG_ENDIAN_BITFIELD
   1294		uint64_t reserved_34_63:30;
   1295		uint64_t ill_rd:1;
   1296		uint64_t ill_wr:1;
   1297		uint64_t win_wr:1;
   1298		uint64_t dma1_fi:1;
   1299		uint64_t dma0_fi:1;
   1300		uint64_t rdtime1:1;
   1301		uint64_t rdtime0:1;
   1302		uint64_t rdcnt1:1;
   1303		uint64_t rdcnt0:1;
   1304		uint64_t reserved_23_24:2;
   1305		uint64_t rptime1:1;
   1306		uint64_t rptime0:1;
   1307		uint64_t reserved_19_20:2;
   1308		uint64_t rpcnt1:1;
   1309		uint64_t rpcnt0:1;
   1310		uint64_t rrsl_int:1;
   1311		uint64_t ill_rrd:1;
   1312		uint64_t ill_rwr:1;
   1313		uint64_t rdperr:1;
   1314		uint64_t raperr:1;
   1315		uint64_t rserr:1;
   1316		uint64_t rtsr_abt:1;
   1317		uint64_t rmsc_msg:1;
   1318		uint64_t rmsi_mabt:1;
   1319		uint64_t rmsi_tabt:1;
   1320		uint64_t rmsi_per:1;
   1321		uint64_t rmr_tto:1;
   1322		uint64_t rmr_abt:1;
   1323		uint64_t rtr_abt:1;
   1324		uint64_t rmr_wtto:1;
   1325		uint64_t rmr_wabt:1;
   1326		uint64_t rtr_wabt:1;
   1327#else
   1328		uint64_t rtr_wabt:1;
   1329		uint64_t rmr_wabt:1;
   1330		uint64_t rmr_wtto:1;
   1331		uint64_t rtr_abt:1;
   1332		uint64_t rmr_abt:1;
   1333		uint64_t rmr_tto:1;
   1334		uint64_t rmsi_per:1;
   1335		uint64_t rmsi_tabt:1;
   1336		uint64_t rmsi_mabt:1;
   1337		uint64_t rmsc_msg:1;
   1338		uint64_t rtsr_abt:1;
   1339		uint64_t rserr:1;
   1340		uint64_t raperr:1;
   1341		uint64_t rdperr:1;
   1342		uint64_t ill_rwr:1;
   1343		uint64_t ill_rrd:1;
   1344		uint64_t rrsl_int:1;
   1345		uint64_t rpcnt0:1;
   1346		uint64_t rpcnt1:1;
   1347		uint64_t reserved_19_20:2;
   1348		uint64_t rptime0:1;
   1349		uint64_t rptime1:1;
   1350		uint64_t reserved_23_24:2;
   1351		uint64_t rdcnt0:1;
   1352		uint64_t rdcnt1:1;
   1353		uint64_t rdtime0:1;
   1354		uint64_t rdtime1:1;
   1355		uint64_t dma0_fi:1;
   1356		uint64_t dma1_fi:1;
   1357		uint64_t win_wr:1;
   1358		uint64_t ill_wr:1;
   1359		uint64_t ill_rd:1;
   1360		uint64_t reserved_34_63:30;
   1361#endif
   1362	} cn31xx;
   1363};
   1364
   1365union cvmx_pci_int_sum {
   1366	uint64_t u64;
   1367	struct cvmx_pci_int_sum_s {
   1368#ifdef __BIG_ENDIAN_BITFIELD
   1369		uint64_t reserved_34_63:30;
   1370		uint64_t ill_rd:1;
   1371		uint64_t ill_wr:1;
   1372		uint64_t win_wr:1;
   1373		uint64_t dma1_fi:1;
   1374		uint64_t dma0_fi:1;
   1375		uint64_t dtime1:1;
   1376		uint64_t dtime0:1;
   1377		uint64_t dcnt1:1;
   1378		uint64_t dcnt0:1;
   1379		uint64_t ptime3:1;
   1380		uint64_t ptime2:1;
   1381		uint64_t ptime1:1;
   1382		uint64_t ptime0:1;
   1383		uint64_t pcnt3:1;
   1384		uint64_t pcnt2:1;
   1385		uint64_t pcnt1:1;
   1386		uint64_t pcnt0:1;
   1387		uint64_t rsl_int:1;
   1388		uint64_t ill_rrd:1;
   1389		uint64_t ill_rwr:1;
   1390		uint64_t dperr:1;
   1391		uint64_t aperr:1;
   1392		uint64_t serr:1;
   1393		uint64_t tsr_abt:1;
   1394		uint64_t msc_msg:1;
   1395		uint64_t msi_mabt:1;
   1396		uint64_t msi_tabt:1;
   1397		uint64_t msi_per:1;
   1398		uint64_t mr_tto:1;
   1399		uint64_t mr_abt:1;
   1400		uint64_t tr_abt:1;
   1401		uint64_t mr_wtto:1;
   1402		uint64_t mr_wabt:1;
   1403		uint64_t tr_wabt:1;
   1404#else
   1405		uint64_t tr_wabt:1;
   1406		uint64_t mr_wabt:1;
   1407		uint64_t mr_wtto:1;
   1408		uint64_t tr_abt:1;
   1409		uint64_t mr_abt:1;
   1410		uint64_t mr_tto:1;
   1411		uint64_t msi_per:1;
   1412		uint64_t msi_tabt:1;
   1413		uint64_t msi_mabt:1;
   1414		uint64_t msc_msg:1;
   1415		uint64_t tsr_abt:1;
   1416		uint64_t serr:1;
   1417		uint64_t aperr:1;
   1418		uint64_t dperr:1;
   1419		uint64_t ill_rwr:1;
   1420		uint64_t ill_rrd:1;
   1421		uint64_t rsl_int:1;
   1422		uint64_t pcnt0:1;
   1423		uint64_t pcnt1:1;
   1424		uint64_t pcnt2:1;
   1425		uint64_t pcnt3:1;
   1426		uint64_t ptime0:1;
   1427		uint64_t ptime1:1;
   1428		uint64_t ptime2:1;
   1429		uint64_t ptime3:1;
   1430		uint64_t dcnt0:1;
   1431		uint64_t dcnt1:1;
   1432		uint64_t dtime0:1;
   1433		uint64_t dtime1:1;
   1434		uint64_t dma0_fi:1;
   1435		uint64_t dma1_fi:1;
   1436		uint64_t win_wr:1;
   1437		uint64_t ill_wr:1;
   1438		uint64_t ill_rd:1;
   1439		uint64_t reserved_34_63:30;
   1440#endif
   1441	} s;
   1442	struct cvmx_pci_int_sum_cn30xx {
   1443#ifdef __BIG_ENDIAN_BITFIELD
   1444		uint64_t reserved_34_63:30;
   1445		uint64_t ill_rd:1;
   1446		uint64_t ill_wr:1;
   1447		uint64_t win_wr:1;
   1448		uint64_t dma1_fi:1;
   1449		uint64_t dma0_fi:1;
   1450		uint64_t dtime1:1;
   1451		uint64_t dtime0:1;
   1452		uint64_t dcnt1:1;
   1453		uint64_t dcnt0:1;
   1454		uint64_t reserved_22_24:3;
   1455		uint64_t ptime0:1;
   1456		uint64_t reserved_18_20:3;
   1457		uint64_t pcnt0:1;
   1458		uint64_t rsl_int:1;
   1459		uint64_t ill_rrd:1;
   1460		uint64_t ill_rwr:1;
   1461		uint64_t dperr:1;
   1462		uint64_t aperr:1;
   1463		uint64_t serr:1;
   1464		uint64_t tsr_abt:1;
   1465		uint64_t msc_msg:1;
   1466		uint64_t msi_mabt:1;
   1467		uint64_t msi_tabt:1;
   1468		uint64_t msi_per:1;
   1469		uint64_t mr_tto:1;
   1470		uint64_t mr_abt:1;
   1471		uint64_t tr_abt:1;
   1472		uint64_t mr_wtto:1;
   1473		uint64_t mr_wabt:1;
   1474		uint64_t tr_wabt:1;
   1475#else
   1476		uint64_t tr_wabt:1;
   1477		uint64_t mr_wabt:1;
   1478		uint64_t mr_wtto:1;
   1479		uint64_t tr_abt:1;
   1480		uint64_t mr_abt:1;
   1481		uint64_t mr_tto:1;
   1482		uint64_t msi_per:1;
   1483		uint64_t msi_tabt:1;
   1484		uint64_t msi_mabt:1;
   1485		uint64_t msc_msg:1;
   1486		uint64_t tsr_abt:1;
   1487		uint64_t serr:1;
   1488		uint64_t aperr:1;
   1489		uint64_t dperr:1;
   1490		uint64_t ill_rwr:1;
   1491		uint64_t ill_rrd:1;
   1492		uint64_t rsl_int:1;
   1493		uint64_t pcnt0:1;
   1494		uint64_t reserved_18_20:3;
   1495		uint64_t ptime0:1;
   1496		uint64_t reserved_22_24:3;
   1497		uint64_t dcnt0:1;
   1498		uint64_t dcnt1:1;
   1499		uint64_t dtime0:1;
   1500		uint64_t dtime1:1;
   1501		uint64_t dma0_fi:1;
   1502		uint64_t dma1_fi:1;
   1503		uint64_t win_wr:1;
   1504		uint64_t ill_wr:1;
   1505		uint64_t ill_rd:1;
   1506		uint64_t reserved_34_63:30;
   1507#endif
   1508	} cn30xx;
   1509	struct cvmx_pci_int_sum_cn31xx {
   1510#ifdef __BIG_ENDIAN_BITFIELD
   1511		uint64_t reserved_34_63:30;
   1512		uint64_t ill_rd:1;
   1513		uint64_t ill_wr:1;
   1514		uint64_t win_wr:1;
   1515		uint64_t dma1_fi:1;
   1516		uint64_t dma0_fi:1;
   1517		uint64_t dtime1:1;
   1518		uint64_t dtime0:1;
   1519		uint64_t dcnt1:1;
   1520		uint64_t dcnt0:1;
   1521		uint64_t reserved_23_24:2;
   1522		uint64_t ptime1:1;
   1523		uint64_t ptime0:1;
   1524		uint64_t reserved_19_20:2;
   1525		uint64_t pcnt1:1;
   1526		uint64_t pcnt0:1;
   1527		uint64_t rsl_int:1;
   1528		uint64_t ill_rrd:1;
   1529		uint64_t ill_rwr:1;
   1530		uint64_t dperr:1;
   1531		uint64_t aperr:1;
   1532		uint64_t serr:1;
   1533		uint64_t tsr_abt:1;
   1534		uint64_t msc_msg:1;
   1535		uint64_t msi_mabt:1;
   1536		uint64_t msi_tabt:1;
   1537		uint64_t msi_per:1;
   1538		uint64_t mr_tto:1;
   1539		uint64_t mr_abt:1;
   1540		uint64_t tr_abt:1;
   1541		uint64_t mr_wtto:1;
   1542		uint64_t mr_wabt:1;
   1543		uint64_t tr_wabt:1;
   1544#else
   1545		uint64_t tr_wabt:1;
   1546		uint64_t mr_wabt:1;
   1547		uint64_t mr_wtto:1;
   1548		uint64_t tr_abt:1;
   1549		uint64_t mr_abt:1;
   1550		uint64_t mr_tto:1;
   1551		uint64_t msi_per:1;
   1552		uint64_t msi_tabt:1;
   1553		uint64_t msi_mabt:1;
   1554		uint64_t msc_msg:1;
   1555		uint64_t tsr_abt:1;
   1556		uint64_t serr:1;
   1557		uint64_t aperr:1;
   1558		uint64_t dperr:1;
   1559		uint64_t ill_rwr:1;
   1560		uint64_t ill_rrd:1;
   1561		uint64_t rsl_int:1;
   1562		uint64_t pcnt0:1;
   1563		uint64_t pcnt1:1;
   1564		uint64_t reserved_19_20:2;
   1565		uint64_t ptime0:1;
   1566		uint64_t ptime1:1;
   1567		uint64_t reserved_23_24:2;
   1568		uint64_t dcnt0:1;
   1569		uint64_t dcnt1:1;
   1570		uint64_t dtime0:1;
   1571		uint64_t dtime1:1;
   1572		uint64_t dma0_fi:1;
   1573		uint64_t dma1_fi:1;
   1574		uint64_t win_wr:1;
   1575		uint64_t ill_wr:1;
   1576		uint64_t ill_rd:1;
   1577		uint64_t reserved_34_63:30;
   1578#endif
   1579	} cn31xx;
   1580};
   1581
   1582union cvmx_pci_int_sum2 {
   1583	uint64_t u64;
   1584	struct cvmx_pci_int_sum2_s {
   1585#ifdef __BIG_ENDIAN_BITFIELD
   1586		uint64_t reserved_34_63:30;
   1587		uint64_t ill_rd:1;
   1588		uint64_t ill_wr:1;
   1589		uint64_t win_wr:1;
   1590		uint64_t dma1_fi:1;
   1591		uint64_t dma0_fi:1;
   1592		uint64_t dtime1:1;
   1593		uint64_t dtime0:1;
   1594		uint64_t dcnt1:1;
   1595		uint64_t dcnt0:1;
   1596		uint64_t ptime3:1;
   1597		uint64_t ptime2:1;
   1598		uint64_t ptime1:1;
   1599		uint64_t ptime0:1;
   1600		uint64_t pcnt3:1;
   1601		uint64_t pcnt2:1;
   1602		uint64_t pcnt1:1;
   1603		uint64_t pcnt0:1;
   1604		uint64_t rsl_int:1;
   1605		uint64_t ill_rrd:1;
   1606		uint64_t ill_rwr:1;
   1607		uint64_t dperr:1;
   1608		uint64_t aperr:1;
   1609		uint64_t serr:1;
   1610		uint64_t tsr_abt:1;
   1611		uint64_t msc_msg:1;
   1612		uint64_t msi_mabt:1;
   1613		uint64_t msi_tabt:1;
   1614		uint64_t msi_per:1;
   1615		uint64_t mr_tto:1;
   1616		uint64_t mr_abt:1;
   1617		uint64_t tr_abt:1;
   1618		uint64_t mr_wtto:1;
   1619		uint64_t mr_wabt:1;
   1620		uint64_t tr_wabt:1;
   1621#else
   1622		uint64_t tr_wabt:1;
   1623		uint64_t mr_wabt:1;
   1624		uint64_t mr_wtto:1;
   1625		uint64_t tr_abt:1;
   1626		uint64_t mr_abt:1;
   1627		uint64_t mr_tto:1;
   1628		uint64_t msi_per:1;
   1629		uint64_t msi_tabt:1;
   1630		uint64_t msi_mabt:1;
   1631		uint64_t msc_msg:1;
   1632		uint64_t tsr_abt:1;
   1633		uint64_t serr:1;
   1634		uint64_t aperr:1;
   1635		uint64_t dperr:1;
   1636		uint64_t ill_rwr:1;
   1637		uint64_t ill_rrd:1;
   1638		uint64_t rsl_int:1;
   1639		uint64_t pcnt0:1;
   1640		uint64_t pcnt1:1;
   1641		uint64_t pcnt2:1;
   1642		uint64_t pcnt3:1;
   1643		uint64_t ptime0:1;
   1644		uint64_t ptime1:1;
   1645		uint64_t ptime2:1;
   1646		uint64_t ptime3:1;
   1647		uint64_t dcnt0:1;
   1648		uint64_t dcnt1:1;
   1649		uint64_t dtime0:1;
   1650		uint64_t dtime1:1;
   1651		uint64_t dma0_fi:1;
   1652		uint64_t dma1_fi:1;
   1653		uint64_t win_wr:1;
   1654		uint64_t ill_wr:1;
   1655		uint64_t ill_rd:1;
   1656		uint64_t reserved_34_63:30;
   1657#endif
   1658	} s;
   1659	struct cvmx_pci_int_sum2_cn30xx {
   1660#ifdef __BIG_ENDIAN_BITFIELD
   1661		uint64_t reserved_34_63:30;
   1662		uint64_t ill_rd:1;
   1663		uint64_t ill_wr:1;
   1664		uint64_t win_wr:1;
   1665		uint64_t dma1_fi:1;
   1666		uint64_t dma0_fi:1;
   1667		uint64_t dtime1:1;
   1668		uint64_t dtime0:1;
   1669		uint64_t dcnt1:1;
   1670		uint64_t dcnt0:1;
   1671		uint64_t reserved_22_24:3;
   1672		uint64_t ptime0:1;
   1673		uint64_t reserved_18_20:3;
   1674		uint64_t pcnt0:1;
   1675		uint64_t rsl_int:1;
   1676		uint64_t ill_rrd:1;
   1677		uint64_t ill_rwr:1;
   1678		uint64_t dperr:1;
   1679		uint64_t aperr:1;
   1680		uint64_t serr:1;
   1681		uint64_t tsr_abt:1;
   1682		uint64_t msc_msg:1;
   1683		uint64_t msi_mabt:1;
   1684		uint64_t msi_tabt:1;
   1685		uint64_t msi_per:1;
   1686		uint64_t mr_tto:1;
   1687		uint64_t mr_abt:1;
   1688		uint64_t tr_abt:1;
   1689		uint64_t mr_wtto:1;
   1690		uint64_t mr_wabt:1;
   1691		uint64_t tr_wabt:1;
   1692#else
   1693		uint64_t tr_wabt:1;
   1694		uint64_t mr_wabt:1;
   1695		uint64_t mr_wtto:1;
   1696		uint64_t tr_abt:1;
   1697		uint64_t mr_abt:1;
   1698		uint64_t mr_tto:1;
   1699		uint64_t msi_per:1;
   1700		uint64_t msi_tabt:1;
   1701		uint64_t msi_mabt:1;
   1702		uint64_t msc_msg:1;
   1703		uint64_t tsr_abt:1;
   1704		uint64_t serr:1;
   1705		uint64_t aperr:1;
   1706		uint64_t dperr:1;
   1707		uint64_t ill_rwr:1;
   1708		uint64_t ill_rrd:1;
   1709		uint64_t rsl_int:1;
   1710		uint64_t pcnt0:1;
   1711		uint64_t reserved_18_20:3;
   1712		uint64_t ptime0:1;
   1713		uint64_t reserved_22_24:3;
   1714		uint64_t dcnt0:1;
   1715		uint64_t dcnt1:1;
   1716		uint64_t dtime0:1;
   1717		uint64_t dtime1:1;
   1718		uint64_t dma0_fi:1;
   1719		uint64_t dma1_fi:1;
   1720		uint64_t win_wr:1;
   1721		uint64_t ill_wr:1;
   1722		uint64_t ill_rd:1;
   1723		uint64_t reserved_34_63:30;
   1724#endif
   1725	} cn30xx;
   1726	struct cvmx_pci_int_sum2_cn31xx {
   1727#ifdef __BIG_ENDIAN_BITFIELD
   1728		uint64_t reserved_34_63:30;
   1729		uint64_t ill_rd:1;
   1730		uint64_t ill_wr:1;
   1731		uint64_t win_wr:1;
   1732		uint64_t dma1_fi:1;
   1733		uint64_t dma0_fi:1;
   1734		uint64_t dtime1:1;
   1735		uint64_t dtime0:1;
   1736		uint64_t dcnt1:1;
   1737		uint64_t dcnt0:1;
   1738		uint64_t reserved_23_24:2;
   1739		uint64_t ptime1:1;
   1740		uint64_t ptime0:1;
   1741		uint64_t reserved_19_20:2;
   1742		uint64_t pcnt1:1;
   1743		uint64_t pcnt0:1;
   1744		uint64_t rsl_int:1;
   1745		uint64_t ill_rrd:1;
   1746		uint64_t ill_rwr:1;
   1747		uint64_t dperr:1;
   1748		uint64_t aperr:1;
   1749		uint64_t serr:1;
   1750		uint64_t tsr_abt:1;
   1751		uint64_t msc_msg:1;
   1752		uint64_t msi_mabt:1;
   1753		uint64_t msi_tabt:1;
   1754		uint64_t msi_per:1;
   1755		uint64_t mr_tto:1;
   1756		uint64_t mr_abt:1;
   1757		uint64_t tr_abt:1;
   1758		uint64_t mr_wtto:1;
   1759		uint64_t mr_wabt:1;
   1760		uint64_t tr_wabt:1;
   1761#else
   1762		uint64_t tr_wabt:1;
   1763		uint64_t mr_wabt:1;
   1764		uint64_t mr_wtto:1;
   1765		uint64_t tr_abt:1;
   1766		uint64_t mr_abt:1;
   1767		uint64_t mr_tto:1;
   1768		uint64_t msi_per:1;
   1769		uint64_t msi_tabt:1;
   1770		uint64_t msi_mabt:1;
   1771		uint64_t msc_msg:1;
   1772		uint64_t tsr_abt:1;
   1773		uint64_t serr:1;
   1774		uint64_t aperr:1;
   1775		uint64_t dperr:1;
   1776		uint64_t ill_rwr:1;
   1777		uint64_t ill_rrd:1;
   1778		uint64_t rsl_int:1;
   1779		uint64_t pcnt0:1;
   1780		uint64_t pcnt1:1;
   1781		uint64_t reserved_19_20:2;
   1782		uint64_t ptime0:1;
   1783		uint64_t ptime1:1;
   1784		uint64_t reserved_23_24:2;
   1785		uint64_t dcnt0:1;
   1786		uint64_t dcnt1:1;
   1787		uint64_t dtime0:1;
   1788		uint64_t dtime1:1;
   1789		uint64_t dma0_fi:1;
   1790		uint64_t dma1_fi:1;
   1791		uint64_t win_wr:1;
   1792		uint64_t ill_wr:1;
   1793		uint64_t ill_rd:1;
   1794		uint64_t reserved_34_63:30;
   1795#endif
   1796	} cn31xx;
   1797};
   1798
   1799union cvmx_pci_msi_rcv {
   1800	uint32_t u32;
   1801	struct cvmx_pci_msi_rcv_s {
   1802#ifdef __BIG_ENDIAN_BITFIELD
   1803		uint32_t reserved_6_31:26;
   1804		uint32_t intr:6;
   1805#else
   1806		uint32_t intr:6;
   1807		uint32_t reserved_6_31:26;
   1808#endif
   1809	} s;
   1810};
   1811
   1812union cvmx_pci_pkt_creditsx {
   1813	uint32_t u32;
   1814	struct cvmx_pci_pkt_creditsx_s {
   1815#ifdef __BIG_ENDIAN_BITFIELD
   1816		uint32_t pkt_cnt:16;
   1817		uint32_t ptr_cnt:16;
   1818#else
   1819		uint32_t ptr_cnt:16;
   1820		uint32_t pkt_cnt:16;
   1821#endif
   1822	} s;
   1823};
   1824
   1825union cvmx_pci_pkts_sentx {
   1826	uint32_t u32;
   1827	struct cvmx_pci_pkts_sentx_s {
   1828#ifdef __BIG_ENDIAN_BITFIELD
   1829		uint32_t pkt_cnt:32;
   1830#else
   1831		uint32_t pkt_cnt:32;
   1832#endif
   1833	} s;
   1834};
   1835
   1836union cvmx_pci_pkts_sent_int_levx {
   1837	uint32_t u32;
   1838	struct cvmx_pci_pkts_sent_int_levx_s {
   1839#ifdef __BIG_ENDIAN_BITFIELD
   1840		uint32_t pkt_cnt:32;
   1841#else
   1842		uint32_t pkt_cnt:32;
   1843#endif
   1844	} s;
   1845};
   1846
   1847union cvmx_pci_pkts_sent_timex {
   1848	uint32_t u32;
   1849	struct cvmx_pci_pkts_sent_timex_s {
   1850#ifdef __BIG_ENDIAN_BITFIELD
   1851		uint32_t pkt_time:32;
   1852#else
   1853		uint32_t pkt_time:32;
   1854#endif
   1855	} s;
   1856};
   1857
   1858union cvmx_pci_read_cmd_6 {
   1859	uint32_t u32;
   1860	struct cvmx_pci_read_cmd_6_s {
   1861#ifdef __BIG_ENDIAN_BITFIELD
   1862		uint32_t reserved_9_31:23;
   1863		uint32_t min_data:6;
   1864		uint32_t prefetch:3;
   1865#else
   1866		uint32_t prefetch:3;
   1867		uint32_t min_data:6;
   1868		uint32_t reserved_9_31:23;
   1869#endif
   1870	} s;
   1871};
   1872
   1873union cvmx_pci_read_cmd_c {
   1874	uint32_t u32;
   1875	struct cvmx_pci_read_cmd_c_s {
   1876#ifdef __BIG_ENDIAN_BITFIELD
   1877		uint32_t reserved_9_31:23;
   1878		uint32_t min_data:6;
   1879		uint32_t prefetch:3;
   1880#else
   1881		uint32_t prefetch:3;
   1882		uint32_t min_data:6;
   1883		uint32_t reserved_9_31:23;
   1884#endif
   1885	} s;
   1886};
   1887
   1888union cvmx_pci_read_cmd_e {
   1889	uint32_t u32;
   1890	struct cvmx_pci_read_cmd_e_s {
   1891#ifdef __BIG_ENDIAN_BITFIELD
   1892		uint32_t reserved_9_31:23;
   1893		uint32_t min_data:6;
   1894		uint32_t prefetch:3;
   1895#else
   1896		uint32_t prefetch:3;
   1897		uint32_t min_data:6;
   1898		uint32_t reserved_9_31:23;
   1899#endif
   1900	} s;
   1901};
   1902
   1903union cvmx_pci_read_timeout {
   1904	uint64_t u64;
   1905	struct cvmx_pci_read_timeout_s {
   1906#ifdef __BIG_ENDIAN_BITFIELD
   1907		uint64_t reserved_32_63:32;
   1908		uint64_t enb:1;
   1909		uint64_t cnt:31;
   1910#else
   1911		uint64_t cnt:31;
   1912		uint64_t enb:1;
   1913		uint64_t reserved_32_63:32;
   1914#endif
   1915	} s;
   1916};
   1917
   1918union cvmx_pci_scm_reg {
   1919	uint64_t u64;
   1920	struct cvmx_pci_scm_reg_s {
   1921#ifdef __BIG_ENDIAN_BITFIELD
   1922		uint64_t reserved_32_63:32;
   1923		uint64_t scm:32;
   1924#else
   1925		uint64_t scm:32;
   1926		uint64_t reserved_32_63:32;
   1927#endif
   1928	} s;
   1929};
   1930
   1931union cvmx_pci_tsr_reg {
   1932	uint64_t u64;
   1933	struct cvmx_pci_tsr_reg_s {
   1934#ifdef __BIG_ENDIAN_BITFIELD
   1935		uint64_t reserved_36_63:28;
   1936		uint64_t tsr:36;
   1937#else
   1938		uint64_t tsr:36;
   1939		uint64_t reserved_36_63:28;
   1940#endif
   1941	} s;
   1942};
   1943
   1944union cvmx_pci_win_rd_addr {
   1945	uint64_t u64;
   1946	struct cvmx_pci_win_rd_addr_s {
   1947#ifdef __BIG_ENDIAN_BITFIELD
   1948		uint64_t reserved_49_63:15;
   1949		uint64_t iobit:1;
   1950		uint64_t reserved_0_47:48;
   1951#else
   1952		uint64_t reserved_0_47:48;
   1953		uint64_t iobit:1;
   1954		uint64_t reserved_49_63:15;
   1955#endif
   1956	} s;
   1957	struct cvmx_pci_win_rd_addr_cn30xx {
   1958#ifdef __BIG_ENDIAN_BITFIELD
   1959		uint64_t reserved_49_63:15;
   1960		uint64_t iobit:1;
   1961		uint64_t rd_addr:46;
   1962		uint64_t reserved_0_1:2;
   1963#else
   1964		uint64_t reserved_0_1:2;
   1965		uint64_t rd_addr:46;
   1966		uint64_t iobit:1;
   1967		uint64_t reserved_49_63:15;
   1968#endif
   1969	} cn30xx;
   1970	struct cvmx_pci_win_rd_addr_cn38xx {
   1971#ifdef __BIG_ENDIAN_BITFIELD
   1972		uint64_t reserved_49_63:15;
   1973		uint64_t iobit:1;
   1974		uint64_t rd_addr:45;
   1975		uint64_t reserved_0_2:3;
   1976#else
   1977		uint64_t reserved_0_2:3;
   1978		uint64_t rd_addr:45;
   1979		uint64_t iobit:1;
   1980		uint64_t reserved_49_63:15;
   1981#endif
   1982	} cn38xx;
   1983};
   1984
   1985union cvmx_pci_win_rd_data {
   1986	uint64_t u64;
   1987	struct cvmx_pci_win_rd_data_s {
   1988#ifdef __BIG_ENDIAN_BITFIELD
   1989		uint64_t rd_data:64;
   1990#else
   1991		uint64_t rd_data:64;
   1992#endif
   1993	} s;
   1994};
   1995
   1996union cvmx_pci_win_wr_addr {
   1997	uint64_t u64;
   1998	struct cvmx_pci_win_wr_addr_s {
   1999#ifdef __BIG_ENDIAN_BITFIELD
   2000		uint64_t reserved_49_63:15;
   2001		uint64_t iobit:1;
   2002		uint64_t wr_addr:45;
   2003		uint64_t reserved_0_2:3;
   2004#else
   2005		uint64_t reserved_0_2:3;
   2006		uint64_t wr_addr:45;
   2007		uint64_t iobit:1;
   2008		uint64_t reserved_49_63:15;
   2009#endif
   2010	} s;
   2011};
   2012
   2013union cvmx_pci_win_wr_data {
   2014	uint64_t u64;
   2015	struct cvmx_pci_win_wr_data_s {
   2016#ifdef __BIG_ENDIAN_BITFIELD
   2017		uint64_t wr_data:64;
   2018#else
   2019		uint64_t wr_data:64;
   2020#endif
   2021	} s;
   2022};
   2023
   2024union cvmx_pci_win_wr_mask {
   2025	uint64_t u64;
   2026	struct cvmx_pci_win_wr_mask_s {
   2027#ifdef __BIG_ENDIAN_BITFIELD
   2028		uint64_t reserved_8_63:56;
   2029		uint64_t wr_mask:8;
   2030#else
   2031		uint64_t wr_mask:8;
   2032		uint64_t reserved_8_63:56;
   2033#endif
   2034	} s;
   2035};
   2036
   2037#endif