From: Aaron Williams Date: Fri, 11 Dec 2020 16:05:38 +0000 (+0100) Subject: mips: octeon: Add cvmx-npi-defs.h header file X-Git-Tag: v2021.10~198^2~102 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=0b9dce59e6a6662d86810008ab1d5bc7c6320683;p=platform%2Fkernel%2Fu-boot.git mips: octeon: Add cvmx-npi-defs.h header file 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 Signed-off-by: Stefan Roese --- 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 index 0000000..f23ed78 --- /dev/null +++ b/arch/mips/mach-octeon/include/mach/cvmx-npi-defs.h @@ -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