cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

cvmx-pciercx-defs.h (11497B)


      1/***********************license start***************
      2 * Author: Cavium Networks
      3 *
      4 * Contact: support@caviumnetworks.com
      5 * This file is part of the OCTEON SDK
      6 *
      7 * Copyright (c) 2003-2017 Cavium, Inc.
      8 *
      9 * This file is free software; you can redistribute it and/or modify
     10 * it under the terms of the GNU General Public License, Version 2, as
     11 * published by the Free Software Foundation.
     12 *
     13 * This file is distributed in the hope that it will be useful, but
     14 * AS-IS and WITHOUT ANY WARRANTY; without even the implied warranty
     15 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, TITLE, or
     16 * NONINFRINGEMENT.  See the GNU General Public License for more
     17 * details.
     18 *
     19 * You should have received a copy of the GNU General Public License
     20 * along with this file; if not, write to the Free Software
     21 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
     22 * or visit http://www.gnu.org/licenses/.
     23 *
     24 * This file may also be available under a different license from Cavium.
     25 * Contact Cavium Networks for more information
     26 ***********************license end**************************************/
     27
     28#ifndef __CVMX_PCIERCX_DEFS_H__
     29#define __CVMX_PCIERCX_DEFS_H__
     30
     31#include <uapi/asm/bitfield.h>
     32
     33#define CVMX_PCIERCX_CFG001(block_id) (0x0000000000000004ull)
     34#define CVMX_PCIERCX_CFG006(block_id) (0x0000000000000018ull)
     35#define CVMX_PCIERCX_CFG008(block_id) (0x0000000000000020ull)
     36#define CVMX_PCIERCX_CFG009(block_id) (0x0000000000000024ull)
     37#define CVMX_PCIERCX_CFG010(block_id) (0x0000000000000028ull)
     38#define CVMX_PCIERCX_CFG011(block_id) (0x000000000000002Cull)
     39#define CVMX_PCIERCX_CFG030(block_id) (0x0000000000000078ull)
     40#define CVMX_PCIERCX_CFG031(block_id) (0x000000000000007Cull)
     41#define CVMX_PCIERCX_CFG032(block_id) (0x0000000000000080ull)
     42#define CVMX_PCIERCX_CFG034(block_id) (0x0000000000000088ull)
     43#define CVMX_PCIERCX_CFG035(block_id) (0x000000000000008Cull)
     44#define CVMX_PCIERCX_CFG040(block_id) (0x00000000000000A0ull)
     45#define CVMX_PCIERCX_CFG066(block_id) (0x0000000000000108ull)
     46#define CVMX_PCIERCX_CFG069(block_id) (0x0000000000000114ull)
     47#define CVMX_PCIERCX_CFG070(block_id) (0x0000000000000118ull)
     48#define CVMX_PCIERCX_CFG075(block_id) (0x000000000000012Cull)
     49#define CVMX_PCIERCX_CFG448(block_id) (0x0000000000000700ull)
     50#define CVMX_PCIERCX_CFG452(block_id) (0x0000000000000710ull)
     51#define CVMX_PCIERCX_CFG455(block_id) (0x000000000000071Cull)
     52#define CVMX_PCIERCX_CFG515(block_id) (0x000000000000080Cull)
     53
     54union cvmx_pciercx_cfg001 {
     55	uint32_t u32;
     56	struct cvmx_pciercx_cfg001_s {
     57		__BITFIELD_FIELD(uint32_t dpe:1,
     58		__BITFIELD_FIELD(uint32_t sse:1,
     59		__BITFIELD_FIELD(uint32_t rma:1,
     60		__BITFIELD_FIELD(uint32_t rta:1,
     61		__BITFIELD_FIELD(uint32_t sta:1,
     62		__BITFIELD_FIELD(uint32_t devt:2,
     63		__BITFIELD_FIELD(uint32_t mdpe:1,
     64		__BITFIELD_FIELD(uint32_t fbb:1,
     65		__BITFIELD_FIELD(uint32_t reserved_22_22:1,
     66		__BITFIELD_FIELD(uint32_t m66:1,
     67		__BITFIELD_FIELD(uint32_t cl:1,
     68		__BITFIELD_FIELD(uint32_t i_stat:1,
     69		__BITFIELD_FIELD(uint32_t reserved_11_18:8,
     70		__BITFIELD_FIELD(uint32_t i_dis:1,
     71		__BITFIELD_FIELD(uint32_t fbbe:1,
     72		__BITFIELD_FIELD(uint32_t see:1,
     73		__BITFIELD_FIELD(uint32_t ids_wcc:1,
     74		__BITFIELD_FIELD(uint32_t per:1,
     75		__BITFIELD_FIELD(uint32_t vps:1,
     76		__BITFIELD_FIELD(uint32_t mwice:1,
     77		__BITFIELD_FIELD(uint32_t scse:1,
     78		__BITFIELD_FIELD(uint32_t me:1,
     79		__BITFIELD_FIELD(uint32_t msae:1,
     80		__BITFIELD_FIELD(uint32_t isae:1,
     81		;))))))))))))))))))))))))
     82	} s;
     83};
     84
     85union cvmx_pciercx_cfg006 {
     86	uint32_t u32;
     87	struct cvmx_pciercx_cfg006_s {
     88		__BITFIELD_FIELD(uint32_t slt:8,
     89		__BITFIELD_FIELD(uint32_t subbnum:8,
     90		__BITFIELD_FIELD(uint32_t sbnum:8,
     91		__BITFIELD_FIELD(uint32_t pbnum:8,
     92		;))))
     93	} s;
     94};
     95
     96union cvmx_pciercx_cfg008 {
     97	uint32_t u32;
     98	struct cvmx_pciercx_cfg008_s {
     99		__BITFIELD_FIELD(uint32_t ml_addr:12,
    100		__BITFIELD_FIELD(uint32_t reserved_16_19:4,
    101		__BITFIELD_FIELD(uint32_t mb_addr:12,
    102		__BITFIELD_FIELD(uint32_t reserved_0_3:4,
    103		;))))
    104	} s;
    105};
    106
    107union cvmx_pciercx_cfg009 {
    108	uint32_t u32;
    109	struct cvmx_pciercx_cfg009_s {
    110		__BITFIELD_FIELD(uint32_t lmem_limit:12,
    111		__BITFIELD_FIELD(uint32_t reserved_17_19:3,
    112		__BITFIELD_FIELD(uint32_t mem64b:1,
    113		__BITFIELD_FIELD(uint32_t lmem_base:12,
    114		__BITFIELD_FIELD(uint32_t reserved_1_3:3,
    115		__BITFIELD_FIELD(uint32_t mem64a:1,
    116		;))))))
    117	} s;
    118};
    119
    120union cvmx_pciercx_cfg010 {
    121	uint32_t u32;
    122	struct cvmx_pciercx_cfg010_s {
    123		uint32_t umem_base;
    124	} s;
    125};
    126
    127union cvmx_pciercx_cfg011 {
    128	uint32_t u32;
    129	struct cvmx_pciercx_cfg011_s {
    130		uint32_t umem_limit;
    131	} s;
    132};
    133
    134union cvmx_pciercx_cfg030 {
    135	uint32_t u32;
    136	struct cvmx_pciercx_cfg030_s {
    137		__BITFIELD_FIELD(uint32_t reserved_22_31:10,
    138		__BITFIELD_FIELD(uint32_t tp:1,
    139		__BITFIELD_FIELD(uint32_t ap_d:1,
    140		__BITFIELD_FIELD(uint32_t ur_d:1,
    141		__BITFIELD_FIELD(uint32_t fe_d:1,
    142		__BITFIELD_FIELD(uint32_t nfe_d:1,
    143		__BITFIELD_FIELD(uint32_t ce_d:1,
    144		__BITFIELD_FIELD(uint32_t reserved_15_15:1,
    145		__BITFIELD_FIELD(uint32_t mrrs:3,
    146		__BITFIELD_FIELD(uint32_t ns_en:1,
    147		__BITFIELD_FIELD(uint32_t ap_en:1,
    148		__BITFIELD_FIELD(uint32_t pf_en:1,
    149		__BITFIELD_FIELD(uint32_t etf_en:1,
    150		__BITFIELD_FIELD(uint32_t mps:3,
    151		__BITFIELD_FIELD(uint32_t ro_en:1,
    152		__BITFIELD_FIELD(uint32_t ur_en:1,
    153		__BITFIELD_FIELD(uint32_t fe_en:1,
    154		__BITFIELD_FIELD(uint32_t nfe_en:1,
    155		__BITFIELD_FIELD(uint32_t ce_en:1,
    156		;)))))))))))))))))))
    157	} s;
    158};
    159
    160union cvmx_pciercx_cfg031 {
    161	uint32_t u32;
    162	struct cvmx_pciercx_cfg031_s {
    163		__BITFIELD_FIELD(uint32_t pnum:8,
    164		__BITFIELD_FIELD(uint32_t reserved_23_23:1,
    165		__BITFIELD_FIELD(uint32_t aspm:1,
    166		__BITFIELD_FIELD(uint32_t lbnc:1,
    167		__BITFIELD_FIELD(uint32_t dllarc:1,
    168		__BITFIELD_FIELD(uint32_t sderc:1,
    169		__BITFIELD_FIELD(uint32_t cpm:1,
    170		__BITFIELD_FIELD(uint32_t l1el:3,
    171		__BITFIELD_FIELD(uint32_t l0el:3,
    172		__BITFIELD_FIELD(uint32_t aslpms:2,
    173		__BITFIELD_FIELD(uint32_t mlw:6,
    174		__BITFIELD_FIELD(uint32_t mls:4,
    175		;))))))))))))
    176	} s;
    177};
    178
    179union cvmx_pciercx_cfg032 {
    180	uint32_t u32;
    181	struct cvmx_pciercx_cfg032_s {
    182		__BITFIELD_FIELD(uint32_t lab:1,
    183		__BITFIELD_FIELD(uint32_t lbm:1,
    184		__BITFIELD_FIELD(uint32_t dlla:1,
    185		__BITFIELD_FIELD(uint32_t scc:1,
    186		__BITFIELD_FIELD(uint32_t lt:1,
    187		__BITFIELD_FIELD(uint32_t reserved_26_26:1,
    188		__BITFIELD_FIELD(uint32_t nlw:6,
    189		__BITFIELD_FIELD(uint32_t ls:4,
    190		__BITFIELD_FIELD(uint32_t reserved_12_15:4,
    191		__BITFIELD_FIELD(uint32_t lab_int_enb:1,
    192		__BITFIELD_FIELD(uint32_t lbm_int_enb:1,
    193		__BITFIELD_FIELD(uint32_t hawd:1,
    194		__BITFIELD_FIELD(uint32_t ecpm:1,
    195		__BITFIELD_FIELD(uint32_t es:1,
    196		__BITFIELD_FIELD(uint32_t ccc:1,
    197		__BITFIELD_FIELD(uint32_t rl:1,
    198		__BITFIELD_FIELD(uint32_t ld:1,
    199		__BITFIELD_FIELD(uint32_t rcb:1,
    200		__BITFIELD_FIELD(uint32_t reserved_2_2:1,
    201		__BITFIELD_FIELD(uint32_t aslpc:2,
    202		;))))))))))))))))))))
    203	} s;
    204};
    205
    206union cvmx_pciercx_cfg034 {
    207	uint32_t u32;
    208	struct cvmx_pciercx_cfg034_s {
    209		__BITFIELD_FIELD(uint32_t reserved_25_31:7,
    210		__BITFIELD_FIELD(uint32_t dlls_c:1,
    211		__BITFIELD_FIELD(uint32_t emis:1,
    212		__BITFIELD_FIELD(uint32_t pds:1,
    213		__BITFIELD_FIELD(uint32_t mrlss:1,
    214		__BITFIELD_FIELD(uint32_t ccint_d:1,
    215		__BITFIELD_FIELD(uint32_t pd_c:1,
    216		__BITFIELD_FIELD(uint32_t mrls_c:1,
    217		__BITFIELD_FIELD(uint32_t pf_d:1,
    218		__BITFIELD_FIELD(uint32_t abp_d:1,
    219		__BITFIELD_FIELD(uint32_t reserved_13_15:3,
    220		__BITFIELD_FIELD(uint32_t dlls_en:1,
    221		__BITFIELD_FIELD(uint32_t emic:1,
    222		__BITFIELD_FIELD(uint32_t pcc:1,
    223		__BITFIELD_FIELD(uint32_t pic:1,
    224		__BITFIELD_FIELD(uint32_t aic:1,
    225		__BITFIELD_FIELD(uint32_t hpint_en:1,
    226		__BITFIELD_FIELD(uint32_t ccint_en:1,
    227		__BITFIELD_FIELD(uint32_t pd_en:1,
    228		__BITFIELD_FIELD(uint32_t mrls_en:1,
    229		__BITFIELD_FIELD(uint32_t pf_en:1,
    230		__BITFIELD_FIELD(uint32_t abp_en:1,
    231		;))))))))))))))))))))))
    232	} s;
    233};
    234
    235union cvmx_pciercx_cfg035 {
    236	uint32_t u32;
    237	struct cvmx_pciercx_cfg035_s {
    238		__BITFIELD_FIELD(uint32_t reserved_17_31:15,
    239		__BITFIELD_FIELD(uint32_t crssv:1,
    240		__BITFIELD_FIELD(uint32_t reserved_5_15:11,
    241		__BITFIELD_FIELD(uint32_t crssve:1,
    242		__BITFIELD_FIELD(uint32_t pmeie:1,
    243		__BITFIELD_FIELD(uint32_t sefee:1,
    244		__BITFIELD_FIELD(uint32_t senfee:1,
    245		__BITFIELD_FIELD(uint32_t secee:1,
    246		;))))))))
    247	} s;
    248};
    249
    250union cvmx_pciercx_cfg040 {
    251	uint32_t u32;
    252	struct cvmx_pciercx_cfg040_s {
    253		__BITFIELD_FIELD(uint32_t reserved_22_31:10,
    254		__BITFIELD_FIELD(uint32_t ler:1,
    255		__BITFIELD_FIELD(uint32_t ep3s:1,
    256		__BITFIELD_FIELD(uint32_t ep2s:1,
    257		__BITFIELD_FIELD(uint32_t ep1s:1,
    258		__BITFIELD_FIELD(uint32_t eqc:1,
    259		__BITFIELD_FIELD(uint32_t cdl:1,
    260		__BITFIELD_FIELD(uint32_t cde:4,
    261		__BITFIELD_FIELD(uint32_t csos:1,
    262		__BITFIELD_FIELD(uint32_t emc:1,
    263		__BITFIELD_FIELD(uint32_t tm:3,
    264		__BITFIELD_FIELD(uint32_t sde:1,
    265		__BITFIELD_FIELD(uint32_t hasd:1,
    266		__BITFIELD_FIELD(uint32_t ec:1,
    267		__BITFIELD_FIELD(uint32_t tls:4,
    268		;)))))))))))))))
    269	} s;
    270};
    271
    272union cvmx_pciercx_cfg070 {
    273	uint32_t u32;
    274	struct cvmx_pciercx_cfg070_s {
    275		__BITFIELD_FIELD(uint32_t reserved_12_31:20,
    276		__BITFIELD_FIELD(uint32_t tplp:1,
    277		__BITFIELD_FIELD(uint32_t reserved_9_10:2,
    278		__BITFIELD_FIELD(uint32_t ce:1,
    279		__BITFIELD_FIELD(uint32_t cc:1,
    280		__BITFIELD_FIELD(uint32_t ge:1,
    281		__BITFIELD_FIELD(uint32_t gc:1,
    282		__BITFIELD_FIELD(uint32_t fep:5,
    283		;))))))))
    284	} s;
    285};
    286
    287union cvmx_pciercx_cfg075 {
    288	uint32_t u32;
    289	struct cvmx_pciercx_cfg075_s {
    290		__BITFIELD_FIELD(uint32_t reserved_3_31:29,
    291		__BITFIELD_FIELD(uint32_t fere:1,
    292		__BITFIELD_FIELD(uint32_t nfere:1,
    293		__BITFIELD_FIELD(uint32_t cere:1,
    294		;))))
    295	} s;
    296};
    297
    298union cvmx_pciercx_cfg448 {
    299	uint32_t u32;
    300	struct cvmx_pciercx_cfg448_s {
    301		__BITFIELD_FIELD(uint32_t rtl:16,
    302		__BITFIELD_FIELD(uint32_t rtltl:16,
    303		;))
    304	} s;
    305};
    306
    307union cvmx_pciercx_cfg452 {
    308	uint32_t u32;
    309	struct cvmx_pciercx_cfg452_s {
    310		__BITFIELD_FIELD(uint32_t reserved_26_31:6,
    311		__BITFIELD_FIELD(uint32_t eccrc:1,
    312		__BITFIELD_FIELD(uint32_t reserved_22_24:3,
    313		__BITFIELD_FIELD(uint32_t lme:6,
    314		__BITFIELD_FIELD(uint32_t reserved_12_15:4,
    315		__BITFIELD_FIELD(uint32_t link_rate:4,
    316		__BITFIELD_FIELD(uint32_t flm:1,
    317		__BITFIELD_FIELD(uint32_t reserved_6_6:1,
    318		__BITFIELD_FIELD(uint32_t dllle:1,
    319		__BITFIELD_FIELD(uint32_t reserved_4_4:1,
    320		__BITFIELD_FIELD(uint32_t ra:1,
    321		__BITFIELD_FIELD(uint32_t le:1,
    322		__BITFIELD_FIELD(uint32_t sd:1,
    323		__BITFIELD_FIELD(uint32_t omr:1,
    324		;))))))))))))))
    325	} s;
    326};
    327
    328union cvmx_pciercx_cfg455 {
    329	uint32_t u32;
    330	struct cvmx_pciercx_cfg455_s {
    331		__BITFIELD_FIELD(uint32_t m_cfg0_filt:1,
    332		__BITFIELD_FIELD(uint32_t m_io_filt:1,
    333		__BITFIELD_FIELD(uint32_t msg_ctrl:1,
    334		__BITFIELD_FIELD(uint32_t m_cpl_ecrc_filt:1,
    335		__BITFIELD_FIELD(uint32_t m_ecrc_filt:1,
    336		__BITFIELD_FIELD(uint32_t m_cpl_len_err:1,
    337		__BITFIELD_FIELD(uint32_t m_cpl_attr_err:1,
    338		__BITFIELD_FIELD(uint32_t m_cpl_tc_err:1,
    339		__BITFIELD_FIELD(uint32_t m_cpl_fun_err:1,
    340		__BITFIELD_FIELD(uint32_t m_cpl_rid_err:1,
    341		__BITFIELD_FIELD(uint32_t m_cpl_tag_err:1,
    342		__BITFIELD_FIELD(uint32_t m_lk_filt:1,
    343		__BITFIELD_FIELD(uint32_t m_cfg1_filt:1,
    344		__BITFIELD_FIELD(uint32_t m_bar_match:1,
    345		__BITFIELD_FIELD(uint32_t m_pois_filt:1,
    346		__BITFIELD_FIELD(uint32_t m_fun:1,
    347		__BITFIELD_FIELD(uint32_t dfcwt:1,
    348		__BITFIELD_FIELD(uint32_t reserved_11_14:4,
    349		__BITFIELD_FIELD(uint32_t skpiv:11,
    350		;)))))))))))))))))))
    351	} s;
    352};
    353
    354union cvmx_pciercx_cfg515 {
    355	uint32_t u32;
    356	struct cvmx_pciercx_cfg515_s {
    357		__BITFIELD_FIELD(uint32_t reserved_21_31:11,
    358		__BITFIELD_FIELD(uint32_t s_d_e:1,
    359		__BITFIELD_FIELD(uint32_t ctcrb:1,
    360		__BITFIELD_FIELD(uint32_t cpyts:1,
    361		__BITFIELD_FIELD(uint32_t dsc:1,
    362		__BITFIELD_FIELD(uint32_t le:9,
    363		__BITFIELD_FIELD(uint32_t n_fts:8,
    364		;)))))))
    365	} s;
    366};
    367
    368#endif