mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-02 23:16:49 +07:00
54293ec307
Here we define the addresses and bit-fields of the Configuration and Status Registers (CSRs) for some of the hardware functional units on the OCTEON SOC. Definitions are needed for: CIU -- Central Interrupt Unit. GPIO -- General Purpose Input Output. IOB -- Input / Output {Busing,Bridge}. IPD -- Input Packet Data unit. L2C -- Level-2 Cache controller. L2D -- Level-2 Data cache. L2T -- Level-2 cache Tag. LED -- Light Emitting Diode controller. MIO -- Miscellaneous Input / Output. POW -- Packet Order / Work unit. Signed-off-by: Tomaso Paoletti <tpaoletti@caviumnetworks.com> Signed-off-by: David Daney <ddaney@caviumnetworks.com> Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
964 lines
23 KiB
C
964 lines
23 KiB
C
/***********************license start***************
|
|
* Author: Cavium Networks
|
|
*
|
|
* Contact: support@caviumnetworks.com
|
|
* This file is part of the OCTEON SDK
|
|
*
|
|
* Copyright (c) 2003-2008 Cavium Networks
|
|
*
|
|
* This file is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License, Version 2, as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This file is distributed in the hope that it will be useful, but
|
|
* AS-IS and WITHOUT ANY WARRANTY; without even the implied warranty
|
|
* of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, TITLE, or
|
|
* NONINFRINGEMENT. See the GNU General Public License for more
|
|
* details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this file; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
* or visit http://www.gnu.org/licenses/.
|
|
*
|
|
* This file may also be available under a different license from Cavium.
|
|
* Contact Cavium Networks for more information
|
|
***********************license end**************************************/
|
|
|
|
#ifndef __CVMX_L2C_DEFS_H__
|
|
#define __CVMX_L2C_DEFS_H__
|
|
|
|
#define CVMX_L2C_BST0 \
|
|
CVMX_ADD_IO_SEG(0x00011800800007F8ull)
|
|
#define CVMX_L2C_BST1 \
|
|
CVMX_ADD_IO_SEG(0x00011800800007F0ull)
|
|
#define CVMX_L2C_BST2 \
|
|
CVMX_ADD_IO_SEG(0x00011800800007E8ull)
|
|
#define CVMX_L2C_CFG \
|
|
CVMX_ADD_IO_SEG(0x0001180080000000ull)
|
|
#define CVMX_L2C_DBG \
|
|
CVMX_ADD_IO_SEG(0x0001180080000030ull)
|
|
#define CVMX_L2C_DUT \
|
|
CVMX_ADD_IO_SEG(0x0001180080000050ull)
|
|
#define CVMX_L2C_GRPWRR0 \
|
|
CVMX_ADD_IO_SEG(0x00011800800000C8ull)
|
|
#define CVMX_L2C_GRPWRR1 \
|
|
CVMX_ADD_IO_SEG(0x00011800800000D0ull)
|
|
#define CVMX_L2C_INT_EN \
|
|
CVMX_ADD_IO_SEG(0x0001180080000100ull)
|
|
#define CVMX_L2C_INT_STAT \
|
|
CVMX_ADD_IO_SEG(0x00011800800000F8ull)
|
|
#define CVMX_L2C_LCKBASE \
|
|
CVMX_ADD_IO_SEG(0x0001180080000058ull)
|
|
#define CVMX_L2C_LCKOFF \
|
|
CVMX_ADD_IO_SEG(0x0001180080000060ull)
|
|
#define CVMX_L2C_LFB0 \
|
|
CVMX_ADD_IO_SEG(0x0001180080000038ull)
|
|
#define CVMX_L2C_LFB1 \
|
|
CVMX_ADD_IO_SEG(0x0001180080000040ull)
|
|
#define CVMX_L2C_LFB2 \
|
|
CVMX_ADD_IO_SEG(0x0001180080000048ull)
|
|
#define CVMX_L2C_LFB3 \
|
|
CVMX_ADD_IO_SEG(0x00011800800000B8ull)
|
|
#define CVMX_L2C_OOB \
|
|
CVMX_ADD_IO_SEG(0x00011800800000D8ull)
|
|
#define CVMX_L2C_OOB1 \
|
|
CVMX_ADD_IO_SEG(0x00011800800000E0ull)
|
|
#define CVMX_L2C_OOB2 \
|
|
CVMX_ADD_IO_SEG(0x00011800800000E8ull)
|
|
#define CVMX_L2C_OOB3 \
|
|
CVMX_ADD_IO_SEG(0x00011800800000F0ull)
|
|
#define CVMX_L2C_PFC0 \
|
|
CVMX_ADD_IO_SEG(0x0001180080000098ull)
|
|
#define CVMX_L2C_PFC1 \
|
|
CVMX_ADD_IO_SEG(0x00011800800000A0ull)
|
|
#define CVMX_L2C_PFC2 \
|
|
CVMX_ADD_IO_SEG(0x00011800800000A8ull)
|
|
#define CVMX_L2C_PFC3 \
|
|
CVMX_ADD_IO_SEG(0x00011800800000B0ull)
|
|
#define CVMX_L2C_PFCTL \
|
|
CVMX_ADD_IO_SEG(0x0001180080000090ull)
|
|
#define CVMX_L2C_PFCX(offset) \
|
|
CVMX_ADD_IO_SEG(0x0001180080000098ull + (((offset) & 3) * 8))
|
|
#define CVMX_L2C_PPGRP \
|
|
CVMX_ADD_IO_SEG(0x00011800800000C0ull)
|
|
#define CVMX_L2C_SPAR0 \
|
|
CVMX_ADD_IO_SEG(0x0001180080000068ull)
|
|
#define CVMX_L2C_SPAR1 \
|
|
CVMX_ADD_IO_SEG(0x0001180080000070ull)
|
|
#define CVMX_L2C_SPAR2 \
|
|
CVMX_ADD_IO_SEG(0x0001180080000078ull)
|
|
#define CVMX_L2C_SPAR3 \
|
|
CVMX_ADD_IO_SEG(0x0001180080000080ull)
|
|
#define CVMX_L2C_SPAR4 \
|
|
CVMX_ADD_IO_SEG(0x0001180080000088ull)
|
|
|
|
union cvmx_l2c_bst0 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_bst0_s {
|
|
uint64_t reserved_24_63:40;
|
|
uint64_t dtbnk:1;
|
|
uint64_t wlb_msk:4;
|
|
uint64_t dtcnt:13;
|
|
uint64_t dt:1;
|
|
uint64_t stin_msk:1;
|
|
uint64_t wlb_dat:4;
|
|
} s;
|
|
struct cvmx_l2c_bst0_cn30xx {
|
|
uint64_t reserved_23_63:41;
|
|
uint64_t wlb_msk:4;
|
|
uint64_t reserved_15_18:4;
|
|
uint64_t dtcnt:9;
|
|
uint64_t dt:1;
|
|
uint64_t reserved_4_4:1;
|
|
uint64_t wlb_dat:4;
|
|
} cn30xx;
|
|
struct cvmx_l2c_bst0_cn31xx {
|
|
uint64_t reserved_23_63:41;
|
|
uint64_t wlb_msk:4;
|
|
uint64_t reserved_16_18:3;
|
|
uint64_t dtcnt:10;
|
|
uint64_t dt:1;
|
|
uint64_t stin_msk:1;
|
|
uint64_t wlb_dat:4;
|
|
} cn31xx;
|
|
struct cvmx_l2c_bst0_cn38xx {
|
|
uint64_t reserved_19_63:45;
|
|
uint64_t dtcnt:13;
|
|
uint64_t dt:1;
|
|
uint64_t stin_msk:1;
|
|
uint64_t wlb_dat:4;
|
|
} cn38xx;
|
|
struct cvmx_l2c_bst0_cn38xx cn38xxp2;
|
|
struct cvmx_l2c_bst0_cn50xx {
|
|
uint64_t reserved_24_63:40;
|
|
uint64_t dtbnk:1;
|
|
uint64_t wlb_msk:4;
|
|
uint64_t reserved_16_18:3;
|
|
uint64_t dtcnt:10;
|
|
uint64_t dt:1;
|
|
uint64_t stin_msk:1;
|
|
uint64_t wlb_dat:4;
|
|
} cn50xx;
|
|
struct cvmx_l2c_bst0_cn50xx cn52xx;
|
|
struct cvmx_l2c_bst0_cn50xx cn52xxp1;
|
|
struct cvmx_l2c_bst0_s cn56xx;
|
|
struct cvmx_l2c_bst0_s cn56xxp1;
|
|
struct cvmx_l2c_bst0_s cn58xx;
|
|
struct cvmx_l2c_bst0_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_bst1 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_bst1_s {
|
|
uint64_t reserved_9_63:55;
|
|
uint64_t l2t:9;
|
|
} s;
|
|
struct cvmx_l2c_bst1_cn30xx {
|
|
uint64_t reserved_16_63:48;
|
|
uint64_t vwdf:4;
|
|
uint64_t lrf:2;
|
|
uint64_t vab_vwcf:1;
|
|
uint64_t reserved_5_8:4;
|
|
uint64_t l2t:5;
|
|
} cn30xx;
|
|
struct cvmx_l2c_bst1_cn30xx cn31xx;
|
|
struct cvmx_l2c_bst1_cn38xx {
|
|
uint64_t reserved_16_63:48;
|
|
uint64_t vwdf:4;
|
|
uint64_t lrf:2;
|
|
uint64_t vab_vwcf:1;
|
|
uint64_t l2t:9;
|
|
} cn38xx;
|
|
struct cvmx_l2c_bst1_cn38xx cn38xxp2;
|
|
struct cvmx_l2c_bst1_cn38xx cn50xx;
|
|
struct cvmx_l2c_bst1_cn52xx {
|
|
uint64_t reserved_19_63:45;
|
|
uint64_t plc2:1;
|
|
uint64_t plc1:1;
|
|
uint64_t plc0:1;
|
|
uint64_t vwdf:4;
|
|
uint64_t reserved_11_11:1;
|
|
uint64_t ilc:1;
|
|
uint64_t vab_vwcf:1;
|
|
uint64_t l2t:9;
|
|
} cn52xx;
|
|
struct cvmx_l2c_bst1_cn52xx cn52xxp1;
|
|
struct cvmx_l2c_bst1_cn56xx {
|
|
uint64_t reserved_24_63:40;
|
|
uint64_t plc2:1;
|
|
uint64_t plc1:1;
|
|
uint64_t plc0:1;
|
|
uint64_t ilc:1;
|
|
uint64_t vwdf1:4;
|
|
uint64_t vwdf0:4;
|
|
uint64_t vab_vwcf1:1;
|
|
uint64_t reserved_10_10:1;
|
|
uint64_t vab_vwcf0:1;
|
|
uint64_t l2t:9;
|
|
} cn56xx;
|
|
struct cvmx_l2c_bst1_cn56xx cn56xxp1;
|
|
struct cvmx_l2c_bst1_cn38xx cn58xx;
|
|
struct cvmx_l2c_bst1_cn38xx cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_bst2 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_bst2_s {
|
|
uint64_t reserved_16_63:48;
|
|
uint64_t mrb:4;
|
|
uint64_t reserved_4_11:8;
|
|
uint64_t ipcbst:1;
|
|
uint64_t picbst:1;
|
|
uint64_t xrdmsk:1;
|
|
uint64_t xrddat:1;
|
|
} s;
|
|
struct cvmx_l2c_bst2_cn30xx {
|
|
uint64_t reserved_16_63:48;
|
|
uint64_t mrb:4;
|
|
uint64_t rmdf:4;
|
|
uint64_t reserved_4_7:4;
|
|
uint64_t ipcbst:1;
|
|
uint64_t reserved_2_2:1;
|
|
uint64_t xrdmsk:1;
|
|
uint64_t xrddat:1;
|
|
} cn30xx;
|
|
struct cvmx_l2c_bst2_cn30xx cn31xx;
|
|
struct cvmx_l2c_bst2_cn38xx {
|
|
uint64_t reserved_16_63:48;
|
|
uint64_t mrb:4;
|
|
uint64_t rmdf:4;
|
|
uint64_t rhdf:4;
|
|
uint64_t ipcbst:1;
|
|
uint64_t picbst:1;
|
|
uint64_t xrdmsk:1;
|
|
uint64_t xrddat:1;
|
|
} cn38xx;
|
|
struct cvmx_l2c_bst2_cn38xx cn38xxp2;
|
|
struct cvmx_l2c_bst2_cn30xx cn50xx;
|
|
struct cvmx_l2c_bst2_cn30xx cn52xx;
|
|
struct cvmx_l2c_bst2_cn30xx cn52xxp1;
|
|
struct cvmx_l2c_bst2_cn56xx {
|
|
uint64_t reserved_16_63:48;
|
|
uint64_t mrb:4;
|
|
uint64_t rmdb:4;
|
|
uint64_t rhdb:4;
|
|
uint64_t ipcbst:1;
|
|
uint64_t picbst:1;
|
|
uint64_t xrdmsk:1;
|
|
uint64_t xrddat:1;
|
|
} cn56xx;
|
|
struct cvmx_l2c_bst2_cn56xx cn56xxp1;
|
|
struct cvmx_l2c_bst2_cn56xx cn58xx;
|
|
struct cvmx_l2c_bst2_cn56xx cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_cfg {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_cfg_s {
|
|
uint64_t reserved_20_63:44;
|
|
uint64_t bstrun:1;
|
|
uint64_t lbist:1;
|
|
uint64_t xor_bank:1;
|
|
uint64_t dpres1:1;
|
|
uint64_t dpres0:1;
|
|
uint64_t dfill_dis:1;
|
|
uint64_t fpexp:4;
|
|
uint64_t fpempty:1;
|
|
uint64_t fpen:1;
|
|
uint64_t idxalias:1;
|
|
uint64_t mwf_crd:4;
|
|
uint64_t rsp_arb_mode:1;
|
|
uint64_t rfb_arb_mode:1;
|
|
uint64_t lrf_arb_mode:1;
|
|
} s;
|
|
struct cvmx_l2c_cfg_cn30xx {
|
|
uint64_t reserved_14_63:50;
|
|
uint64_t fpexp:4;
|
|
uint64_t fpempty:1;
|
|
uint64_t fpen:1;
|
|
uint64_t idxalias:1;
|
|
uint64_t mwf_crd:4;
|
|
uint64_t rsp_arb_mode:1;
|
|
uint64_t rfb_arb_mode:1;
|
|
uint64_t lrf_arb_mode:1;
|
|
} cn30xx;
|
|
struct cvmx_l2c_cfg_cn30xx cn31xx;
|
|
struct cvmx_l2c_cfg_cn30xx cn38xx;
|
|
struct cvmx_l2c_cfg_cn30xx cn38xxp2;
|
|
struct cvmx_l2c_cfg_cn50xx {
|
|
uint64_t reserved_20_63:44;
|
|
uint64_t bstrun:1;
|
|
uint64_t lbist:1;
|
|
uint64_t reserved_14_17:4;
|
|
uint64_t fpexp:4;
|
|
uint64_t fpempty:1;
|
|
uint64_t fpen:1;
|
|
uint64_t idxalias:1;
|
|
uint64_t mwf_crd:4;
|
|
uint64_t rsp_arb_mode:1;
|
|
uint64_t rfb_arb_mode:1;
|
|
uint64_t lrf_arb_mode:1;
|
|
} cn50xx;
|
|
struct cvmx_l2c_cfg_cn50xx cn52xx;
|
|
struct cvmx_l2c_cfg_cn50xx cn52xxp1;
|
|
struct cvmx_l2c_cfg_s cn56xx;
|
|
struct cvmx_l2c_cfg_s cn56xxp1;
|
|
struct cvmx_l2c_cfg_cn58xx {
|
|
uint64_t reserved_20_63:44;
|
|
uint64_t bstrun:1;
|
|
uint64_t lbist:1;
|
|
uint64_t reserved_15_17:3;
|
|
uint64_t dfill_dis:1;
|
|
uint64_t fpexp:4;
|
|
uint64_t fpempty:1;
|
|
uint64_t fpen:1;
|
|
uint64_t idxalias:1;
|
|
uint64_t mwf_crd:4;
|
|
uint64_t rsp_arb_mode:1;
|
|
uint64_t rfb_arb_mode:1;
|
|
uint64_t lrf_arb_mode:1;
|
|
} cn58xx;
|
|
struct cvmx_l2c_cfg_cn58xxp1 {
|
|
uint64_t reserved_15_63:49;
|
|
uint64_t dfill_dis:1;
|
|
uint64_t fpexp:4;
|
|
uint64_t fpempty:1;
|
|
uint64_t fpen:1;
|
|
uint64_t idxalias:1;
|
|
uint64_t mwf_crd:4;
|
|
uint64_t rsp_arb_mode:1;
|
|
uint64_t rfb_arb_mode:1;
|
|
uint64_t lrf_arb_mode:1;
|
|
} cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_dbg {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_dbg_s {
|
|
uint64_t reserved_15_63:49;
|
|
uint64_t lfb_enum:4;
|
|
uint64_t lfb_dmp:1;
|
|
uint64_t ppnum:4;
|
|
uint64_t set:3;
|
|
uint64_t finv:1;
|
|
uint64_t l2d:1;
|
|
uint64_t l2t:1;
|
|
} s;
|
|
struct cvmx_l2c_dbg_cn30xx {
|
|
uint64_t reserved_13_63:51;
|
|
uint64_t lfb_enum:2;
|
|
uint64_t lfb_dmp:1;
|
|
uint64_t reserved_5_9:5;
|
|
uint64_t set:2;
|
|
uint64_t finv:1;
|
|
uint64_t l2d:1;
|
|
uint64_t l2t:1;
|
|
} cn30xx;
|
|
struct cvmx_l2c_dbg_cn31xx {
|
|
uint64_t reserved_14_63:50;
|
|
uint64_t lfb_enum:3;
|
|
uint64_t lfb_dmp:1;
|
|
uint64_t reserved_7_9:3;
|
|
uint64_t ppnum:1;
|
|
uint64_t reserved_5_5:1;
|
|
uint64_t set:2;
|
|
uint64_t finv:1;
|
|
uint64_t l2d:1;
|
|
uint64_t l2t:1;
|
|
} cn31xx;
|
|
struct cvmx_l2c_dbg_s cn38xx;
|
|
struct cvmx_l2c_dbg_s cn38xxp2;
|
|
struct cvmx_l2c_dbg_cn50xx {
|
|
uint64_t reserved_14_63:50;
|
|
uint64_t lfb_enum:3;
|
|
uint64_t lfb_dmp:1;
|
|
uint64_t reserved_7_9:3;
|
|
uint64_t ppnum:1;
|
|
uint64_t set:3;
|
|
uint64_t finv:1;
|
|
uint64_t l2d:1;
|
|
uint64_t l2t:1;
|
|
} cn50xx;
|
|
struct cvmx_l2c_dbg_cn52xx {
|
|
uint64_t reserved_14_63:50;
|
|
uint64_t lfb_enum:3;
|
|
uint64_t lfb_dmp:1;
|
|
uint64_t reserved_8_9:2;
|
|
uint64_t ppnum:2;
|
|
uint64_t set:3;
|
|
uint64_t finv:1;
|
|
uint64_t l2d:1;
|
|
uint64_t l2t:1;
|
|
} cn52xx;
|
|
struct cvmx_l2c_dbg_cn52xx cn52xxp1;
|
|
struct cvmx_l2c_dbg_s cn56xx;
|
|
struct cvmx_l2c_dbg_s cn56xxp1;
|
|
struct cvmx_l2c_dbg_s cn58xx;
|
|
struct cvmx_l2c_dbg_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_dut {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_dut_s {
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t dtena:1;
|
|
uint64_t reserved_30_30:1;
|
|
uint64_t dt_vld:1;
|
|
uint64_t dt_tag:29;
|
|
} s;
|
|
struct cvmx_l2c_dut_s cn30xx;
|
|
struct cvmx_l2c_dut_s cn31xx;
|
|
struct cvmx_l2c_dut_s cn38xx;
|
|
struct cvmx_l2c_dut_s cn38xxp2;
|
|
struct cvmx_l2c_dut_s cn50xx;
|
|
struct cvmx_l2c_dut_s cn52xx;
|
|
struct cvmx_l2c_dut_s cn52xxp1;
|
|
struct cvmx_l2c_dut_s cn56xx;
|
|
struct cvmx_l2c_dut_s cn56xxp1;
|
|
struct cvmx_l2c_dut_s cn58xx;
|
|
struct cvmx_l2c_dut_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_grpwrr0 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_grpwrr0_s {
|
|
uint64_t plc1rmsk:32;
|
|
uint64_t plc0rmsk:32;
|
|
} s;
|
|
struct cvmx_l2c_grpwrr0_s cn52xx;
|
|
struct cvmx_l2c_grpwrr0_s cn52xxp1;
|
|
struct cvmx_l2c_grpwrr0_s cn56xx;
|
|
struct cvmx_l2c_grpwrr0_s cn56xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_grpwrr1 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_grpwrr1_s {
|
|
uint64_t ilcrmsk:32;
|
|
uint64_t plc2rmsk:32;
|
|
} s;
|
|
struct cvmx_l2c_grpwrr1_s cn52xx;
|
|
struct cvmx_l2c_grpwrr1_s cn52xxp1;
|
|
struct cvmx_l2c_grpwrr1_s cn56xx;
|
|
struct cvmx_l2c_grpwrr1_s cn56xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_int_en {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_int_en_s {
|
|
uint64_t reserved_9_63:55;
|
|
uint64_t lck2ena:1;
|
|
uint64_t lckena:1;
|
|
uint64_t l2ddeden:1;
|
|
uint64_t l2dsecen:1;
|
|
uint64_t l2tdeden:1;
|
|
uint64_t l2tsecen:1;
|
|
uint64_t oob3en:1;
|
|
uint64_t oob2en:1;
|
|
uint64_t oob1en:1;
|
|
} s;
|
|
struct cvmx_l2c_int_en_s cn52xx;
|
|
struct cvmx_l2c_int_en_s cn52xxp1;
|
|
struct cvmx_l2c_int_en_s cn56xx;
|
|
struct cvmx_l2c_int_en_s cn56xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_int_stat {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_int_stat_s {
|
|
uint64_t reserved_9_63:55;
|
|
uint64_t lck2:1;
|
|
uint64_t lck:1;
|
|
uint64_t l2dded:1;
|
|
uint64_t l2dsec:1;
|
|
uint64_t l2tded:1;
|
|
uint64_t l2tsec:1;
|
|
uint64_t oob3:1;
|
|
uint64_t oob2:1;
|
|
uint64_t oob1:1;
|
|
} s;
|
|
struct cvmx_l2c_int_stat_s cn52xx;
|
|
struct cvmx_l2c_int_stat_s cn52xxp1;
|
|
struct cvmx_l2c_int_stat_s cn56xx;
|
|
struct cvmx_l2c_int_stat_s cn56xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_lckbase {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_lckbase_s {
|
|
uint64_t reserved_31_63:33;
|
|
uint64_t lck_base:27;
|
|
uint64_t reserved_1_3:3;
|
|
uint64_t lck_ena:1;
|
|
} s;
|
|
struct cvmx_l2c_lckbase_s cn30xx;
|
|
struct cvmx_l2c_lckbase_s cn31xx;
|
|
struct cvmx_l2c_lckbase_s cn38xx;
|
|
struct cvmx_l2c_lckbase_s cn38xxp2;
|
|
struct cvmx_l2c_lckbase_s cn50xx;
|
|
struct cvmx_l2c_lckbase_s cn52xx;
|
|
struct cvmx_l2c_lckbase_s cn52xxp1;
|
|
struct cvmx_l2c_lckbase_s cn56xx;
|
|
struct cvmx_l2c_lckbase_s cn56xxp1;
|
|
struct cvmx_l2c_lckbase_s cn58xx;
|
|
struct cvmx_l2c_lckbase_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_lckoff {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_lckoff_s {
|
|
uint64_t reserved_10_63:54;
|
|
uint64_t lck_offset:10;
|
|
} s;
|
|
struct cvmx_l2c_lckoff_s cn30xx;
|
|
struct cvmx_l2c_lckoff_s cn31xx;
|
|
struct cvmx_l2c_lckoff_s cn38xx;
|
|
struct cvmx_l2c_lckoff_s cn38xxp2;
|
|
struct cvmx_l2c_lckoff_s cn50xx;
|
|
struct cvmx_l2c_lckoff_s cn52xx;
|
|
struct cvmx_l2c_lckoff_s cn52xxp1;
|
|
struct cvmx_l2c_lckoff_s cn56xx;
|
|
struct cvmx_l2c_lckoff_s cn56xxp1;
|
|
struct cvmx_l2c_lckoff_s cn58xx;
|
|
struct cvmx_l2c_lckoff_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_lfb0 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_lfb0_s {
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t stcpnd:1;
|
|
uint64_t stpnd:1;
|
|
uint64_t stinv:1;
|
|
uint64_t stcfl:1;
|
|
uint64_t vam:1;
|
|
uint64_t inxt:4;
|
|
uint64_t itl:1;
|
|
uint64_t ihd:1;
|
|
uint64_t set:3;
|
|
uint64_t vabnum:4;
|
|
uint64_t sid:9;
|
|
uint64_t cmd:4;
|
|
uint64_t vld:1;
|
|
} s;
|
|
struct cvmx_l2c_lfb0_cn30xx {
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t stcpnd:1;
|
|
uint64_t stpnd:1;
|
|
uint64_t stinv:1;
|
|
uint64_t stcfl:1;
|
|
uint64_t vam:1;
|
|
uint64_t reserved_25_26:2;
|
|
uint64_t inxt:2;
|
|
uint64_t itl:1;
|
|
uint64_t ihd:1;
|
|
uint64_t reserved_20_20:1;
|
|
uint64_t set:2;
|
|
uint64_t reserved_16_17:2;
|
|
uint64_t vabnum:2;
|
|
uint64_t sid:9;
|
|
uint64_t cmd:4;
|
|
uint64_t vld:1;
|
|
} cn30xx;
|
|
struct cvmx_l2c_lfb0_cn31xx {
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t stcpnd:1;
|
|
uint64_t stpnd:1;
|
|
uint64_t stinv:1;
|
|
uint64_t stcfl:1;
|
|
uint64_t vam:1;
|
|
uint64_t reserved_26_26:1;
|
|
uint64_t inxt:3;
|
|
uint64_t itl:1;
|
|
uint64_t ihd:1;
|
|
uint64_t reserved_20_20:1;
|
|
uint64_t set:2;
|
|
uint64_t reserved_17_17:1;
|
|
uint64_t vabnum:3;
|
|
uint64_t sid:9;
|
|
uint64_t cmd:4;
|
|
uint64_t vld:1;
|
|
} cn31xx;
|
|
struct cvmx_l2c_lfb0_s cn38xx;
|
|
struct cvmx_l2c_lfb0_s cn38xxp2;
|
|
struct cvmx_l2c_lfb0_cn50xx {
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t stcpnd:1;
|
|
uint64_t stpnd:1;
|
|
uint64_t stinv:1;
|
|
uint64_t stcfl:1;
|
|
uint64_t vam:1;
|
|
uint64_t reserved_26_26:1;
|
|
uint64_t inxt:3;
|
|
uint64_t itl:1;
|
|
uint64_t ihd:1;
|
|
uint64_t set:3;
|
|
uint64_t reserved_17_17:1;
|
|
uint64_t vabnum:3;
|
|
uint64_t sid:9;
|
|
uint64_t cmd:4;
|
|
uint64_t vld:1;
|
|
} cn50xx;
|
|
struct cvmx_l2c_lfb0_cn50xx cn52xx;
|
|
struct cvmx_l2c_lfb0_cn50xx cn52xxp1;
|
|
struct cvmx_l2c_lfb0_s cn56xx;
|
|
struct cvmx_l2c_lfb0_s cn56xxp1;
|
|
struct cvmx_l2c_lfb0_s cn58xx;
|
|
struct cvmx_l2c_lfb0_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_lfb1 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_lfb1_s {
|
|
uint64_t reserved_19_63:45;
|
|
uint64_t dsgoing:1;
|
|
uint64_t bid:2;
|
|
uint64_t wtrsp:1;
|
|
uint64_t wtdw:1;
|
|
uint64_t wtdq:1;
|
|
uint64_t wtwhp:1;
|
|
uint64_t wtwhf:1;
|
|
uint64_t wtwrm:1;
|
|
uint64_t wtstm:1;
|
|
uint64_t wtrda:1;
|
|
uint64_t wtstdt:1;
|
|
uint64_t wtstrsp:1;
|
|
uint64_t wtstrsc:1;
|
|
uint64_t wtvtm:1;
|
|
uint64_t wtmfl:1;
|
|
uint64_t prbrty:1;
|
|
uint64_t wtprb:1;
|
|
uint64_t vld:1;
|
|
} s;
|
|
struct cvmx_l2c_lfb1_s cn30xx;
|
|
struct cvmx_l2c_lfb1_s cn31xx;
|
|
struct cvmx_l2c_lfb1_s cn38xx;
|
|
struct cvmx_l2c_lfb1_s cn38xxp2;
|
|
struct cvmx_l2c_lfb1_s cn50xx;
|
|
struct cvmx_l2c_lfb1_s cn52xx;
|
|
struct cvmx_l2c_lfb1_s cn52xxp1;
|
|
struct cvmx_l2c_lfb1_s cn56xx;
|
|
struct cvmx_l2c_lfb1_s cn56xxp1;
|
|
struct cvmx_l2c_lfb1_s cn58xx;
|
|
struct cvmx_l2c_lfb1_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_lfb2 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_lfb2_s {
|
|
uint64_t reserved_0_63:64;
|
|
} s;
|
|
struct cvmx_l2c_lfb2_cn30xx {
|
|
uint64_t reserved_27_63:37;
|
|
uint64_t lfb_tag:19;
|
|
uint64_t lfb_idx:8;
|
|
} cn30xx;
|
|
struct cvmx_l2c_lfb2_cn31xx {
|
|
uint64_t reserved_27_63:37;
|
|
uint64_t lfb_tag:17;
|
|
uint64_t lfb_idx:10;
|
|
} cn31xx;
|
|
struct cvmx_l2c_lfb2_cn31xx cn38xx;
|
|
struct cvmx_l2c_lfb2_cn31xx cn38xxp2;
|
|
struct cvmx_l2c_lfb2_cn50xx {
|
|
uint64_t reserved_27_63:37;
|
|
uint64_t lfb_tag:20;
|
|
uint64_t lfb_idx:7;
|
|
} cn50xx;
|
|
struct cvmx_l2c_lfb2_cn52xx {
|
|
uint64_t reserved_27_63:37;
|
|
uint64_t lfb_tag:18;
|
|
uint64_t lfb_idx:9;
|
|
} cn52xx;
|
|
struct cvmx_l2c_lfb2_cn52xx cn52xxp1;
|
|
struct cvmx_l2c_lfb2_cn56xx {
|
|
uint64_t reserved_27_63:37;
|
|
uint64_t lfb_tag:16;
|
|
uint64_t lfb_idx:11;
|
|
} cn56xx;
|
|
struct cvmx_l2c_lfb2_cn56xx cn56xxp1;
|
|
struct cvmx_l2c_lfb2_cn56xx cn58xx;
|
|
struct cvmx_l2c_lfb2_cn56xx cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_lfb3 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_lfb3_s {
|
|
uint64_t reserved_5_63:59;
|
|
uint64_t stpartdis:1;
|
|
uint64_t lfb_hwm:4;
|
|
} s;
|
|
struct cvmx_l2c_lfb3_cn30xx {
|
|
uint64_t reserved_5_63:59;
|
|
uint64_t stpartdis:1;
|
|
uint64_t reserved_2_3:2;
|
|
uint64_t lfb_hwm:2;
|
|
} cn30xx;
|
|
struct cvmx_l2c_lfb3_cn31xx {
|
|
uint64_t reserved_5_63:59;
|
|
uint64_t stpartdis:1;
|
|
uint64_t reserved_3_3:1;
|
|
uint64_t lfb_hwm:3;
|
|
} cn31xx;
|
|
struct cvmx_l2c_lfb3_s cn38xx;
|
|
struct cvmx_l2c_lfb3_s cn38xxp2;
|
|
struct cvmx_l2c_lfb3_cn31xx cn50xx;
|
|
struct cvmx_l2c_lfb3_cn31xx cn52xx;
|
|
struct cvmx_l2c_lfb3_cn31xx cn52xxp1;
|
|
struct cvmx_l2c_lfb3_s cn56xx;
|
|
struct cvmx_l2c_lfb3_s cn56xxp1;
|
|
struct cvmx_l2c_lfb3_s cn58xx;
|
|
struct cvmx_l2c_lfb3_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_oob {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_oob_s {
|
|
uint64_t reserved_2_63:62;
|
|
uint64_t dwbena:1;
|
|
uint64_t stena:1;
|
|
} s;
|
|
struct cvmx_l2c_oob_s cn52xx;
|
|
struct cvmx_l2c_oob_s cn52xxp1;
|
|
struct cvmx_l2c_oob_s cn56xx;
|
|
struct cvmx_l2c_oob_s cn56xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_oob1 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_oob1_s {
|
|
uint64_t fadr:27;
|
|
uint64_t fsrc:1;
|
|
uint64_t reserved_34_35:2;
|
|
uint64_t sadr:14;
|
|
uint64_t reserved_14_19:6;
|
|
uint64_t size:14;
|
|
} s;
|
|
struct cvmx_l2c_oob1_s cn52xx;
|
|
struct cvmx_l2c_oob1_s cn52xxp1;
|
|
struct cvmx_l2c_oob1_s cn56xx;
|
|
struct cvmx_l2c_oob1_s cn56xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_oob2 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_oob2_s {
|
|
uint64_t fadr:27;
|
|
uint64_t fsrc:1;
|
|
uint64_t reserved_34_35:2;
|
|
uint64_t sadr:14;
|
|
uint64_t reserved_14_19:6;
|
|
uint64_t size:14;
|
|
} s;
|
|
struct cvmx_l2c_oob2_s cn52xx;
|
|
struct cvmx_l2c_oob2_s cn52xxp1;
|
|
struct cvmx_l2c_oob2_s cn56xx;
|
|
struct cvmx_l2c_oob2_s cn56xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_oob3 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_oob3_s {
|
|
uint64_t fadr:27;
|
|
uint64_t fsrc:1;
|
|
uint64_t reserved_34_35:2;
|
|
uint64_t sadr:14;
|
|
uint64_t reserved_14_19:6;
|
|
uint64_t size:14;
|
|
} s;
|
|
struct cvmx_l2c_oob3_s cn52xx;
|
|
struct cvmx_l2c_oob3_s cn52xxp1;
|
|
struct cvmx_l2c_oob3_s cn56xx;
|
|
struct cvmx_l2c_oob3_s cn56xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_pfcx {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_pfcx_s {
|
|
uint64_t reserved_36_63:28;
|
|
uint64_t pfcnt0:36;
|
|
} s;
|
|
struct cvmx_l2c_pfcx_s cn30xx;
|
|
struct cvmx_l2c_pfcx_s cn31xx;
|
|
struct cvmx_l2c_pfcx_s cn38xx;
|
|
struct cvmx_l2c_pfcx_s cn38xxp2;
|
|
struct cvmx_l2c_pfcx_s cn50xx;
|
|
struct cvmx_l2c_pfcx_s cn52xx;
|
|
struct cvmx_l2c_pfcx_s cn52xxp1;
|
|
struct cvmx_l2c_pfcx_s cn56xx;
|
|
struct cvmx_l2c_pfcx_s cn56xxp1;
|
|
struct cvmx_l2c_pfcx_s cn58xx;
|
|
struct cvmx_l2c_pfcx_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_pfctl {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_pfctl_s {
|
|
uint64_t reserved_36_63:28;
|
|
uint64_t cnt3rdclr:1;
|
|
uint64_t cnt2rdclr:1;
|
|
uint64_t cnt1rdclr:1;
|
|
uint64_t cnt0rdclr:1;
|
|
uint64_t cnt3ena:1;
|
|
uint64_t cnt3clr:1;
|
|
uint64_t cnt3sel:6;
|
|
uint64_t cnt2ena:1;
|
|
uint64_t cnt2clr:1;
|
|
uint64_t cnt2sel:6;
|
|
uint64_t cnt1ena:1;
|
|
uint64_t cnt1clr:1;
|
|
uint64_t cnt1sel:6;
|
|
uint64_t cnt0ena:1;
|
|
uint64_t cnt0clr:1;
|
|
uint64_t cnt0sel:6;
|
|
} s;
|
|
struct cvmx_l2c_pfctl_s cn30xx;
|
|
struct cvmx_l2c_pfctl_s cn31xx;
|
|
struct cvmx_l2c_pfctl_s cn38xx;
|
|
struct cvmx_l2c_pfctl_s cn38xxp2;
|
|
struct cvmx_l2c_pfctl_s cn50xx;
|
|
struct cvmx_l2c_pfctl_s cn52xx;
|
|
struct cvmx_l2c_pfctl_s cn52xxp1;
|
|
struct cvmx_l2c_pfctl_s cn56xx;
|
|
struct cvmx_l2c_pfctl_s cn56xxp1;
|
|
struct cvmx_l2c_pfctl_s cn58xx;
|
|
struct cvmx_l2c_pfctl_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_ppgrp {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_ppgrp_s {
|
|
uint64_t reserved_24_63:40;
|
|
uint64_t pp11grp:2;
|
|
uint64_t pp10grp:2;
|
|
uint64_t pp9grp:2;
|
|
uint64_t pp8grp:2;
|
|
uint64_t pp7grp:2;
|
|
uint64_t pp6grp:2;
|
|
uint64_t pp5grp:2;
|
|
uint64_t pp4grp:2;
|
|
uint64_t pp3grp:2;
|
|
uint64_t pp2grp:2;
|
|
uint64_t pp1grp:2;
|
|
uint64_t pp0grp:2;
|
|
} s;
|
|
struct cvmx_l2c_ppgrp_cn52xx {
|
|
uint64_t reserved_8_63:56;
|
|
uint64_t pp3grp:2;
|
|
uint64_t pp2grp:2;
|
|
uint64_t pp1grp:2;
|
|
uint64_t pp0grp:2;
|
|
} cn52xx;
|
|
struct cvmx_l2c_ppgrp_cn52xx cn52xxp1;
|
|
struct cvmx_l2c_ppgrp_s cn56xx;
|
|
struct cvmx_l2c_ppgrp_s cn56xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_spar0 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_spar0_s {
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t umsk3:8;
|
|
uint64_t umsk2:8;
|
|
uint64_t umsk1:8;
|
|
uint64_t umsk0:8;
|
|
} s;
|
|
struct cvmx_l2c_spar0_cn30xx {
|
|
uint64_t reserved_4_63:60;
|
|
uint64_t umsk0:4;
|
|
} cn30xx;
|
|
struct cvmx_l2c_spar0_cn31xx {
|
|
uint64_t reserved_12_63:52;
|
|
uint64_t umsk1:4;
|
|
uint64_t reserved_4_7:4;
|
|
uint64_t umsk0:4;
|
|
} cn31xx;
|
|
struct cvmx_l2c_spar0_s cn38xx;
|
|
struct cvmx_l2c_spar0_s cn38xxp2;
|
|
struct cvmx_l2c_spar0_cn50xx {
|
|
uint64_t reserved_16_63:48;
|
|
uint64_t umsk1:8;
|
|
uint64_t umsk0:8;
|
|
} cn50xx;
|
|
struct cvmx_l2c_spar0_s cn52xx;
|
|
struct cvmx_l2c_spar0_s cn52xxp1;
|
|
struct cvmx_l2c_spar0_s cn56xx;
|
|
struct cvmx_l2c_spar0_s cn56xxp1;
|
|
struct cvmx_l2c_spar0_s cn58xx;
|
|
struct cvmx_l2c_spar0_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_spar1 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_spar1_s {
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t umsk7:8;
|
|
uint64_t umsk6:8;
|
|
uint64_t umsk5:8;
|
|
uint64_t umsk4:8;
|
|
} s;
|
|
struct cvmx_l2c_spar1_s cn38xx;
|
|
struct cvmx_l2c_spar1_s cn38xxp2;
|
|
struct cvmx_l2c_spar1_s cn56xx;
|
|
struct cvmx_l2c_spar1_s cn56xxp1;
|
|
struct cvmx_l2c_spar1_s cn58xx;
|
|
struct cvmx_l2c_spar1_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_spar2 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_spar2_s {
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t umsk11:8;
|
|
uint64_t umsk10:8;
|
|
uint64_t umsk9:8;
|
|
uint64_t umsk8:8;
|
|
} s;
|
|
struct cvmx_l2c_spar2_s cn38xx;
|
|
struct cvmx_l2c_spar2_s cn38xxp2;
|
|
struct cvmx_l2c_spar2_s cn56xx;
|
|
struct cvmx_l2c_spar2_s cn56xxp1;
|
|
struct cvmx_l2c_spar2_s cn58xx;
|
|
struct cvmx_l2c_spar2_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_spar3 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_spar3_s {
|
|
uint64_t reserved_32_63:32;
|
|
uint64_t umsk15:8;
|
|
uint64_t umsk14:8;
|
|
uint64_t umsk13:8;
|
|
uint64_t umsk12:8;
|
|
} s;
|
|
struct cvmx_l2c_spar3_s cn38xx;
|
|
struct cvmx_l2c_spar3_s cn38xxp2;
|
|
struct cvmx_l2c_spar3_s cn58xx;
|
|
struct cvmx_l2c_spar3_s cn58xxp1;
|
|
};
|
|
|
|
union cvmx_l2c_spar4 {
|
|
uint64_t u64;
|
|
struct cvmx_l2c_spar4_s {
|
|
uint64_t reserved_8_63:56;
|
|
uint64_t umskiob:8;
|
|
} s;
|
|
struct cvmx_l2c_spar4_cn30xx {
|
|
uint64_t reserved_4_63:60;
|
|
uint64_t umskiob:4;
|
|
} cn30xx;
|
|
struct cvmx_l2c_spar4_cn30xx cn31xx;
|
|
struct cvmx_l2c_spar4_s cn38xx;
|
|
struct cvmx_l2c_spar4_s cn38xxp2;
|
|
struct cvmx_l2c_spar4_s cn50xx;
|
|
struct cvmx_l2c_spar4_s cn52xx;
|
|
struct cvmx_l2c_spar4_s cn52xxp1;
|
|
struct cvmx_l2c_spar4_s cn56xx;
|
|
struct cvmx_l2c_spar4_s cn56xxp1;
|
|
struct cvmx_l2c_spar4_s cn58xx;
|
|
struct cvmx_l2c_spar4_s cn58xxp1;
|
|
};
|
|
|
|
#endif
|