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