]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
mips: octeon: Add cvmx-npi-defs.h header file
authorAaron Williams <awilliams@marvell.com>
Fri, 11 Dec 2020 16:05:38 +0000 (17:05 +0100)
committerDaniel Schwierzeck <daniel.schwierzeck@gmail.com>
Fri, 23 Apr 2021 19:02:12 +0000 (21:02 +0200)
Import cvmx-npi-defs.h header file from 2013 U-Boot. It will be used
by the later added drivers to support PCIe and networking on the MIPS
Octeon II / III platforms.

Signed-off-by: Aaron Williams <awilliams@marvell.com>
Signed-off-by: Stefan Roese <sr@denx.de>
arch/mips/mach-octeon/include/mach/cvmx-npi-defs.h [new file with mode: 0644]

diff --git a/arch/mips/mach-octeon/include/mach/cvmx-npi-defs.h b/arch/mips/mach-octeon/include/mach/cvmx-npi-defs.h
new file mode 100644 (file)
index 0000000..f23ed78
--- /dev/null
@@ -0,0 +1,1953 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * Copyright (C) 2020 Marvell International Ltd.
+ *
+ * Configuration and status register (CSR) type definitions for
+ * Octeon npi.
+ */
+
+#ifndef __CVMX_NPI_DEFS_H__
+#define __CVMX_NPI_DEFS_H__
+
+#define CVMX_NPI_BASE_ADDR_INPUT0         CVMX_NPI_BASE_ADDR_INPUTX(0)
+#define CVMX_NPI_BASE_ADDR_INPUT1         CVMX_NPI_BASE_ADDR_INPUTX(1)
+#define CVMX_NPI_BASE_ADDR_INPUT2         CVMX_NPI_BASE_ADDR_INPUTX(2)
+#define CVMX_NPI_BASE_ADDR_INPUT3         CVMX_NPI_BASE_ADDR_INPUTX(3)
+#define CVMX_NPI_BASE_ADDR_INPUTX(offset)  (0x00011F0000000070ull + ((offset) & 3) * 16)
+#define CVMX_NPI_BASE_ADDR_OUTPUT0        CVMX_NPI_BASE_ADDR_OUTPUTX(0)
+#define CVMX_NPI_BASE_ADDR_OUTPUT1        CVMX_NPI_BASE_ADDR_OUTPUTX(1)
+#define CVMX_NPI_BASE_ADDR_OUTPUT2        CVMX_NPI_BASE_ADDR_OUTPUTX(2)
+#define CVMX_NPI_BASE_ADDR_OUTPUT3        CVMX_NPI_BASE_ADDR_OUTPUTX(3)
+#define CVMX_NPI_BASE_ADDR_OUTPUTX(offset) (0x00011F00000000B8ull + ((offset) & 3) * 8)
+#define CVMX_NPI_BIST_STATUS              (0x00011F00000003F8ull)
+#define CVMX_NPI_BUFF_SIZE_OUTPUT0        CVMX_NPI_BUFF_SIZE_OUTPUTX(0)
+#define CVMX_NPI_BUFF_SIZE_OUTPUT1        CVMX_NPI_BUFF_SIZE_OUTPUTX(1)
+#define CVMX_NPI_BUFF_SIZE_OUTPUT2        CVMX_NPI_BUFF_SIZE_OUTPUTX(2)
+#define CVMX_NPI_BUFF_SIZE_OUTPUT3        CVMX_NPI_BUFF_SIZE_OUTPUTX(3)
+#define CVMX_NPI_BUFF_SIZE_OUTPUTX(offset) (0x00011F00000000E0ull + ((offset) & 3) * 8)
+#define CVMX_NPI_COMP_CTL                 (0x00011F0000000218ull)
+#define CVMX_NPI_CTL_STATUS               (0x00011F0000000010ull)
+#define CVMX_NPI_DBG_SELECT               (0x00011F0000000008ull)
+#define CVMX_NPI_DMA_CONTROL              (0x00011F0000000128ull)
+#define CVMX_NPI_DMA_HIGHP_COUNTS         (0x00011F0000000148ull)
+#define CVMX_NPI_DMA_HIGHP_NADDR          (0x00011F0000000158ull)
+#define CVMX_NPI_DMA_LOWP_COUNTS          (0x00011F0000000140ull)
+#define CVMX_NPI_DMA_LOWP_NADDR                   (0x00011F0000000150ull)
+#define CVMX_NPI_HIGHP_DBELL              (0x00011F0000000120ull)
+#define CVMX_NPI_HIGHP_IBUFF_SADDR        (0x00011F0000000110ull)
+#define CVMX_NPI_INPUT_CONTROL            (0x00011F0000000138ull)
+#define CVMX_NPI_INT_ENB                  (0x00011F0000000020ull)
+#define CVMX_NPI_INT_SUM                  (0x00011F0000000018ull)
+#define CVMX_NPI_LOWP_DBELL               (0x00011F0000000118ull)
+#define CVMX_NPI_LOWP_IBUFF_SADDR         (0x00011F0000000108ull)
+#define CVMX_NPI_MEM_ACCESS_SUBID3        CVMX_NPI_MEM_ACCESS_SUBIDX(3)
+#define CVMX_NPI_MEM_ACCESS_SUBID4        CVMX_NPI_MEM_ACCESS_SUBIDX(4)
+#define CVMX_NPI_MEM_ACCESS_SUBID5        CVMX_NPI_MEM_ACCESS_SUBIDX(5)
+#define CVMX_NPI_MEM_ACCESS_SUBID6        CVMX_NPI_MEM_ACCESS_SUBIDX(6)
+#define CVMX_NPI_MEM_ACCESS_SUBIDX(offset) (0x00011F0000000028ull + ((offset) & 7) * 8 - 8 * 3)
+#define CVMX_NPI_MSI_RCV                  (0x0000000000000190ull)
+#define CVMX_NPI_NPI_MSI_RCV              (0x00011F0000001190ull)
+#define CVMX_NPI_NUM_DESC_OUTPUT0         CVMX_NPI_NUM_DESC_OUTPUTX(0)
+#define CVMX_NPI_NUM_DESC_OUTPUT1         CVMX_NPI_NUM_DESC_OUTPUTX(1)
+#define CVMX_NPI_NUM_DESC_OUTPUT2         CVMX_NPI_NUM_DESC_OUTPUTX(2)
+#define CVMX_NPI_NUM_DESC_OUTPUT3         CVMX_NPI_NUM_DESC_OUTPUTX(3)
+#define CVMX_NPI_NUM_DESC_OUTPUTX(offset)  (0x00011F0000000050ull + ((offset) & 3) * 8)
+#define CVMX_NPI_OUTPUT_CONTROL                   (0x00011F0000000100ull)
+#define CVMX_NPI_P0_DBPAIR_ADDR                   CVMX_NPI_PX_DBPAIR_ADDR(0)
+#define CVMX_NPI_P0_INSTR_ADDR            CVMX_NPI_PX_INSTR_ADDR(0)
+#define CVMX_NPI_P0_INSTR_CNTS            CVMX_NPI_PX_INSTR_CNTS(0)
+#define CVMX_NPI_P0_PAIR_CNTS             CVMX_NPI_PX_PAIR_CNTS(0)
+#define CVMX_NPI_P1_DBPAIR_ADDR                   CVMX_NPI_PX_DBPAIR_ADDR(1)
+#define CVMX_NPI_P1_INSTR_ADDR            CVMX_NPI_PX_INSTR_ADDR(1)
+#define CVMX_NPI_P1_INSTR_CNTS            CVMX_NPI_PX_INSTR_CNTS(1)
+#define CVMX_NPI_P1_PAIR_CNTS             CVMX_NPI_PX_PAIR_CNTS(1)
+#define CVMX_NPI_P2_DBPAIR_ADDR                   CVMX_NPI_PX_DBPAIR_ADDR(2)
+#define CVMX_NPI_P2_INSTR_ADDR            CVMX_NPI_PX_INSTR_ADDR(2)
+#define CVMX_NPI_P2_INSTR_CNTS            CVMX_NPI_PX_INSTR_CNTS(2)
+#define CVMX_NPI_P2_PAIR_CNTS             CVMX_NPI_PX_PAIR_CNTS(2)
+#define CVMX_NPI_P3_DBPAIR_ADDR                   CVMX_NPI_PX_DBPAIR_ADDR(3)
+#define CVMX_NPI_P3_INSTR_ADDR            CVMX_NPI_PX_INSTR_ADDR(3)
+#define CVMX_NPI_P3_INSTR_CNTS            CVMX_NPI_PX_INSTR_CNTS(3)
+#define CVMX_NPI_P3_PAIR_CNTS             CVMX_NPI_PX_PAIR_CNTS(3)
+#define CVMX_NPI_PCI_BAR1_INDEXX(offset)   (0x00011F0000001100ull + ((offset) & 31) * 4)
+#define CVMX_NPI_PCI_BIST_REG             (0x00011F00000011C0ull)
+#define CVMX_NPI_PCI_BURST_SIZE                   (0x00011F00000000D8ull)
+#define CVMX_NPI_PCI_CFG00                (0x00011F0000001800ull)
+#define CVMX_NPI_PCI_CFG01                (0x00011F0000001804ull)
+#define CVMX_NPI_PCI_CFG02                (0x00011F0000001808ull)
+#define CVMX_NPI_PCI_CFG03                (0x00011F000000180Cull)
+#define CVMX_NPI_PCI_CFG04                (0x00011F0000001810ull)
+#define CVMX_NPI_PCI_CFG05                (0x00011F0000001814ull)
+#define CVMX_NPI_PCI_CFG06                (0x00011F0000001818ull)
+#define CVMX_NPI_PCI_CFG07                (0x00011F000000181Cull)
+#define CVMX_NPI_PCI_CFG08                (0x00011F0000001820ull)
+#define CVMX_NPI_PCI_CFG09                (0x00011F0000001824ull)
+#define CVMX_NPI_PCI_CFG10                (0x00011F0000001828ull)
+#define CVMX_NPI_PCI_CFG11                (0x00011F000000182Cull)
+#define CVMX_NPI_PCI_CFG12                (0x00011F0000001830ull)
+#define CVMX_NPI_PCI_CFG13                (0x00011F0000001834ull)
+#define CVMX_NPI_PCI_CFG15                (0x00011F000000183Cull)
+#define CVMX_NPI_PCI_CFG16                (0x00011F0000001840ull)
+#define CVMX_NPI_PCI_CFG17                (0x00011F0000001844ull)
+#define CVMX_NPI_PCI_CFG18                (0x00011F0000001848ull)
+#define CVMX_NPI_PCI_CFG19                (0x00011F000000184Cull)
+#define CVMX_NPI_PCI_CFG20                (0x00011F0000001850ull)
+#define CVMX_NPI_PCI_CFG21                (0x00011F0000001854ull)
+#define CVMX_NPI_PCI_CFG22                (0x00011F0000001858ull)
+#define CVMX_NPI_PCI_CFG56                (0x00011F00000018E0ull)
+#define CVMX_NPI_PCI_CFG57                (0x00011F00000018E4ull)
+#define CVMX_NPI_PCI_CFG58                (0x00011F00000018E8ull)
+#define CVMX_NPI_PCI_CFG59                (0x00011F00000018ECull)
+#define CVMX_NPI_PCI_CFG60                (0x00011F00000018F0ull)
+#define CVMX_NPI_PCI_CFG61                (0x00011F00000018F4ull)
+#define CVMX_NPI_PCI_CFG62                (0x00011F00000018F8ull)
+#define CVMX_NPI_PCI_CFG63                (0x00011F00000018FCull)
+#define CVMX_NPI_PCI_CNT_REG              (0x00011F00000011B8ull)
+#define CVMX_NPI_PCI_CTL_STATUS_2         (0x00011F000000118Cull)
+#define CVMX_NPI_PCI_INT_ARB_CFG          (0x00011F0000000130ull)
+#define CVMX_NPI_PCI_INT_ENB2             (0x00011F00000011A0ull)
+#define CVMX_NPI_PCI_INT_SUM2             (0x00011F0000001198ull)
+#define CVMX_NPI_PCI_READ_CMD             (0x00011F0000000048ull)
+#define CVMX_NPI_PCI_READ_CMD_6                   (0x00011F0000001180ull)
+#define CVMX_NPI_PCI_READ_CMD_C                   (0x00011F0000001184ull)
+#define CVMX_NPI_PCI_READ_CMD_E                   (0x00011F0000001188ull)
+#define CVMX_NPI_PCI_SCM_REG              (0x00011F00000011A8ull)
+#define CVMX_NPI_PCI_TSR_REG              (0x00011F00000011B0ull)
+#define CVMX_NPI_PORT32_INSTR_HDR         (0x00011F00000001F8ull)
+#define CVMX_NPI_PORT33_INSTR_HDR         (0x00011F0000000200ull)
+#define CVMX_NPI_PORT34_INSTR_HDR         (0x00011F0000000208ull)
+#define CVMX_NPI_PORT35_INSTR_HDR         (0x00011F0000000210ull)
+#define CVMX_NPI_PORT_BP_CONTROL          (0x00011F00000001F0ull)
+#define CVMX_NPI_PX_DBPAIR_ADDR(offset)           (0x00011F0000000180ull + ((offset) & 3) * 8)
+#define CVMX_NPI_PX_INSTR_ADDR(offset)    (0x00011F00000001C0ull + ((offset) & 3) * 8)
+#define CVMX_NPI_PX_INSTR_CNTS(offset)    (0x00011F00000001A0ull + ((offset) & 3) * 8)
+#define CVMX_NPI_PX_PAIR_CNTS(offset)     (0x00011F0000000160ull + ((offset) & 3) * 8)
+#define CVMX_NPI_RSL_INT_BLOCKS                   (0x00011F0000000000ull)
+#define CVMX_NPI_SIZE_INPUT0              CVMX_NPI_SIZE_INPUTX(0)
+#define CVMX_NPI_SIZE_INPUT1              CVMX_NPI_SIZE_INPUTX(1)
+#define CVMX_NPI_SIZE_INPUT2              CVMX_NPI_SIZE_INPUTX(2)
+#define CVMX_NPI_SIZE_INPUT3              CVMX_NPI_SIZE_INPUTX(3)
+#define CVMX_NPI_SIZE_INPUTX(offset)      (0x00011F0000000078ull + ((offset) & 3) * 16)
+#define CVMX_NPI_WIN_READ_TO              (0x00011F00000001E0ull)
+
+/**
+ * cvmx_npi_base_addr_input#
+ *
+ * NPI_BASE_ADDR_INPUT0 = NPI's Base Address Input 0 Register
+ *
+ * The address to start reading Instructions from for Input-0.
+ */
+union cvmx_npi_base_addr_inputx {
+       u64 u64;
+       struct cvmx_npi_base_addr_inputx_s {
+               u64 baddr : 61;
+               u64 reserved_0_2 : 3;
+       } s;
+       struct cvmx_npi_base_addr_inputx_s cn30xx;
+       struct cvmx_npi_base_addr_inputx_s cn31xx;
+       struct cvmx_npi_base_addr_inputx_s cn38xx;
+       struct cvmx_npi_base_addr_inputx_s cn38xxp2;
+       struct cvmx_npi_base_addr_inputx_s cn50xx;
+       struct cvmx_npi_base_addr_inputx_s cn58xx;
+       struct cvmx_npi_base_addr_inputx_s cn58xxp1;
+};
+
+typedef union cvmx_npi_base_addr_inputx cvmx_npi_base_addr_inputx_t;
+
+/**
+ * cvmx_npi_base_addr_output#
+ *
+ * NPI_BASE_ADDR_OUTPUT0 = NPI's Base Address Output 0 Register
+ *
+ * The address to start reading Instructions from for Output-0.
+ */
+union cvmx_npi_base_addr_outputx {
+       u64 u64;
+       struct cvmx_npi_base_addr_outputx_s {
+               u64 baddr : 61;
+               u64 reserved_0_2 : 3;
+       } s;
+       struct cvmx_npi_base_addr_outputx_s cn30xx;
+       struct cvmx_npi_base_addr_outputx_s cn31xx;
+       struct cvmx_npi_base_addr_outputx_s cn38xx;
+       struct cvmx_npi_base_addr_outputx_s cn38xxp2;
+       struct cvmx_npi_base_addr_outputx_s cn50xx;
+       struct cvmx_npi_base_addr_outputx_s cn58xx;
+       struct cvmx_npi_base_addr_outputx_s cn58xxp1;
+};
+
+typedef union cvmx_npi_base_addr_outputx cvmx_npi_base_addr_outputx_t;
+
+/**
+ * cvmx_npi_bist_status
+ *
+ * NPI_BIST_STATUS = NPI's BIST Status Register
+ *
+ * Results from BIST runs of NPI's memories.
+ */
+union cvmx_npi_bist_status {
+       u64 u64;
+       struct cvmx_npi_bist_status_s {
+               u64 reserved_20_63 : 44;
+               u64 csr_bs : 1;
+               u64 dif_bs : 1;
+               u64 rdp_bs : 1;
+               u64 pcnc_bs : 1;
+               u64 pcn_bs : 1;
+               u64 rdn_bs : 1;
+               u64 pcac_bs : 1;
+               u64 pcad_bs : 1;
+               u64 rdnl_bs : 1;
+               u64 pgf_bs : 1;
+               u64 pig_bs : 1;
+               u64 pof0_bs : 1;
+               u64 pof1_bs : 1;
+               u64 pof2_bs : 1;
+               u64 pof3_bs : 1;
+               u64 pos_bs : 1;
+               u64 nus_bs : 1;
+               u64 dob_bs : 1;
+               u64 pdf_bs : 1;
+               u64 dpi_bs : 1;
+       } s;
+       struct cvmx_npi_bist_status_cn30xx {
+               u64 reserved_20_63 : 44;
+               u64 csr_bs : 1;
+               u64 dif_bs : 1;
+               u64 rdp_bs : 1;
+               u64 pcnc_bs : 1;
+               u64 pcn_bs : 1;
+               u64 rdn_bs : 1;
+               u64 pcac_bs : 1;
+               u64 pcad_bs : 1;
+               u64 rdnl_bs : 1;
+               u64 pgf_bs : 1;
+               u64 pig_bs : 1;
+               u64 pof0_bs : 1;
+               u64 reserved_5_7 : 3;
+               u64 pos_bs : 1;
+               u64 nus_bs : 1;
+               u64 dob_bs : 1;
+               u64 pdf_bs : 1;
+               u64 dpi_bs : 1;
+       } cn30xx;
+       struct cvmx_npi_bist_status_s cn31xx;
+       struct cvmx_npi_bist_status_s cn38xx;
+       struct cvmx_npi_bist_status_s cn38xxp2;
+       struct cvmx_npi_bist_status_cn50xx {
+               u64 reserved_20_63 : 44;
+               u64 csr_bs : 1;
+               u64 dif_bs : 1;
+               u64 rdp_bs : 1;
+               u64 pcnc_bs : 1;
+               u64 pcn_bs : 1;
+               u64 rdn_bs : 1;
+               u64 pcac_bs : 1;
+               u64 pcad_bs : 1;
+               u64 rdnl_bs : 1;
+               u64 pgf_bs : 1;
+               u64 pig_bs : 1;
+               u64 pof0_bs : 1;
+               u64 pof1_bs : 1;
+               u64 reserved_5_6 : 2;
+               u64 pos_bs : 1;
+               u64 nus_bs : 1;
+               u64 dob_bs : 1;
+               u64 pdf_bs : 1;
+               u64 dpi_bs : 1;
+       } cn50xx;
+       struct cvmx_npi_bist_status_s cn58xx;
+       struct cvmx_npi_bist_status_s cn58xxp1;
+};
+
+typedef union cvmx_npi_bist_status cvmx_npi_bist_status_t;
+
+/**
+ * cvmx_npi_buff_size_output#
+ *
+ * NPI_BUFF_SIZE_OUTPUT0 = NPI's D/I Buffer Sizes For Output 0
+ *
+ * The size in bytes of the Data Bufffer and Information Buffer for output 0.
+ */
+union cvmx_npi_buff_size_outputx {
+       u64 u64;
+       struct cvmx_npi_buff_size_outputx_s {
+               u64 reserved_23_63 : 41;
+               u64 isize : 7;
+               u64 bsize : 16;
+       } s;
+       struct cvmx_npi_buff_size_outputx_s cn30xx;
+       struct cvmx_npi_buff_size_outputx_s cn31xx;
+       struct cvmx_npi_buff_size_outputx_s cn38xx;
+       struct cvmx_npi_buff_size_outputx_s cn38xxp2;
+       struct cvmx_npi_buff_size_outputx_s cn50xx;
+       struct cvmx_npi_buff_size_outputx_s cn58xx;
+       struct cvmx_npi_buff_size_outputx_s cn58xxp1;
+};
+
+typedef union cvmx_npi_buff_size_outputx cvmx_npi_buff_size_outputx_t;
+
+/**
+ * cvmx_npi_comp_ctl
+ *
+ * NPI_COMP_CTL = PCI Compensation Control
+ *
+ * PCI Compensation Control
+ */
+union cvmx_npi_comp_ctl {
+       u64 u64;
+       struct cvmx_npi_comp_ctl_s {
+               u64 reserved_10_63 : 54;
+               u64 pctl : 5;
+               u64 nctl : 5;
+       } s;
+       struct cvmx_npi_comp_ctl_s cn50xx;
+       struct cvmx_npi_comp_ctl_s cn58xx;
+       struct cvmx_npi_comp_ctl_s cn58xxp1;
+};
+
+typedef union cvmx_npi_comp_ctl cvmx_npi_comp_ctl_t;
+
+/**
+ * cvmx_npi_ctl_status
+ *
+ * NPI_CTL_STATUS = NPI's Control Status Register
+ *
+ * Contains control ans status for NPI.
+ * Writes to this register are not ordered with writes/reads to the PCI Memory space.
+ * To ensure that a write has completed the user must read the register before
+ * making an access(i.e. PCI memory space) that requires the value of this register to be updated.
+ */
+union cvmx_npi_ctl_status {
+       u64 u64;
+       struct cvmx_npi_ctl_status_s {
+               u64 reserved_63_63 : 1;
+               u64 chip_rev : 8;
+               u64 dis_pniw : 1;
+               u64 out3_enb : 1;
+               u64 out2_enb : 1;
+               u64 out1_enb : 1;
+               u64 out0_enb : 1;
+               u64 ins3_enb : 1;
+               u64 ins2_enb : 1;
+               u64 ins1_enb : 1;
+               u64 ins0_enb : 1;
+               u64 ins3_64b : 1;
+               u64 ins2_64b : 1;
+               u64 ins1_64b : 1;
+               u64 ins0_64b : 1;
+               u64 pci_wdis : 1;
+               u64 wait_com : 1;
+               u64 reserved_37_39 : 3;
+               u64 max_word : 5;
+               u64 reserved_10_31 : 22;
+               u64 timer : 10;
+       } s;
+       struct cvmx_npi_ctl_status_cn30xx {
+               u64 reserved_63_63 : 1;
+               u64 chip_rev : 8;
+               u64 dis_pniw : 1;
+               u64 reserved_51_53 : 3;
+               u64 out0_enb : 1;
+               u64 reserved_47_49 : 3;
+               u64 ins0_enb : 1;
+               u64 reserved_43_45 : 3;
+               u64 ins0_64b : 1;
+               u64 pci_wdis : 1;
+               u64 wait_com : 1;
+               u64 reserved_37_39 : 3;
+               u64 max_word : 5;
+               u64 reserved_10_31 : 22;
+               u64 timer : 10;
+       } cn30xx;
+       struct cvmx_npi_ctl_status_cn31xx {
+               u64 reserved_63_63 : 1;
+               u64 chip_rev : 8;
+               u64 dis_pniw : 1;
+               u64 reserved_52_53 : 2;
+               u64 out1_enb : 1;
+               u64 out0_enb : 1;
+               u64 reserved_48_49 : 2;
+               u64 ins1_enb : 1;
+               u64 ins0_enb : 1;
+               u64 reserved_44_45 : 2;
+               u64 ins1_64b : 1;
+               u64 ins0_64b : 1;
+               u64 pci_wdis : 1;
+               u64 wait_com : 1;
+               u64 reserved_37_39 : 3;
+               u64 max_word : 5;
+               u64 reserved_10_31 : 22;
+               u64 timer : 10;
+       } cn31xx;
+       struct cvmx_npi_ctl_status_s cn38xx;
+       struct cvmx_npi_ctl_status_s cn38xxp2;
+       struct cvmx_npi_ctl_status_cn31xx cn50xx;
+       struct cvmx_npi_ctl_status_s cn58xx;
+       struct cvmx_npi_ctl_status_s cn58xxp1;
+};
+
+typedef union cvmx_npi_ctl_status cvmx_npi_ctl_status_t;
+
+/**
+ * cvmx_npi_dbg_select
+ *
+ * NPI_DBG_SELECT = Debug Select Register
+ *
+ * Contains the debug select value in last written to the RSLs.
+ */
+union cvmx_npi_dbg_select {
+       u64 u64;
+       struct cvmx_npi_dbg_select_s {
+               u64 reserved_16_63 : 48;
+               u64 dbg_sel : 16;
+       } s;
+       struct cvmx_npi_dbg_select_s cn30xx;
+       struct cvmx_npi_dbg_select_s cn31xx;
+       struct cvmx_npi_dbg_select_s cn38xx;
+       struct cvmx_npi_dbg_select_s cn38xxp2;
+       struct cvmx_npi_dbg_select_s cn50xx;
+       struct cvmx_npi_dbg_select_s cn58xx;
+       struct cvmx_npi_dbg_select_s cn58xxp1;
+};
+
+typedef union cvmx_npi_dbg_select cvmx_npi_dbg_select_t;
+
+/**
+ * cvmx_npi_dma_control
+ *
+ * NPI_DMA_CONTROL = DMA Control Register
+ *
+ * Controls operation of the DMA IN/OUT of the NPI.
+ */
+union cvmx_npi_dma_control {
+       u64 u64;
+       struct cvmx_npi_dma_control_s {
+               u64 reserved_36_63 : 28;
+               u64 b0_lend : 1;
+               u64 dwb_denb : 1;
+               u64 dwb_ichk : 9;
+               u64 fpa_que : 3;
+               u64 o_add1 : 1;
+               u64 o_ro : 1;
+               u64 o_ns : 1;
+               u64 o_es : 2;
+               u64 o_mode : 1;
+               u64 hp_enb : 1;
+               u64 lp_enb : 1;
+               u64 csize : 14;
+       } s;
+       struct cvmx_npi_dma_control_s cn30xx;
+       struct cvmx_npi_dma_control_s cn31xx;
+       struct cvmx_npi_dma_control_s cn38xx;
+       struct cvmx_npi_dma_control_s cn38xxp2;
+       struct cvmx_npi_dma_control_s cn50xx;
+       struct cvmx_npi_dma_control_s cn58xx;
+       struct cvmx_npi_dma_control_s cn58xxp1;
+};
+
+typedef union cvmx_npi_dma_control cvmx_npi_dma_control_t;
+
+/**
+ * cvmx_npi_dma_highp_counts
+ *
+ * NPI_DMA_HIGHP_COUNTS = NPI's High Priority DMA Counts
+ *
+ * Values for determing the number of instructions for High Priority DMA in the NPI.
+ */
+union cvmx_npi_dma_highp_counts {
+       u64 u64;
+       struct cvmx_npi_dma_highp_counts_s {
+               u64 reserved_39_63 : 25;
+               u64 fcnt : 7;
+               u64 dbell : 32;
+       } s;
+       struct cvmx_npi_dma_highp_counts_s cn30xx;
+       struct cvmx_npi_dma_highp_counts_s cn31xx;
+       struct cvmx_npi_dma_highp_counts_s cn38xx;
+       struct cvmx_npi_dma_highp_counts_s cn38xxp2;
+       struct cvmx_npi_dma_highp_counts_s cn50xx;
+       struct cvmx_npi_dma_highp_counts_s cn58xx;
+       struct cvmx_npi_dma_highp_counts_s cn58xxp1;
+};
+
+typedef union cvmx_npi_dma_highp_counts cvmx_npi_dma_highp_counts_t;
+
+/**
+ * cvmx_npi_dma_highp_naddr
+ *
+ * NPI_DMA_HIGHP_NADDR = NPI's High Priority DMA Next Ichunk Address
+ *
+ * Place NPI will read the next Ichunk data from. This is valid when state is 0
+ */
+union cvmx_npi_dma_highp_naddr {
+       u64 u64;
+       struct cvmx_npi_dma_highp_naddr_s {
+               u64 reserved_40_63 : 24;
+               u64 state : 4;
+               u64 addr : 36;
+       } s;
+       struct cvmx_npi_dma_highp_naddr_s cn30xx;
+       struct cvmx_npi_dma_highp_naddr_s cn31xx;
+       struct cvmx_npi_dma_highp_naddr_s cn38xx;
+       struct cvmx_npi_dma_highp_naddr_s cn38xxp2;
+       struct cvmx_npi_dma_highp_naddr_s cn50xx;
+       struct cvmx_npi_dma_highp_naddr_s cn58xx;
+       struct cvmx_npi_dma_highp_naddr_s cn58xxp1;
+};
+
+typedef union cvmx_npi_dma_highp_naddr cvmx_npi_dma_highp_naddr_t;
+
+/**
+ * cvmx_npi_dma_lowp_counts
+ *
+ * NPI_DMA_LOWP_COUNTS = NPI's Low Priority DMA Counts
+ *
+ * Values for determing the number of instructions for Low Priority DMA in the NPI.
+ */
+union cvmx_npi_dma_lowp_counts {
+       u64 u64;
+       struct cvmx_npi_dma_lowp_counts_s {
+               u64 reserved_39_63 : 25;
+               u64 fcnt : 7;
+               u64 dbell : 32;
+       } s;
+       struct cvmx_npi_dma_lowp_counts_s cn30xx;
+       struct cvmx_npi_dma_lowp_counts_s cn31xx;
+       struct cvmx_npi_dma_lowp_counts_s cn38xx;
+       struct cvmx_npi_dma_lowp_counts_s cn38xxp2;
+       struct cvmx_npi_dma_lowp_counts_s cn50xx;
+       struct cvmx_npi_dma_lowp_counts_s cn58xx;
+       struct cvmx_npi_dma_lowp_counts_s cn58xxp1;
+};
+
+typedef union cvmx_npi_dma_lowp_counts cvmx_npi_dma_lowp_counts_t;
+
+/**
+ * cvmx_npi_dma_lowp_naddr
+ *
+ * NPI_DMA_LOWP_NADDR = NPI's Low Priority DMA Next Ichunk Address
+ *
+ * Place NPI will read the next Ichunk data from. This is valid when state is 0
+ */
+union cvmx_npi_dma_lowp_naddr {
+       u64 u64;
+       struct cvmx_npi_dma_lowp_naddr_s {
+               u64 reserved_40_63 : 24;
+               u64 state : 4;
+               u64 addr : 36;
+       } s;
+       struct cvmx_npi_dma_lowp_naddr_s cn30xx;
+       struct cvmx_npi_dma_lowp_naddr_s cn31xx;
+       struct cvmx_npi_dma_lowp_naddr_s cn38xx;
+       struct cvmx_npi_dma_lowp_naddr_s cn38xxp2;
+       struct cvmx_npi_dma_lowp_naddr_s cn50xx;
+       struct cvmx_npi_dma_lowp_naddr_s cn58xx;
+       struct cvmx_npi_dma_lowp_naddr_s cn58xxp1;
+};
+
+typedef union cvmx_npi_dma_lowp_naddr cvmx_npi_dma_lowp_naddr_t;
+
+/**
+ * cvmx_npi_highp_dbell
+ *
+ * NPI_HIGHP_DBELL = High Priority Door Bell
+ *
+ * The door bell register for the high priority DMA queue.
+ */
+union cvmx_npi_highp_dbell {
+       u64 u64;
+       struct cvmx_npi_highp_dbell_s {
+               u64 reserved_16_63 : 48;
+               u64 dbell : 16;
+       } s;
+       struct cvmx_npi_highp_dbell_s cn30xx;
+       struct cvmx_npi_highp_dbell_s cn31xx;
+       struct cvmx_npi_highp_dbell_s cn38xx;
+       struct cvmx_npi_highp_dbell_s cn38xxp2;
+       struct cvmx_npi_highp_dbell_s cn50xx;
+       struct cvmx_npi_highp_dbell_s cn58xx;
+       struct cvmx_npi_highp_dbell_s cn58xxp1;
+};
+
+typedef union cvmx_npi_highp_dbell cvmx_npi_highp_dbell_t;
+
+/**
+ * cvmx_npi_highp_ibuff_saddr
+ *
+ * NPI_HIGHP_IBUFF_SADDR = DMA High Priority Instruction Buffer Starting Address
+ *
+ * The address to start reading Instructions from for HIGHP.
+ */
+union cvmx_npi_highp_ibuff_saddr {
+       u64 u64;
+       struct cvmx_npi_highp_ibuff_saddr_s {
+               u64 reserved_36_63 : 28;
+               u64 saddr : 36;
+       } s;
+       struct cvmx_npi_highp_ibuff_saddr_s cn30xx;
+       struct cvmx_npi_highp_ibuff_saddr_s cn31xx;
+       struct cvmx_npi_highp_ibuff_saddr_s cn38xx;
+       struct cvmx_npi_highp_ibuff_saddr_s cn38xxp2;
+       struct cvmx_npi_highp_ibuff_saddr_s cn50xx;
+       struct cvmx_npi_highp_ibuff_saddr_s cn58xx;
+       struct cvmx_npi_highp_ibuff_saddr_s cn58xxp1;
+};
+
+typedef union cvmx_npi_highp_ibuff_saddr cvmx_npi_highp_ibuff_saddr_t;
+
+/**
+ * cvmx_npi_input_control
+ *
+ * NPI_INPUT_CONTROL = NPI's Input Control Register
+ *
+ * Control for reads for gather list and instructions.
+ */
+union cvmx_npi_input_control {
+       u64 u64;
+       struct cvmx_npi_input_control_s {
+               u64 reserved_23_63 : 41;
+               u64 pkt_rr : 1;
+               u64 pbp_dhi : 13;
+               u64 d_nsr : 1;
+               u64 d_esr : 2;
+               u64 d_ror : 1;
+               u64 use_csr : 1;
+               u64 nsr : 1;
+               u64 esr : 2;
+               u64 ror : 1;
+       } s;
+       struct cvmx_npi_input_control_cn30xx {
+               u64 reserved_22_63 : 42;
+               u64 pbp_dhi : 13;
+               u64 d_nsr : 1;
+               u64 d_esr : 2;
+               u64 d_ror : 1;
+               u64 use_csr : 1;
+               u64 nsr : 1;
+               u64 esr : 2;
+               u64 ror : 1;
+       } cn30xx;
+       struct cvmx_npi_input_control_cn30xx cn31xx;
+       struct cvmx_npi_input_control_s cn38xx;
+       struct cvmx_npi_input_control_cn30xx cn38xxp2;
+       struct cvmx_npi_input_control_s cn50xx;
+       struct cvmx_npi_input_control_s cn58xx;
+       struct cvmx_npi_input_control_s cn58xxp1;
+};
+
+typedef union cvmx_npi_input_control cvmx_npi_input_control_t;
+
+/**
+ * cvmx_npi_int_enb
+ *
+ * NPI_INTERRUPT_ENB = NPI's Interrupt Enable Register
+ *
+ * Used to enable the various interrupting conditions of NPI
+ */
+union cvmx_npi_int_enb {
+       u64 u64;
+       struct cvmx_npi_int_enb_s {
+               u64 reserved_62_63 : 2;
+               u64 q1_a_f : 1;
+               u64 q1_s_e : 1;
+               u64 pdf_p_f : 1;
+               u64 pdf_p_e : 1;
+               u64 pcf_p_f : 1;
+               u64 pcf_p_e : 1;
+               u64 rdx_s_e : 1;
+               u64 rwx_s_e : 1;
+               u64 pnc_a_f : 1;
+               u64 pnc_s_e : 1;
+               u64 com_a_f : 1;
+               u64 com_s_e : 1;
+               u64 q3_a_f : 1;
+               u64 q3_s_e : 1;
+               u64 q2_a_f : 1;
+               u64 q2_s_e : 1;
+               u64 pcr_a_f : 1;
+               u64 pcr_s_e : 1;
+               u64 fcr_a_f : 1;
+               u64 fcr_s_e : 1;
+               u64 iobdma : 1;
+               u64 p_dperr : 1;
+               u64 win_rto : 1;
+               u64 i3_pperr : 1;
+               u64 i2_pperr : 1;
+               u64 i1_pperr : 1;
+               u64 i0_pperr : 1;
+               u64 p3_ptout : 1;
+               u64 p2_ptout : 1;
+               u64 p1_ptout : 1;
+               u64 p0_ptout : 1;
+               u64 p3_pperr : 1;
+               u64 p2_pperr : 1;
+               u64 p1_pperr : 1;
+               u64 p0_pperr : 1;
+               u64 g3_rtout : 1;
+               u64 g2_rtout : 1;
+               u64 g1_rtout : 1;
+               u64 g0_rtout : 1;
+               u64 p3_perr : 1;
+               u64 p2_perr : 1;
+               u64 p1_perr : 1;
+               u64 p0_perr : 1;
+               u64 p3_rtout : 1;
+               u64 p2_rtout : 1;
+               u64 p1_rtout : 1;
+               u64 p0_rtout : 1;
+               u64 i3_overf : 1;
+               u64 i2_overf : 1;
+               u64 i1_overf : 1;
+               u64 i0_overf : 1;
+               u64 i3_rtout : 1;
+               u64 i2_rtout : 1;
+               u64 i1_rtout : 1;
+               u64 i0_rtout : 1;
+               u64 po3_2sml : 1;
+               u64 po2_2sml : 1;
+               u64 po1_2sml : 1;
+               u64 po0_2sml : 1;
+               u64 pci_rsl : 1;
+               u64 rml_wto : 1;
+               u64 rml_rto : 1;
+       } s;
+       struct cvmx_npi_int_enb_cn30xx {
+               u64 reserved_62_63 : 2;
+               u64 q1_a_f : 1;
+               u64 q1_s_e : 1;
+               u64 pdf_p_f : 1;
+               u64 pdf_p_e : 1;
+               u64 pcf_p_f : 1;
+               u64 pcf_p_e : 1;
+               u64 rdx_s_e : 1;
+               u64 rwx_s_e : 1;
+               u64 pnc_a_f : 1;
+               u64 pnc_s_e : 1;
+               u64 com_a_f : 1;
+               u64 com_s_e : 1;
+               u64 q3_a_f : 1;
+               u64 q3_s_e : 1;
+               u64 q2_a_f : 1;
+               u64 q2_s_e : 1;
+               u64 pcr_a_f : 1;
+               u64 pcr_s_e : 1;
+               u64 fcr_a_f : 1;
+               u64 fcr_s_e : 1;
+               u64 iobdma : 1;
+               u64 p_dperr : 1;
+               u64 win_rto : 1;
+               u64 reserved_36_38 : 3;
+               u64 i0_pperr : 1;
+               u64 reserved_32_34 : 3;
+               u64 p0_ptout : 1;
+               u64 reserved_28_30 : 3;
+               u64 p0_pperr : 1;
+               u64 reserved_24_26 : 3;
+               u64 g0_rtout : 1;
+               u64 reserved_20_22 : 3;
+               u64 p0_perr : 1;
+               u64 reserved_16_18 : 3;
+               u64 p0_rtout : 1;
+               u64 reserved_12_14 : 3;
+               u64 i0_overf : 1;
+               u64 reserved_8_10 : 3;
+               u64 i0_rtout : 1;
+               u64 reserved_4_6 : 3;
+               u64 po0_2sml : 1;
+               u64 pci_rsl : 1;
+               u64 rml_wto : 1;
+               u64 rml_rto : 1;
+       } cn30xx;
+       struct cvmx_npi_int_enb_cn31xx {
+               u64 reserved_62_63 : 2;
+               u64 q1_a_f : 1;
+               u64 q1_s_e : 1;
+               u64 pdf_p_f : 1;
+               u64 pdf_p_e : 1;
+               u64 pcf_p_f : 1;
+               u64 pcf_p_e : 1;
+               u64 rdx_s_e : 1;
+               u64 rwx_s_e : 1;
+               u64 pnc_a_f : 1;
+               u64 pnc_s_e : 1;
+               u64 com_a_f : 1;
+               u64 com_s_e : 1;
+               u64 q3_a_f : 1;
+               u64 q3_s_e : 1;
+               u64 q2_a_f : 1;
+               u64 q2_s_e : 1;
+               u64 pcr_a_f : 1;
+               u64 pcr_s_e : 1;
+               u64 fcr_a_f : 1;
+               u64 fcr_s_e : 1;
+               u64 iobdma : 1;
+               u64 p_dperr : 1;
+               u64 win_rto : 1;
+               u64 reserved_37_38 : 2;
+               u64 i1_pperr : 1;
+               u64 i0_pperr : 1;
+               u64 reserved_33_34 : 2;
+               u64 p1_ptout : 1;
+               u64 p0_ptout : 1;
+               u64 reserved_29_30 : 2;
+               u64 p1_pperr : 1;
+               u64 p0_pperr : 1;
+               u64 reserved_25_26 : 2;
+               u64 g1_rtout : 1;
+               u64 g0_rtout : 1;
+               u64 reserved_21_22 : 2;
+               u64 p1_perr : 1;
+               u64 p0_perr : 1;
+               u64 reserved_17_18 : 2;
+               u64 p1_rtout : 1;
+               u64 p0_rtout : 1;
+               u64 reserved_13_14 : 2;
+               u64 i1_overf : 1;
+               u64 i0_overf : 1;
+               u64 reserved_9_10 : 2;
+               u64 i1_rtout : 1;
+               u64 i0_rtout : 1;
+               u64 reserved_5_6 : 2;
+               u64 po1_2sml : 1;
+               u64 po0_2sml : 1;
+               u64 pci_rsl : 1;
+               u64 rml_wto : 1;
+               u64 rml_rto : 1;
+       } cn31xx;
+       struct cvmx_npi_int_enb_s cn38xx;
+       struct cvmx_npi_int_enb_cn38xxp2 {
+               u64 reserved_42_63 : 22;
+               u64 iobdma : 1;
+               u64 p_dperr : 1;
+               u64 win_rto : 1;
+               u64 i3_pperr : 1;
+               u64 i2_pperr : 1;
+               u64 i1_pperr : 1;
+               u64 i0_pperr : 1;
+               u64 p3_ptout : 1;
+               u64 p2_ptout : 1;
+               u64 p1_ptout : 1;
+               u64 p0_ptout : 1;
+               u64 p3_pperr : 1;
+               u64 p2_pperr : 1;
+               u64 p1_pperr : 1;
+               u64 p0_pperr : 1;
+               u64 g3_rtout : 1;
+               u64 g2_rtout : 1;
+               u64 g1_rtout : 1;
+               u64 g0_rtout : 1;
+               u64 p3_perr : 1;
+               u64 p2_perr : 1;
+               u64 p1_perr : 1;
+               u64 p0_perr : 1;
+               u64 p3_rtout : 1;
+               u64 p2_rtout : 1;
+               u64 p1_rtout : 1;
+               u64 p0_rtout : 1;
+               u64 i3_overf : 1;
+               u64 i2_overf : 1;
+               u64 i1_overf : 1;
+               u64 i0_overf : 1;
+               u64 i3_rtout : 1;
+               u64 i2_rtout : 1;
+               u64 i1_rtout : 1;
+               u64 i0_rtout : 1;
+               u64 po3_2sml : 1;
+               u64 po2_2sml : 1;
+               u64 po1_2sml : 1;
+               u64 po0_2sml : 1;
+               u64 pci_rsl : 1;
+               u64 rml_wto : 1;
+               u64 rml_rto : 1;
+       } cn38xxp2;
+       struct cvmx_npi_int_enb_cn31xx cn50xx;
+       struct cvmx_npi_int_enb_s cn58xx;
+       struct cvmx_npi_int_enb_s cn58xxp1;
+};
+
+typedef union cvmx_npi_int_enb cvmx_npi_int_enb_t;
+
+/**
+ * cvmx_npi_int_sum
+ *
+ * NPI_INTERRUPT_SUM = NPI Interrupt Summary Register
+ *
+ * Set when an interrupt condition occurs, write '1' to clear.
+ */
+union cvmx_npi_int_sum {
+       u64 u64;
+       struct cvmx_npi_int_sum_s {
+               u64 reserved_62_63 : 2;
+               u64 q1_a_f : 1;
+               u64 q1_s_e : 1;
+               u64 pdf_p_f : 1;
+               u64 pdf_p_e : 1;
+               u64 pcf_p_f : 1;
+               u64 pcf_p_e : 1;
+               u64 rdx_s_e : 1;
+               u64 rwx_s_e : 1;
+               u64 pnc_a_f : 1;
+               u64 pnc_s_e : 1;
+               u64 com_a_f : 1;
+               u64 com_s_e : 1;
+               u64 q3_a_f : 1;
+               u64 q3_s_e : 1;
+               u64 q2_a_f : 1;
+               u64 q2_s_e : 1;
+               u64 pcr_a_f : 1;
+               u64 pcr_s_e : 1;
+               u64 fcr_a_f : 1;
+               u64 fcr_s_e : 1;
+               u64 iobdma : 1;
+               u64 p_dperr : 1;
+               u64 win_rto : 1;
+               u64 i3_pperr : 1;
+               u64 i2_pperr : 1;
+               u64 i1_pperr : 1;
+               u64 i0_pperr : 1;
+               u64 p3_ptout : 1;
+               u64 p2_ptout : 1;
+               u64 p1_ptout : 1;
+               u64 p0_ptout : 1;
+               u64 p3_pperr : 1;
+               u64 p2_pperr : 1;
+               u64 p1_pperr : 1;
+               u64 p0_pperr : 1;
+               u64 g3_rtout : 1;
+               u64 g2_rtout : 1;
+               u64 g1_rtout : 1;
+               u64 g0_rtout : 1;
+               u64 p3_perr : 1;
+               u64 p2_perr : 1;
+               u64 p1_perr : 1;
+               u64 p0_perr : 1;
+               u64 p3_rtout : 1;
+               u64 p2_rtout : 1;
+               u64 p1_rtout : 1;
+               u64 p0_rtout : 1;
+               u64 i3_overf : 1;
+               u64 i2_overf : 1;
+               u64 i1_overf : 1;
+               u64 i0_overf : 1;
+               u64 i3_rtout : 1;
+               u64 i2_rtout : 1;
+               u64 i1_rtout : 1;
+               u64 i0_rtout : 1;
+               u64 po3_2sml : 1;
+               u64 po2_2sml : 1;
+               u64 po1_2sml : 1;
+               u64 po0_2sml : 1;
+               u64 pci_rsl : 1;
+               u64 rml_wto : 1;
+               u64 rml_rto : 1;
+       } s;
+       struct cvmx_npi_int_sum_cn30xx {
+               u64 reserved_62_63 : 2;
+               u64 q1_a_f : 1;
+               u64 q1_s_e : 1;
+               u64 pdf_p_f : 1;
+               u64 pdf_p_e : 1;
+               u64 pcf_p_f : 1;
+               u64 pcf_p_e : 1;
+               u64 rdx_s_e : 1;
+               u64 rwx_s_e : 1;
+               u64 pnc_a_f : 1;
+               u64 pnc_s_e : 1;
+               u64 com_a_f : 1;
+               u64 com_s_e : 1;
+               u64 q3_a_f : 1;
+               u64 q3_s_e : 1;
+               u64 q2_a_f : 1;
+               u64 q2_s_e : 1;
+               u64 pcr_a_f : 1;
+               u64 pcr_s_e : 1;
+               u64 fcr_a_f : 1;
+               u64 fcr_s_e : 1;
+               u64 iobdma : 1;
+               u64 p_dperr : 1;
+               u64 win_rto : 1;
+               u64 reserved_36_38 : 3;
+               u64 i0_pperr : 1;
+               u64 reserved_32_34 : 3;
+               u64 p0_ptout : 1;
+               u64 reserved_28_30 : 3;
+               u64 p0_pperr : 1;
+               u64 reserved_24_26 : 3;
+               u64 g0_rtout : 1;
+               u64 reserved_20_22 : 3;
+               u64 p0_perr : 1;
+               u64 reserved_16_18 : 3;
+               u64 p0_rtout : 1;
+               u64 reserved_12_14 : 3;
+               u64 i0_overf : 1;
+               u64 reserved_8_10 : 3;
+               u64 i0_rtout : 1;
+               u64 reserved_4_6 : 3;
+               u64 po0_2sml : 1;
+               u64 pci_rsl : 1;
+               u64 rml_wto : 1;
+               u64 rml_rto : 1;
+       } cn30xx;
+       struct cvmx_npi_int_sum_cn31xx {
+               u64 reserved_62_63 : 2;
+               u64 q1_a_f : 1;
+               u64 q1_s_e : 1;
+               u64 pdf_p_f : 1;
+               u64 pdf_p_e : 1;
+               u64 pcf_p_f : 1;
+               u64 pcf_p_e : 1;
+               u64 rdx_s_e : 1;
+               u64 rwx_s_e : 1;
+               u64 pnc_a_f : 1;
+               u64 pnc_s_e : 1;
+               u64 com_a_f : 1;
+               u64 com_s_e : 1;
+               u64 q3_a_f : 1;
+               u64 q3_s_e : 1;
+               u64 q2_a_f : 1;
+               u64 q2_s_e : 1;
+               u64 pcr_a_f : 1;
+               u64 pcr_s_e : 1;
+               u64 fcr_a_f : 1;
+               u64 fcr_s_e : 1;
+               u64 iobdma : 1;
+               u64 p_dperr : 1;
+               u64 win_rto : 1;
+               u64 reserved_37_38 : 2;
+               u64 i1_pperr : 1;
+               u64 i0_pperr : 1;
+               u64 reserved_33_34 : 2;
+               u64 p1_ptout : 1;
+               u64 p0_ptout : 1;
+               u64 reserved_29_30 : 2;
+               u64 p1_pperr : 1;
+               u64 p0_pperr : 1;
+               u64 reserved_25_26 : 2;
+               u64 g1_rtout : 1;
+               u64 g0_rtout : 1;
+               u64 reserved_21_22 : 2;
+               u64 p1_perr : 1;
+               u64 p0_perr : 1;
+               u64 reserved_17_18 : 2;
+               u64 p1_rtout : 1;
+               u64 p0_rtout : 1;
+               u64 reserved_13_14 : 2;
+               u64 i1_overf : 1;
+               u64 i0_overf : 1;
+               u64 reserved_9_10 : 2;
+               u64 i1_rtout : 1;
+               u64 i0_rtout : 1;
+               u64 reserved_5_6 : 2;
+               u64 po1_2sml : 1;
+               u64 po0_2sml : 1;
+               u64 pci_rsl : 1;
+               u64 rml_wto : 1;
+               u64 rml_rto : 1;
+       } cn31xx;
+       struct cvmx_npi_int_sum_s cn38xx;
+       struct cvmx_npi_int_sum_cn38xxp2 {
+               u64 reserved_42_63 : 22;
+               u64 iobdma : 1;
+               u64 p_dperr : 1;
+               u64 win_rto : 1;
+               u64 i3_pperr : 1;
+               u64 i2_pperr : 1;
+               u64 i1_pperr : 1;
+               u64 i0_pperr : 1;
+               u64 p3_ptout : 1;
+               u64 p2_ptout : 1;
+               u64 p1_ptout : 1;
+               u64 p0_ptout : 1;
+               u64 p3_pperr : 1;
+               u64 p2_pperr : 1;
+               u64 p1_pperr : 1;
+               u64 p0_pperr : 1;
+               u64 g3_rtout : 1;
+               u64 g2_rtout : 1;
+               u64 g1_rtout : 1;
+               u64 g0_rtout : 1;
+               u64 p3_perr : 1;
+               u64 p2_perr : 1;
+               u64 p1_perr : 1;
+               u64 p0_perr : 1;
+               u64 p3_rtout : 1;
+               u64 p2_rtout : 1;
+               u64 p1_rtout : 1;
+               u64 p0_rtout : 1;
+               u64 i3_overf : 1;
+               u64 i2_overf : 1;
+               u64 i1_overf : 1;
+               u64 i0_overf : 1;
+               u64 i3_rtout : 1;
+               u64 i2_rtout : 1;
+               u64 i1_rtout : 1;
+               u64 i0_rtout : 1;
+               u64 po3_2sml : 1;
+               u64 po2_2sml : 1;
+               u64 po1_2sml : 1;
+               u64 po0_2sml : 1;
+               u64 pci_rsl : 1;
+               u64 rml_wto : 1;
+               u64 rml_rto : 1;
+       } cn38xxp2;
+       struct cvmx_npi_int_sum_cn31xx cn50xx;
+       struct cvmx_npi_int_sum_s cn58xx;
+       struct cvmx_npi_int_sum_s cn58xxp1;
+};
+
+typedef union cvmx_npi_int_sum cvmx_npi_int_sum_t;
+
+/**
+ * cvmx_npi_lowp_dbell
+ *
+ * NPI_LOWP_DBELL = Low Priority Door Bell
+ *
+ * The door bell register for the low priority DMA queue.
+ */
+union cvmx_npi_lowp_dbell {
+       u64 u64;
+       struct cvmx_npi_lowp_dbell_s {
+               u64 reserved_16_63 : 48;
+               u64 dbell : 16;
+       } s;
+       struct cvmx_npi_lowp_dbell_s cn30xx;
+       struct cvmx_npi_lowp_dbell_s cn31xx;
+       struct cvmx_npi_lowp_dbell_s cn38xx;
+       struct cvmx_npi_lowp_dbell_s cn38xxp2;
+       struct cvmx_npi_lowp_dbell_s cn50xx;
+       struct cvmx_npi_lowp_dbell_s cn58xx;
+       struct cvmx_npi_lowp_dbell_s cn58xxp1;
+};
+
+typedef union cvmx_npi_lowp_dbell cvmx_npi_lowp_dbell_t;
+
+/**
+ * cvmx_npi_lowp_ibuff_saddr
+ *
+ * NPI_LOWP_IBUFF_SADDR = DMA Low Priority's Instruction Buffer Starting Address
+ *
+ * The address to start reading Instructions from for LOWP.
+ */
+union cvmx_npi_lowp_ibuff_saddr {
+       u64 u64;
+       struct cvmx_npi_lowp_ibuff_saddr_s {
+               u64 reserved_36_63 : 28;
+               u64 saddr : 36;
+       } s;
+       struct cvmx_npi_lowp_ibuff_saddr_s cn30xx;
+       struct cvmx_npi_lowp_ibuff_saddr_s cn31xx;
+       struct cvmx_npi_lowp_ibuff_saddr_s cn38xx;
+       struct cvmx_npi_lowp_ibuff_saddr_s cn38xxp2;
+       struct cvmx_npi_lowp_ibuff_saddr_s cn50xx;
+       struct cvmx_npi_lowp_ibuff_saddr_s cn58xx;
+       struct cvmx_npi_lowp_ibuff_saddr_s cn58xxp1;
+};
+
+typedef union cvmx_npi_lowp_ibuff_saddr cvmx_npi_lowp_ibuff_saddr_t;
+
+/**
+ * cvmx_npi_mem_access_subid#
+ *
+ * NPI_MEM_ACCESS_SUBID3 = Memory Access SubId 3Register
+ *
+ * Carries Read/Write parameters for PP access to PCI memory that use NPI SubId3.
+ * Writes to this register are not ordered with writes/reads to the PCI Memory space.
+ * To ensure that a write has completed the user must read the register before
+ * making an access(i.e. PCI memory space) that requires the value of this register to be updated.
+ */
+union cvmx_npi_mem_access_subidx {
+       u64 u64;
+       struct cvmx_npi_mem_access_subidx_s {
+               u64 reserved_38_63 : 26;
+               u64 shortl : 1;
+               u64 nmerge : 1;
+               u64 esr : 2;
+               u64 esw : 2;
+               u64 nsr : 1;
+               u64 nsw : 1;
+               u64 ror : 1;
+               u64 row : 1;
+               u64 ba : 28;
+       } s;
+       struct cvmx_npi_mem_access_subidx_s cn30xx;
+       struct cvmx_npi_mem_access_subidx_cn31xx {
+               u64 reserved_36_63 : 28;
+               u64 esr : 2;
+               u64 esw : 2;
+               u64 nsr : 1;
+               u64 nsw : 1;
+               u64 ror : 1;
+               u64 row : 1;
+               u64 ba : 28;
+       } cn31xx;
+       struct cvmx_npi_mem_access_subidx_s cn38xx;
+       struct cvmx_npi_mem_access_subidx_cn31xx cn38xxp2;
+       struct cvmx_npi_mem_access_subidx_s cn50xx;
+       struct cvmx_npi_mem_access_subidx_s cn58xx;
+       struct cvmx_npi_mem_access_subidx_s cn58xxp1;
+};
+
+typedef union cvmx_npi_mem_access_subidx cvmx_npi_mem_access_subidx_t;
+
+/**
+ * cvmx_npi_msi_rcv
+ *
+ * NPI_MSI_RCV = NPI MSI Receive Vector Register
+ *
+ * A bit is set in this register relative to the vector received during a MSI. And cleared by a W1 to the register.
+ */
+union cvmx_npi_msi_rcv {
+       u64 u64;
+       struct cvmx_npi_msi_rcv_s {
+               u64 int_vec : 64;
+       } s;
+       struct cvmx_npi_msi_rcv_s cn30xx;
+       struct cvmx_npi_msi_rcv_s cn31xx;
+       struct cvmx_npi_msi_rcv_s cn38xx;
+       struct cvmx_npi_msi_rcv_s cn38xxp2;
+       struct cvmx_npi_msi_rcv_s cn50xx;
+       struct cvmx_npi_msi_rcv_s cn58xx;
+       struct cvmx_npi_msi_rcv_s cn58xxp1;
+};
+
+typedef union cvmx_npi_msi_rcv cvmx_npi_msi_rcv_t;
+
+/**
+ * cvmx_npi_num_desc_output#
+ *
+ * NUM_DESC_OUTPUT0 = Number Of Descriptors Available For Output 0
+ *
+ * The size of the Buffer/Info Pointer Pair ring for Output-0.
+ */
+union cvmx_npi_num_desc_outputx {
+       u64 u64;
+       struct cvmx_npi_num_desc_outputx_s {
+               u64 reserved_32_63 : 32;
+               u64 size : 32;
+       } s;
+       struct cvmx_npi_num_desc_outputx_s cn30xx;
+       struct cvmx_npi_num_desc_outputx_s cn31xx;
+       struct cvmx_npi_num_desc_outputx_s cn38xx;
+       struct cvmx_npi_num_desc_outputx_s cn38xxp2;
+       struct cvmx_npi_num_desc_outputx_s cn50xx;
+       struct cvmx_npi_num_desc_outputx_s cn58xx;
+       struct cvmx_npi_num_desc_outputx_s cn58xxp1;
+};
+
+typedef union cvmx_npi_num_desc_outputx cvmx_npi_num_desc_outputx_t;
+
+/**
+ * cvmx_npi_output_control
+ *
+ * NPI_OUTPUT_CONTROL = NPI's Output Control Register
+ *
+ * The address to start reading Instructions from for Output-3.
+ */
+union cvmx_npi_output_control {
+       u64 u64;
+       struct cvmx_npi_output_control_s {
+               u64 reserved_49_63 : 15;
+               u64 pkt_rr : 1;
+               u64 p3_bmode : 1;
+               u64 p2_bmode : 1;
+               u64 p1_bmode : 1;
+               u64 p0_bmode : 1;
+               u64 o3_es : 2;
+               u64 o3_ns : 1;
+               u64 o3_ro : 1;
+               u64 o2_es : 2;
+               u64 o2_ns : 1;
+               u64 o2_ro : 1;
+               u64 o1_es : 2;
+               u64 o1_ns : 1;
+               u64 o1_ro : 1;
+               u64 o0_es : 2;
+               u64 o0_ns : 1;
+               u64 o0_ro : 1;
+               u64 o3_csrm : 1;
+               u64 o2_csrm : 1;
+               u64 o1_csrm : 1;
+               u64 o0_csrm : 1;
+               u64 reserved_20_23 : 4;
+               u64 iptr_o3 : 1;
+               u64 iptr_o2 : 1;
+               u64 iptr_o1 : 1;
+               u64 iptr_o0 : 1;
+               u64 esr_sl3 : 2;
+               u64 nsr_sl3 : 1;
+               u64 ror_sl3 : 1;
+               u64 esr_sl2 : 2;
+               u64 nsr_sl2 : 1;
+               u64 ror_sl2 : 1;
+               u64 esr_sl1 : 2;
+               u64 nsr_sl1 : 1;
+               u64 ror_sl1 : 1;
+               u64 esr_sl0 : 2;
+               u64 nsr_sl0 : 1;
+               u64 ror_sl0 : 1;
+       } s;
+       struct cvmx_npi_output_control_cn30xx {
+               u64 reserved_45_63 : 19;
+               u64 p0_bmode : 1;
+               u64 reserved_32_43 : 12;
+               u64 o0_es : 2;
+               u64 o0_ns : 1;
+               u64 o0_ro : 1;
+               u64 reserved_25_27 : 3;
+               u64 o0_csrm : 1;
+               u64 reserved_17_23 : 7;
+               u64 iptr_o0 : 1;
+               u64 reserved_4_15 : 12;
+               u64 esr_sl0 : 2;
+               u64 nsr_sl0 : 1;
+               u64 ror_sl0 : 1;
+       } cn30xx;
+       struct cvmx_npi_output_control_cn31xx {
+               u64 reserved_46_63 : 18;
+               u64 p1_bmode : 1;
+               u64 p0_bmode : 1;
+               u64 reserved_36_43 : 8;
+               u64 o1_es : 2;
+               u64 o1_ns : 1;
+               u64 o1_ro : 1;
+               u64 o0_es : 2;
+               u64 o0_ns : 1;
+               u64 o0_ro : 1;
+               u64 reserved_26_27 : 2;
+               u64 o1_csrm : 1;
+               u64 o0_csrm : 1;
+               u64 reserved_18_23 : 6;
+               u64 iptr_o1 : 1;
+               u64 iptr_o0 : 1;
+               u64 reserved_8_15 : 8;
+               u64 esr_sl1 : 2;
+               u64 nsr_sl1 : 1;
+               u64 ror_sl1 : 1;
+               u64 esr_sl0 : 2;
+               u64 nsr_sl0 : 1;
+               u64 ror_sl0 : 1;
+       } cn31xx;
+       struct cvmx_npi_output_control_s cn38xx;
+       struct cvmx_npi_output_control_cn38xxp2 {
+               u64 reserved_48_63 : 16;
+               u64 p3_bmode : 1;
+               u64 p2_bmode : 1;
+               u64 p1_bmode : 1;
+               u64 p0_bmode : 1;
+               u64 o3_es : 2;
+               u64 o3_ns : 1;
+               u64 o3_ro : 1;
+               u64 o2_es : 2;
+               u64 o2_ns : 1;
+               u64 o2_ro : 1;
+               u64 o1_es : 2;
+               u64 o1_ns : 1;
+               u64 o1_ro : 1;
+               u64 o0_es : 2;
+               u64 o0_ns : 1;
+               u64 o0_ro : 1;
+               u64 o3_csrm : 1;
+               u64 o2_csrm : 1;
+               u64 o1_csrm : 1;
+               u64 o0_csrm : 1;
+               u64 reserved_20_23 : 4;
+               u64 iptr_o3 : 1;
+               u64 iptr_o2 : 1;
+               u64 iptr_o1 : 1;
+               u64 iptr_o0 : 1;
+               u64 esr_sl3 : 2;
+               u64 nsr_sl3 : 1;
+               u64 ror_sl3 : 1;
+               u64 esr_sl2 : 2;
+               u64 nsr_sl2 : 1;
+               u64 ror_sl2 : 1;
+               u64 esr_sl1 : 2;
+               u64 nsr_sl1 : 1;
+               u64 ror_sl1 : 1;
+               u64 esr_sl0 : 2;
+               u64 nsr_sl0 : 1;
+               u64 ror_sl0 : 1;
+       } cn38xxp2;
+       struct cvmx_npi_output_control_cn50xx {
+               u64 reserved_49_63 : 15;
+               u64 pkt_rr : 1;
+               u64 reserved_46_47 : 2;
+               u64 p1_bmode : 1;
+               u64 p0_bmode : 1;
+               u64 reserved_36_43 : 8;
+               u64 o1_es : 2;
+               u64 o1_ns : 1;
+               u64 o1_ro : 1;
+               u64 o0_es : 2;
+               u64 o0_ns : 1;
+               u64 o0_ro : 1;
+               u64 reserved_26_27 : 2;
+               u64 o1_csrm : 1;
+               u64 o0_csrm : 1;
+               u64 reserved_18_23 : 6;
+               u64 iptr_o1 : 1;
+               u64 iptr_o0 : 1;
+               u64 reserved_8_15 : 8;
+               u64 esr_sl1 : 2;
+               u64 nsr_sl1 : 1;
+               u64 ror_sl1 : 1;
+               u64 esr_sl0 : 2;
+               u64 nsr_sl0 : 1;
+               u64 ror_sl0 : 1;
+       } cn50xx;
+       struct cvmx_npi_output_control_s cn58xx;
+       struct cvmx_npi_output_control_s cn58xxp1;
+};
+
+typedef union cvmx_npi_output_control cvmx_npi_output_control_t;
+
+/**
+ * cvmx_npi_p#_dbpair_addr
+ *
+ * NPI_P0_DBPAIR_ADDR = NPI's Port-0 DATA-BUFFER Pair Next Read Address.
+ *
+ * Contains the next address to read for Port's-0 Data/Buffer Pair.
+ */
+union cvmx_npi_px_dbpair_addr {
+       u64 u64;
+       struct cvmx_npi_px_dbpair_addr_s {
+               u64 reserved_63_63 : 1;
+               u64 state : 2;
+               u64 naddr : 61;
+       } s;
+       struct cvmx_npi_px_dbpair_addr_s cn30xx;
+       struct cvmx_npi_px_dbpair_addr_s cn31xx;
+       struct cvmx_npi_px_dbpair_addr_s cn38xx;
+       struct cvmx_npi_px_dbpair_addr_s cn38xxp2;
+       struct cvmx_npi_px_dbpair_addr_s cn50xx;
+       struct cvmx_npi_px_dbpair_addr_s cn58xx;
+       struct cvmx_npi_px_dbpair_addr_s cn58xxp1;
+};
+
+typedef union cvmx_npi_px_dbpair_addr cvmx_npi_px_dbpair_addr_t;
+
+/**
+ * cvmx_npi_p#_instr_addr
+ *
+ * NPI_P0_INSTR_ADDR = NPI's Port-0 Instruction Next Read Address.
+ *
+ * Contains the next address to read for Port's-0 Instructions.
+ */
+union cvmx_npi_px_instr_addr {
+       u64 u64;
+       struct cvmx_npi_px_instr_addr_s {
+               u64 state : 3;
+               u64 naddr : 61;
+       } s;
+       struct cvmx_npi_px_instr_addr_s cn30xx;
+       struct cvmx_npi_px_instr_addr_s cn31xx;
+       struct cvmx_npi_px_instr_addr_s cn38xx;
+       struct cvmx_npi_px_instr_addr_s cn38xxp2;
+       struct cvmx_npi_px_instr_addr_s cn50xx;
+       struct cvmx_npi_px_instr_addr_s cn58xx;
+       struct cvmx_npi_px_instr_addr_s cn58xxp1;
+};
+
+typedef union cvmx_npi_px_instr_addr cvmx_npi_px_instr_addr_t;
+
+/**
+ * cvmx_npi_p#_instr_cnts
+ *
+ * NPI_P0_INSTR_CNTS = NPI's Port-0 Instruction Counts For Packets In.
+ *
+ * Used to determine the number of instruction in the NPI and to be fetched for Input-Packets.
+ */
+union cvmx_npi_px_instr_cnts {
+       u64 u64;
+       struct cvmx_npi_px_instr_cnts_s {
+               u64 reserved_38_63 : 26;
+               u64 fcnt : 6;
+               u64 avail : 32;
+       } s;
+       struct cvmx_npi_px_instr_cnts_s cn30xx;
+       struct cvmx_npi_px_instr_cnts_s cn31xx;
+       struct cvmx_npi_px_instr_cnts_s cn38xx;
+       struct cvmx_npi_px_instr_cnts_s cn38xxp2;
+       struct cvmx_npi_px_instr_cnts_s cn50xx;
+       struct cvmx_npi_px_instr_cnts_s cn58xx;
+       struct cvmx_npi_px_instr_cnts_s cn58xxp1;
+};
+
+typedef union cvmx_npi_px_instr_cnts cvmx_npi_px_instr_cnts_t;
+
+/**
+ * cvmx_npi_p#_pair_cnts
+ *
+ * NPI_P0_PAIR_CNTS = NPI's Port-0 Instruction Counts For Packets Out.
+ *
+ * Used to determine the number of instruction in the NPI and to be fetched for Output-Packets.
+ */
+union cvmx_npi_px_pair_cnts {
+       u64 u64;
+       struct cvmx_npi_px_pair_cnts_s {
+               u64 reserved_37_63 : 27;
+               u64 fcnt : 5;
+               u64 avail : 32;
+       } s;
+       struct cvmx_npi_px_pair_cnts_s cn30xx;
+       struct cvmx_npi_px_pair_cnts_s cn31xx;
+       struct cvmx_npi_px_pair_cnts_s cn38xx;
+       struct cvmx_npi_px_pair_cnts_s cn38xxp2;
+       struct cvmx_npi_px_pair_cnts_s cn50xx;
+       struct cvmx_npi_px_pair_cnts_s cn58xx;
+       struct cvmx_npi_px_pair_cnts_s cn58xxp1;
+};
+
+typedef union cvmx_npi_px_pair_cnts cvmx_npi_px_pair_cnts_t;
+
+/**
+ * cvmx_npi_pci_burst_size
+ *
+ * NPI_PCI_BURST_SIZE = NPI PCI Burst Size Register
+ *
+ * Control the number of words the NPI will attempt to read / write to/from the PCI.
+ */
+union cvmx_npi_pci_burst_size {
+       u64 u64;
+       struct cvmx_npi_pci_burst_size_s {
+               u64 reserved_14_63 : 50;
+               u64 wr_brst : 7;
+               u64 rd_brst : 7;
+       } s;
+       struct cvmx_npi_pci_burst_size_s cn30xx;
+       struct cvmx_npi_pci_burst_size_s cn31xx;
+       struct cvmx_npi_pci_burst_size_s cn38xx;
+       struct cvmx_npi_pci_burst_size_s cn38xxp2;
+       struct cvmx_npi_pci_burst_size_s cn50xx;
+       struct cvmx_npi_pci_burst_size_s cn58xx;
+       struct cvmx_npi_pci_burst_size_s cn58xxp1;
+};
+
+typedef union cvmx_npi_pci_burst_size cvmx_npi_pci_burst_size_t;
+
+/**
+ * cvmx_npi_pci_int_arb_cfg
+ *
+ * NPI_PCI_INT_ARB_CFG = Configuration For PCI Arbiter
+ *
+ * Controls operation of the Internal PCI Arbiter.  This register should
+ * only be written when PRST# is asserted.  NPI_PCI_INT_ARB_CFG[EN] should
+ * only be set when Octane is a host.
+ */
+union cvmx_npi_pci_int_arb_cfg {
+       u64 u64;
+       struct cvmx_npi_pci_int_arb_cfg_s {
+               u64 reserved_13_63 : 51;
+               u64 hostmode : 1;
+               u64 pci_ovr : 4;
+               u64 reserved_5_7 : 3;
+               u64 en : 1;
+               u64 park_mod : 1;
+               u64 park_dev : 3;
+       } s;
+       struct cvmx_npi_pci_int_arb_cfg_cn30xx {
+               u64 reserved_5_63 : 59;
+               u64 en : 1;
+               u64 park_mod : 1;
+               u64 park_dev : 3;
+       } cn30xx;
+       struct cvmx_npi_pci_int_arb_cfg_cn30xx cn31xx;
+       struct cvmx_npi_pci_int_arb_cfg_cn30xx cn38xx;
+       struct cvmx_npi_pci_int_arb_cfg_cn30xx cn38xxp2;
+       struct cvmx_npi_pci_int_arb_cfg_s cn50xx;
+       struct cvmx_npi_pci_int_arb_cfg_s cn58xx;
+       struct cvmx_npi_pci_int_arb_cfg_s cn58xxp1;
+};
+
+typedef union cvmx_npi_pci_int_arb_cfg cvmx_npi_pci_int_arb_cfg_t;
+
+/**
+ * cvmx_npi_pci_read_cmd
+ *
+ * NPI_PCI_READ_CMD = NPI PCI Read Command Register
+ *
+ * Controls the type of read command sent.
+ * Writes to this register are not ordered with writes/reads to the PCI Memory space.
+ * To ensure that a write has completed the user must read the register before
+ * making an access(i.e. PCI memory space) that requires the value of this register to be updated.
+ * Also any previously issued reads/writes to PCI memory space, still stored in the outbound
+ * FIFO will use the value of this register after it has been updated.
+ */
+union cvmx_npi_pci_read_cmd {
+       u64 u64;
+       struct cvmx_npi_pci_read_cmd_s {
+               u64 reserved_11_63 : 53;
+               u64 cmd_size : 11;
+       } s;
+       struct cvmx_npi_pci_read_cmd_s cn30xx;
+       struct cvmx_npi_pci_read_cmd_s cn31xx;
+       struct cvmx_npi_pci_read_cmd_s cn38xx;
+       struct cvmx_npi_pci_read_cmd_s cn38xxp2;
+       struct cvmx_npi_pci_read_cmd_s cn50xx;
+       struct cvmx_npi_pci_read_cmd_s cn58xx;
+       struct cvmx_npi_pci_read_cmd_s cn58xxp1;
+};
+
+typedef union cvmx_npi_pci_read_cmd cvmx_npi_pci_read_cmd_t;
+
+/**
+ * cvmx_npi_port32_instr_hdr
+ *
+ * NPI_PORT32_INSTR_HDR = NPI Port 32 Instruction Header
+ *
+ * Contains bits [62:42] of the Instruction Header for port 32.
+ */
+union cvmx_npi_port32_instr_hdr {
+       u64 u64;
+       struct cvmx_npi_port32_instr_hdr_s {
+               u64 reserved_44_63 : 20;
+               u64 pbp : 1;
+               u64 rsv_f : 5;
+               u64 rparmode : 2;
+               u64 rsv_e : 1;
+               u64 rskp_len : 7;
+               u64 rsv_d : 6;
+               u64 use_ihdr : 1;
+               u64 rsv_c : 5;
+               u64 par_mode : 2;
+               u64 rsv_b : 1;
+               u64 skp_len : 7;
+               u64 rsv_a : 6;
+       } s;
+       struct cvmx_npi_port32_instr_hdr_s cn30xx;
+       struct cvmx_npi_port32_instr_hdr_s cn31xx;
+       struct cvmx_npi_port32_instr_hdr_s cn38xx;
+       struct cvmx_npi_port32_instr_hdr_s cn38xxp2;
+       struct cvmx_npi_port32_instr_hdr_s cn50xx;
+       struct cvmx_npi_port32_instr_hdr_s cn58xx;
+       struct cvmx_npi_port32_instr_hdr_s cn58xxp1;
+};
+
+typedef union cvmx_npi_port32_instr_hdr cvmx_npi_port32_instr_hdr_t;
+
+/**
+ * cvmx_npi_port33_instr_hdr
+ *
+ * NPI_PORT33_INSTR_HDR = NPI Port 33 Instruction Header
+ *
+ * Contains bits [62:42] of the Instruction Header for port 33.
+ */
+union cvmx_npi_port33_instr_hdr {
+       u64 u64;
+       struct cvmx_npi_port33_instr_hdr_s {
+               u64 reserved_44_63 : 20;
+               u64 pbp : 1;
+               u64 rsv_f : 5;
+               u64 rparmode : 2;
+               u64 rsv_e : 1;
+               u64 rskp_len : 7;
+               u64 rsv_d : 6;
+               u64 use_ihdr : 1;
+               u64 rsv_c : 5;
+               u64 par_mode : 2;
+               u64 rsv_b : 1;
+               u64 skp_len : 7;
+               u64 rsv_a : 6;
+       } s;
+       struct cvmx_npi_port33_instr_hdr_s cn31xx;
+       struct cvmx_npi_port33_instr_hdr_s cn38xx;
+       struct cvmx_npi_port33_instr_hdr_s cn38xxp2;
+       struct cvmx_npi_port33_instr_hdr_s cn50xx;
+       struct cvmx_npi_port33_instr_hdr_s cn58xx;
+       struct cvmx_npi_port33_instr_hdr_s cn58xxp1;
+};
+
+typedef union cvmx_npi_port33_instr_hdr cvmx_npi_port33_instr_hdr_t;
+
+/**
+ * cvmx_npi_port34_instr_hdr
+ *
+ * NPI_PORT34_INSTR_HDR = NPI Port 34 Instruction Header
+ *
+ * Contains bits [62:42] of the Instruction Header for port 34. Added for PASS-2.
+ */
+union cvmx_npi_port34_instr_hdr {
+       u64 u64;
+       struct cvmx_npi_port34_instr_hdr_s {
+               u64 reserved_44_63 : 20;
+               u64 pbp : 1;
+               u64 rsv_f : 5;
+               u64 rparmode : 2;
+               u64 rsv_e : 1;
+               u64 rskp_len : 7;
+               u64 rsv_d : 6;
+               u64 use_ihdr : 1;
+               u64 rsv_c : 5;
+               u64 par_mode : 2;
+               u64 rsv_b : 1;
+               u64 skp_len : 7;
+               u64 rsv_a : 6;
+       } s;
+       struct cvmx_npi_port34_instr_hdr_s cn38xx;
+       struct cvmx_npi_port34_instr_hdr_s cn38xxp2;
+       struct cvmx_npi_port34_instr_hdr_s cn58xx;
+       struct cvmx_npi_port34_instr_hdr_s cn58xxp1;
+};
+
+typedef union cvmx_npi_port34_instr_hdr cvmx_npi_port34_instr_hdr_t;
+
+/**
+ * cvmx_npi_port35_instr_hdr
+ *
+ * NPI_PORT35_INSTR_HDR = NPI Port 35 Instruction Header
+ *
+ * Contains bits [62:42] of the Instruction Header for port 35. Added for PASS-2.
+ */
+union cvmx_npi_port35_instr_hdr {
+       u64 u64;
+       struct cvmx_npi_port35_instr_hdr_s {
+               u64 reserved_44_63 : 20;
+               u64 pbp : 1;
+               u64 rsv_f : 5;
+               u64 rparmode : 2;
+               u64 rsv_e : 1;
+               u64 rskp_len : 7;
+               u64 rsv_d : 6;
+               u64 use_ihdr : 1;
+               u64 rsv_c : 5;
+               u64 par_mode : 2;
+               u64 rsv_b : 1;
+               u64 skp_len : 7;
+               u64 rsv_a : 6;
+       } s;
+       struct cvmx_npi_port35_instr_hdr_s cn38xx;
+       struct cvmx_npi_port35_instr_hdr_s cn38xxp2;
+       struct cvmx_npi_port35_instr_hdr_s cn58xx;
+       struct cvmx_npi_port35_instr_hdr_s cn58xxp1;
+};
+
+typedef union cvmx_npi_port35_instr_hdr cvmx_npi_port35_instr_hdr_t;
+
+/**
+ * cvmx_npi_port_bp_control
+ *
+ * NPI_PORT_BP_CONTROL = Port Backpressure Control
+ *
+ * Enables Port Level Backpressure
+ */
+union cvmx_npi_port_bp_control {
+       u64 u64;
+       struct cvmx_npi_port_bp_control_s {
+               u64 reserved_8_63 : 56;
+               u64 bp_on : 4;
+               u64 enb : 4;
+       } s;
+       struct cvmx_npi_port_bp_control_s cn30xx;
+       struct cvmx_npi_port_bp_control_s cn31xx;
+       struct cvmx_npi_port_bp_control_s cn38xx;
+       struct cvmx_npi_port_bp_control_s cn38xxp2;
+       struct cvmx_npi_port_bp_control_s cn50xx;
+       struct cvmx_npi_port_bp_control_s cn58xx;
+       struct cvmx_npi_port_bp_control_s cn58xxp1;
+};
+
+typedef union cvmx_npi_port_bp_control cvmx_npi_port_bp_control_t;
+
+/**
+ * cvmx_npi_rsl_int_blocks
+ *
+ * RSL_INT_BLOCKS = RSL Interrupt Blocks Register
+ *
+ * Reading this register will return a vector with a bit set '1' for a corresponding RSL block
+ * that presently has an interrupt pending. The Field Description below supplies the name of the
+ * register that software should read to find out why that intterupt bit is set.
+ */
+union cvmx_npi_rsl_int_blocks {
+       u64 u64;
+       struct cvmx_npi_rsl_int_blocks_s {
+               u64 reserved_32_63 : 32;
+               u64 rint_31 : 1;
+               u64 iob : 1;
+               u64 reserved_28_29 : 2;
+               u64 rint_27 : 1;
+               u64 rint_26 : 1;
+               u64 rint_25 : 1;
+               u64 rint_24 : 1;
+               u64 asx1 : 1;
+               u64 asx0 : 1;
+               u64 rint_21 : 1;
+               u64 pip : 1;
+               u64 spx1 : 1;
+               u64 spx0 : 1;
+               u64 lmc : 1;
+               u64 l2c : 1;
+               u64 rint_15 : 1;
+               u64 reserved_13_14 : 2;
+               u64 pow : 1;
+               u64 tim : 1;
+               u64 pko : 1;
+               u64 ipd : 1;
+               u64 rint_8 : 1;
+               u64 zip : 1;
+               u64 dfa : 1;
+               u64 fpa : 1;
+               u64 key : 1;
+               u64 npi : 1;
+               u64 gmx1 : 1;
+               u64 gmx0 : 1;
+               u64 mio : 1;
+       } s;
+       struct cvmx_npi_rsl_int_blocks_cn30xx {
+               u64 reserved_32_63 : 32;
+               u64 rint_31 : 1;
+               u64 iob : 1;
+               u64 rint_29 : 1;
+               u64 rint_28 : 1;
+               u64 rint_27 : 1;
+               u64 rint_26 : 1;
+               u64 rint_25 : 1;
+               u64 rint_24 : 1;
+               u64 asx1 : 1;
+               u64 asx0 : 1;
+               u64 rint_21 : 1;
+               u64 pip : 1;
+               u64 spx1 : 1;
+               u64 spx0 : 1;
+               u64 lmc : 1;
+               u64 l2c : 1;
+               u64 rint_15 : 1;
+               u64 rint_14 : 1;
+               u64 usb : 1;
+               u64 pow : 1;
+               u64 tim : 1;
+               u64 pko : 1;
+               u64 ipd : 1;
+               u64 rint_8 : 1;
+               u64 zip : 1;
+               u64 dfa : 1;
+               u64 fpa : 1;
+               u64 key : 1;
+               u64 npi : 1;
+               u64 gmx1 : 1;
+               u64 gmx0 : 1;
+               u64 mio : 1;
+       } cn30xx;
+       struct cvmx_npi_rsl_int_blocks_cn30xx cn31xx;
+       struct cvmx_npi_rsl_int_blocks_cn38xx {
+               u64 reserved_32_63 : 32;
+               u64 rint_31 : 1;
+               u64 iob : 1;
+               u64 rint_29 : 1;
+               u64 rint_28 : 1;
+               u64 rint_27 : 1;
+               u64 rint_26 : 1;
+               u64 rint_25 : 1;
+               u64 rint_24 : 1;
+               u64 asx1 : 1;
+               u64 asx0 : 1;
+               u64 rint_21 : 1;
+               u64 pip : 1;
+               u64 spx1 : 1;
+               u64 spx0 : 1;
+               u64 lmc : 1;
+               u64 l2c : 1;
+               u64 rint_15 : 1;
+               u64 rint_14 : 1;
+               u64 rint_13 : 1;
+               u64 pow : 1;
+               u64 tim : 1;
+               u64 pko : 1;
+               u64 ipd : 1;
+               u64 rint_8 : 1;
+               u64 zip : 1;
+               u64 dfa : 1;
+               u64 fpa : 1;
+               u64 key : 1;
+               u64 npi : 1;
+               u64 gmx1 : 1;
+               u64 gmx0 : 1;
+               u64 mio : 1;
+       } cn38xx;
+       struct cvmx_npi_rsl_int_blocks_cn38xx cn38xxp2;
+       struct cvmx_npi_rsl_int_blocks_cn50xx {
+               u64 reserved_31_63 : 33;
+               u64 iob : 1;
+               u64 lmc1 : 1;
+               u64 agl : 1;
+               u64 reserved_24_27 : 4;
+               u64 asx1 : 1;
+               u64 asx0 : 1;
+               u64 reserved_21_21 : 1;
+               u64 pip : 1;
+               u64 spx1 : 1;
+               u64 spx0 : 1;
+               u64 lmc : 1;
+               u64 l2c : 1;
+               u64 reserved_15_15 : 1;
+               u64 rad : 1;
+               u64 usb : 1;
+               u64 pow : 1;
+               u64 tim : 1;
+               u64 pko : 1;
+               u64 ipd : 1;
+               u64 reserved_8_8 : 1;
+               u64 zip : 1;
+               u64 dfa : 1;
+               u64 fpa : 1;
+               u64 key : 1;
+               u64 npi : 1;
+               u64 gmx1 : 1;
+               u64 gmx0 : 1;
+               u64 mio : 1;
+       } cn50xx;
+       struct cvmx_npi_rsl_int_blocks_cn38xx cn58xx;
+       struct cvmx_npi_rsl_int_blocks_cn38xx cn58xxp1;
+};
+
+typedef union cvmx_npi_rsl_int_blocks cvmx_npi_rsl_int_blocks_t;
+
+/**
+ * cvmx_npi_size_input#
+ *
+ * NPI_SIZE_INPUT0 = NPI's Size for Input 0 Register
+ *
+ * The size (in instructions) of Instruction Queue-0.
+ */
+union cvmx_npi_size_inputx {
+       u64 u64;
+       struct cvmx_npi_size_inputx_s {
+               u64 reserved_32_63 : 32;
+               u64 size : 32;
+       } s;
+       struct cvmx_npi_size_inputx_s cn30xx;
+       struct cvmx_npi_size_inputx_s cn31xx;
+       struct cvmx_npi_size_inputx_s cn38xx;
+       struct cvmx_npi_size_inputx_s cn38xxp2;
+       struct cvmx_npi_size_inputx_s cn50xx;
+       struct cvmx_npi_size_inputx_s cn58xx;
+       struct cvmx_npi_size_inputx_s cn58xxp1;
+};
+
+typedef union cvmx_npi_size_inputx cvmx_npi_size_inputx_t;
+
+/**
+ * cvmx_npi_win_read_to
+ *
+ * NPI_WIN_READ_TO = NPI WINDOW READ Timeout Register
+ *
+ * Number of core clocks to wait before timing out on a WINDOW-READ to the NCB.
+ */
+union cvmx_npi_win_read_to {
+       u64 u64;
+       struct cvmx_npi_win_read_to_s {
+               u64 reserved_32_63 : 32;
+               u64 time : 32;
+       } s;
+       struct cvmx_npi_win_read_to_s cn30xx;
+       struct cvmx_npi_win_read_to_s cn31xx;
+       struct cvmx_npi_win_read_to_s cn38xx;
+       struct cvmx_npi_win_read_to_s cn38xxp2;
+       struct cvmx_npi_win_read_to_s cn50xx;
+       struct cvmx_npi_win_read_to_s cn58xx;
+       struct cvmx_npi_win_read_to_s cn58xxp1;
+};
+
+typedef union cvmx_npi_win_read_to cvmx_npi_win_read_to_t;
+
+#endif