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
369