162306a36Sopenharmony_ci/***********************license start*************** 262306a36Sopenharmony_ci * Author: Cavium Networks 362306a36Sopenharmony_ci * 462306a36Sopenharmony_ci * Contact: support@caviumnetworks.com 562306a36Sopenharmony_ci * This file is part of the OCTEON SDK 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Copyright (c) 2003-2017 Cavium, Inc. 862306a36Sopenharmony_ci * 962306a36Sopenharmony_ci * This file is free software; you can redistribute it and/or modify 1062306a36Sopenharmony_ci * it under the terms of the GNU General Public License, Version 2, as 1162306a36Sopenharmony_ci * published by the Free Software Foundation. 1262306a36Sopenharmony_ci * 1362306a36Sopenharmony_ci * This file is distributed in the hope that it will be useful, but 1462306a36Sopenharmony_ci * AS-IS and WITHOUT ANY WARRANTY; without even the implied warranty 1562306a36Sopenharmony_ci * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, TITLE, or 1662306a36Sopenharmony_ci * NONINFRINGEMENT. See the GNU General Public License for more 1762306a36Sopenharmony_ci * details. 1862306a36Sopenharmony_ci * 1962306a36Sopenharmony_ci * You should have received a copy of the GNU General Public License 2062306a36Sopenharmony_ci * along with this file; if not, write to the Free Software 2162306a36Sopenharmony_ci * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 2262306a36Sopenharmony_ci * or visit http://www.gnu.org/licenses/. 2362306a36Sopenharmony_ci * 2462306a36Sopenharmony_ci * This file may also be available under a different license from Cavium. 2562306a36Sopenharmony_ci * Contact Cavium Networks for more information 2662306a36Sopenharmony_ci ***********************license end**************************************/ 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci#ifndef __CVMX_L2C_DEFS_H__ 2962306a36Sopenharmony_ci#define __CVMX_L2C_DEFS_H__ 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_ci#include <uapi/asm/bitfield.h> 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci#define CVMX_L2C_DBG (CVMX_ADD_IO_SEG(0x0001180080000030ull)) 3462306a36Sopenharmony_ci#define CVMX_L2C_CFG (CVMX_ADD_IO_SEG(0x0001180080000000ull)) 3562306a36Sopenharmony_ci#define CVMX_L2C_CTL (CVMX_ADD_IO_SEG(0x0001180080800000ull)) 3662306a36Sopenharmony_ci#define CVMX_L2C_ERR_TDTX(block_id) \ 3762306a36Sopenharmony_ci (CVMX_ADD_IO_SEG(0x0001180080A007E0ull) + ((block_id) & 3) * 0x40000ull) 3862306a36Sopenharmony_ci#define CVMX_L2C_ERR_TTGX(block_id) \ 3962306a36Sopenharmony_ci (CVMX_ADD_IO_SEG(0x0001180080A007E8ull) + ((block_id) & 3) * 0x40000ull) 4062306a36Sopenharmony_ci#define CVMX_L2C_LCKBASE (CVMX_ADD_IO_SEG(0x0001180080000058ull)) 4162306a36Sopenharmony_ci#define CVMX_L2C_LCKOFF (CVMX_ADD_IO_SEG(0x0001180080000060ull)) 4262306a36Sopenharmony_ci#define CVMX_L2C_PFCTL (CVMX_ADD_IO_SEG(0x0001180080000090ull)) 4362306a36Sopenharmony_ci#define CVMX_L2C_PFCX(offset) (CVMX_ADD_IO_SEG(0x0001180080000098ull) + \ 4462306a36Sopenharmony_ci ((offset) & 3) * 8) 4562306a36Sopenharmony_ci#define CVMX_L2C_PFC0 CVMX_L2C_PFCX(0) 4662306a36Sopenharmony_ci#define CVMX_L2C_PFC1 CVMX_L2C_PFCX(1) 4762306a36Sopenharmony_ci#define CVMX_L2C_PFC2 CVMX_L2C_PFCX(2) 4862306a36Sopenharmony_ci#define CVMX_L2C_PFC3 CVMX_L2C_PFCX(3) 4962306a36Sopenharmony_ci#define CVMX_L2C_SPAR0 (CVMX_ADD_IO_SEG(0x0001180080000068ull)) 5062306a36Sopenharmony_ci#define CVMX_L2C_SPAR1 (CVMX_ADD_IO_SEG(0x0001180080000070ull)) 5162306a36Sopenharmony_ci#define CVMX_L2C_SPAR2 (CVMX_ADD_IO_SEG(0x0001180080000078ull)) 5262306a36Sopenharmony_ci#define CVMX_L2C_SPAR3 (CVMX_ADD_IO_SEG(0x0001180080000080ull)) 5362306a36Sopenharmony_ci#define CVMX_L2C_SPAR4 (CVMX_ADD_IO_SEG(0x0001180080000088ull)) 5462306a36Sopenharmony_ci#define CVMX_L2C_TADX_PFCX(offset, block_id) \ 5562306a36Sopenharmony_ci (CVMX_ADD_IO_SEG(0x0001180080A00400ull) + (((offset) & 3) + \ 5662306a36Sopenharmony_ci ((block_id) & 7) * 0x8000ull) * 8) 5762306a36Sopenharmony_ci#define CVMX_L2C_TADX_PFC0(block_id) (CVMX_ADD_IO_SEG(0x0001180080A00400ull) + \ 5862306a36Sopenharmony_ci ((block_id) & 3) * 0x40000ull) 5962306a36Sopenharmony_ci#define CVMX_L2C_TADX_PFC1(block_id) (CVMX_ADD_IO_SEG(0x0001180080A00408ull) + \ 6062306a36Sopenharmony_ci ((block_id) & 3) * 0x40000ull) 6162306a36Sopenharmony_ci#define CVMX_L2C_TADX_PFC2(block_id) (CVMX_ADD_IO_SEG(0x0001180080A00410ull) + \ 6262306a36Sopenharmony_ci ((block_id) & 3) * 0x40000ull) 6362306a36Sopenharmony_ci#define CVMX_L2C_TADX_PFC3(block_id) (CVMX_ADD_IO_SEG(0x0001180080A00418ull) + \ 6462306a36Sopenharmony_ci ((block_id) & 3) * 0x40000ull) 6562306a36Sopenharmony_ci#define CVMX_L2C_TADX_PRF(offset) (CVMX_ADD_IO_SEG(0x0001180080A00008ull) + \ 6662306a36Sopenharmony_ci ((offset) & 7) * 0x40000ull) 6762306a36Sopenharmony_ci#define CVMX_L2C_TADX_TAG(block_id) (CVMX_ADD_IO_SEG(0x0001180080A00010ull) + \ 6862306a36Sopenharmony_ci ((block_id) & 3) * 0x40000ull) 6962306a36Sopenharmony_ci#define CVMX_L2C_WPAR_IOBX(offset) (CVMX_ADD_IO_SEG(0x0001180080840200ull) + \ 7062306a36Sopenharmony_ci ((offset) & 1) * 8) 7162306a36Sopenharmony_ci#define CVMX_L2C_WPAR_PPX(offset) (CVMX_ADD_IO_SEG(0x0001180080840000ull) + \ 7262306a36Sopenharmony_ci ((offset) & 31) * 8) 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ci 7562306a36Sopenharmony_ciunion cvmx_l2c_err_tdtx { 7662306a36Sopenharmony_ci uint64_t u64; 7762306a36Sopenharmony_ci struct cvmx_l2c_err_tdtx_s { 7862306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t dbe:1, 7962306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t sbe:1, 8062306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t vdbe:1, 8162306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t vsbe:1, 8262306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t syn:10, 8362306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_22_49:28, 8462306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t wayidx:18, 8562306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_2_3:2, 8662306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t type:2, 8762306a36Sopenharmony_ci ;))))))))) 8862306a36Sopenharmony_ci } s; 8962306a36Sopenharmony_ci}; 9062306a36Sopenharmony_ci 9162306a36Sopenharmony_ciunion cvmx_l2c_err_ttgx { 9262306a36Sopenharmony_ci uint64_t u64; 9362306a36Sopenharmony_ci struct cvmx_l2c_err_ttgx_s { 9462306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t dbe:1, 9562306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t sbe:1, 9662306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t noway:1, 9762306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_56_60:5, 9862306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t syn:6, 9962306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_22_49:28, 10062306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t wayidx:15, 10162306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_2_6:5, 10262306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t type:2, 10362306a36Sopenharmony_ci ;))))))))) 10462306a36Sopenharmony_ci } s; 10562306a36Sopenharmony_ci}; 10662306a36Sopenharmony_ci 10762306a36Sopenharmony_ciunion cvmx_l2c_cfg { 10862306a36Sopenharmony_ci uint64_t u64; 10962306a36Sopenharmony_ci struct cvmx_l2c_cfg_s { 11062306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_20_63:44, 11162306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t bstrun:1, 11262306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t lbist:1, 11362306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t xor_bank:1, 11462306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t dpres1:1, 11562306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t dpres0:1, 11662306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t dfill_dis:1, 11762306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t fpexp:4, 11862306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t fpempty:1, 11962306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t fpen:1, 12062306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t idxalias:1, 12162306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t mwf_crd:4, 12262306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t rsp_arb_mode:1, 12362306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t rfb_arb_mode:1, 12462306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t lrf_arb_mode:1, 12562306a36Sopenharmony_ci ;))))))))))))))) 12662306a36Sopenharmony_ci } s; 12762306a36Sopenharmony_ci}; 12862306a36Sopenharmony_ci 12962306a36Sopenharmony_ciunion cvmx_l2c_ctl { 13062306a36Sopenharmony_ci uint64_t u64; 13162306a36Sopenharmony_ci struct cvmx_l2c_ctl_s { 13262306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_30_63:34, 13362306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t sepcmt:1, 13462306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t rdf_fast:1, 13562306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t disstgl2i:1, 13662306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t l2dfsbe:1, 13762306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t l2dfdbe:1, 13862306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t discclk:1, 13962306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t maxvab:4, 14062306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t maxlfb:4, 14162306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t rsp_arb_mode:1, 14262306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t xmc_arb_mode:1, 14362306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t ef_ena:1, 14462306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t ef_cnt:7, 14562306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t vab_thresh:4, 14662306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t disecc:1, 14762306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t disidxalias:1, 14862306a36Sopenharmony_ci ;)))))))))))))))) 14962306a36Sopenharmony_ci } s; 15062306a36Sopenharmony_ci}; 15162306a36Sopenharmony_ci 15262306a36Sopenharmony_ciunion cvmx_l2c_dbg { 15362306a36Sopenharmony_ci uint64_t u64; 15462306a36Sopenharmony_ci struct cvmx_l2c_dbg_s { 15562306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_15_63:49, 15662306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t lfb_enum:4, 15762306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t lfb_dmp:1, 15862306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t ppnum:4, 15962306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t set:3, 16062306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t finv:1, 16162306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t l2d:1, 16262306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t l2t:1, 16362306a36Sopenharmony_ci ;)))))))) 16462306a36Sopenharmony_ci } s; 16562306a36Sopenharmony_ci}; 16662306a36Sopenharmony_ci 16762306a36Sopenharmony_ciunion cvmx_l2c_pfctl { 16862306a36Sopenharmony_ci uint64_t u64; 16962306a36Sopenharmony_ci struct cvmx_l2c_pfctl_s { 17062306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_36_63:28, 17162306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt3rdclr:1, 17262306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt2rdclr:1, 17362306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt1rdclr:1, 17462306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt0rdclr:1, 17562306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt3ena:1, 17662306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt3clr:1, 17762306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt3sel:6, 17862306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt2ena:1, 17962306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt2clr:1, 18062306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt2sel:6, 18162306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt1ena:1, 18262306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt1clr:1, 18362306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt1sel:6, 18462306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt0ena:1, 18562306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt0clr:1, 18662306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt0sel:6, 18762306a36Sopenharmony_ci ;))))))))))))))))) 18862306a36Sopenharmony_ci } s; 18962306a36Sopenharmony_ci}; 19062306a36Sopenharmony_ci 19162306a36Sopenharmony_ciunion cvmx_l2c_tadx_prf { 19262306a36Sopenharmony_ci uint64_t u64; 19362306a36Sopenharmony_ci struct cvmx_l2c_tadx_prf_s { 19462306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_32_63:32, 19562306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt3sel:8, 19662306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt2sel:8, 19762306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt1sel:8, 19862306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t cnt0sel:8, 19962306a36Sopenharmony_ci ;))))) 20062306a36Sopenharmony_ci } s; 20162306a36Sopenharmony_ci}; 20262306a36Sopenharmony_ci 20362306a36Sopenharmony_ciunion cvmx_l2c_tadx_tag { 20462306a36Sopenharmony_ci uint64_t u64; 20562306a36Sopenharmony_ci struct cvmx_l2c_tadx_tag_s { 20662306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_46_63:18, 20762306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t ecc:6, 20862306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_36_39:4, 20962306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t tag:19, 21062306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_4_16:13, 21162306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t use:1, 21262306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t valid:1, 21362306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t dirty:1, 21462306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t lock:1, 21562306a36Sopenharmony_ci ;))))))))) 21662306a36Sopenharmony_ci } s; 21762306a36Sopenharmony_ci}; 21862306a36Sopenharmony_ci 21962306a36Sopenharmony_ciunion cvmx_l2c_lckbase { 22062306a36Sopenharmony_ci uint64_t u64; 22162306a36Sopenharmony_ci struct cvmx_l2c_lckbase_s { 22262306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_31_63:33, 22362306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t lck_base:27, 22462306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_1_3:3, 22562306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t lck_ena:1, 22662306a36Sopenharmony_ci ;)))) 22762306a36Sopenharmony_ci } s; 22862306a36Sopenharmony_ci}; 22962306a36Sopenharmony_ci 23062306a36Sopenharmony_ciunion cvmx_l2c_lckoff { 23162306a36Sopenharmony_ci uint64_t u64; 23262306a36Sopenharmony_ci struct cvmx_l2c_lckoff_s { 23362306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t reserved_10_63:54, 23462306a36Sopenharmony_ci __BITFIELD_FIELD(uint64_t lck_offset:10, 23562306a36Sopenharmony_ci ;)) 23662306a36Sopenharmony_ci } s; 23762306a36Sopenharmony_ci}; 23862306a36Sopenharmony_ci 23962306a36Sopenharmony_ci#endif 240