RTEMS
6.1-rc4
Loading...
Searching...
No Matches
bsps
arm
tms570
include
bsp
ti_herc
reg_htu.h
Go to the documentation of this file.
1
/* SPDX-License-Identifier: BSD-2-Clause */
2
11
/* The header file is generated by make_header.py from HTU.json */
12
/* Current script's version can be found at: */
13
/* https://github.com/AoLaD/rtems-tms570-utils/tree/headers/headers/python */
14
15
/*
16
* Copyright (c) 2014-2015, Premysl Houdek <kom541000@gmail.com>
17
*
18
* Czech Technical University in Prague
19
* Zikova 1903/4
20
* 166 36 Praha 6
21
* Czech Republic
22
*
23
* All rights reserved.
24
*
25
* Redistribution and use in source and binary forms, with or without
26
* modification, are permitted provided that the following conditions are met:
27
*
28
* 1. Redistributions of source code must retain the above copyright notice, this
29
* list of conditions and the following disclaimer.
30
* 2. Redistributions in binary form must reproduce the above copyright notice,
31
* this list of conditions and the following disclaimer in the documentation
32
* and/or other materials provided with the distribution.
33
*
34
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
35
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
36
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
37
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
38
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
39
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
40
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
41
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
42
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
43
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
44
*
45
* The views and conclusions contained in the software and documentation are those
46
* of the authors and should not be interpreted as representing official policies,
47
* either expressed or implied, of the FreeBSD Project.
48
*/
49
#ifndef LIBBSP_ARM_TMS570_HTU
50
#define LIBBSP_ARM_TMS570_HTU
51
52
#include <
bsp/utility.h
>
53
54
typedef
struct
{
55
uint32_t GC;
/*Global Control Register*/
56
uint32_t CPENA;
/*Control Packet Enable Register*/
57
uint32_t BUSY0;
/*Control Packet Busy Register 0*/
58
uint32_t BUSY1;
/*Control Packet Busy Register 1*/
59
uint32_t BUSY2;
/*Control Packet Busy Register 2*/
60
uint32_t BUSY3;
/*Control Packet Busy Register 3*/
61
uint32_t ACPE;
/*Active Control Packet and Error Register*/
62
uint8_t reserved1 [4];
63
uint32_t RLBECTRL;
/*Request Lost and Bus Error Control Register*/
64
uint32_t BFINTS;
/*Buffer Full Interrupt Enable Set Register*/
65
uint32_t BFINTC;
/*Buffer Full Interrupt Enable Clear Register*/
66
uint8_t reserved2 [8];
67
uint32_t INTOFF0;
/*Interrupt Offset Register 0*/
68
uint32_t INTOFF1;
/*Interrupt Offset Register 1*/
69
uint32_t BIM;
/*Buffer Initialization Mode Register*/
70
uint32_t RLOSTFL;
/*Request Lost Flag Register*/
71
uint32_t BFINTFL;
/*Buffer Full Interrupt Flag Register*/
72
uint32_t BERINTFL;
/*BER Interrupt Flag Register*/
73
uint32_t MP1S;
/*Memory Protection 1 Start Address Register*/
74
uint32_t MP1E;
/*Memory Protection 1 End Address Register*/
75
uint32_t DCTRL;
/*Debug Control Register*/
76
uint32_t WPR;
/*Watch Point Register*/
77
uint32_t WMR;
/*Watch Mask Register*/
78
uint32_t ID;
/*Module Identification Register*/
79
uint32_t PCR;
/*Parity Control Register*/
80
uint32_t PAR;
/*Parity Address Register*/
81
uint8_t reserved3 [4];
82
uint32_t MPCS;
/*Memory Protection Control and Status Register*/
83
uint32_t MP0S;
/*Memory Protection 0 Start Address Register*/
84
uint32_t MP0E;
/*Memory Protection 0 End Address Register*/
85
}
tms570_htu_t
;
86
87
88
/*-----------------------TMS570_HTU_GC-----------------------*/
89
/* field: VBUSHOLD - Hold the VBUS bus */
90
#define TMS570_HTU_GC_VBUSHOLD BSP_BIT32(24)
91
92
/* field: HTUEN - Transfer Unit Enable Bit */
93
#define TMS570_HTU_GC_HTUEN BSP_BIT32(16)
94
95
/* field: DEBM - Debug Mode */
96
#define TMS570_HTU_GC_DEBM BSP_BIT32(8)
97
98
/* field: HTURES - HTU Software Reset Request */
99
#define TMS570_HTU_GC_HTURES BSP_BIT32(0)
100
101
102
/*----------------------TMS570_HTU_CPENA----------------------*/
103
/* field: CPENA - CP Enable Bits */
104
#define TMS570_HTU_CPENA_CPENA(val) BSP_FLD32(val,0, 15)
105
#define TMS570_HTU_CPENA_CPENA_GET(reg) BSP_FLD32GET(reg,0, 15)
106
#define TMS570_HTU_CPENA_CPENA_SET(reg,val) BSP_FLD32SET(reg, val,0, 15)
107
108
109
/*----------------------TMS570_HTU_BUSY0----------------------*/
110
/* field: BUSY0A - Busy Flag for CP A of DCP 0 */
111
#define TMS570_HTU_BUSY0_BUSY0A BSP_BIT32(24)
112
113
/* field: BUSY0B - Busy Flag for CP B of DCP 0 */
114
#define TMS570_HTU_BUSY0_BUSY0B BSP_BIT32(16)
115
116
/* field: BUSY1A - Busy Flag for CP A of DCP 1 */
117
#define TMS570_HTU_BUSY0_BUSY1A BSP_BIT32(8)
118
119
/* field: BUSY1B - Busy Flag for CP B of DCP 1 */
120
#define TMS570_HTU_BUSY0_BUSY1B BSP_BIT32(0)
121
122
123
/*----------------------TMS570_HTU_BUSY1----------------------*/
124
/* field: BUSY2A - Busy Flag for CP A of DCP 2 */
125
#define TMS570_HTU_BUSY1_BUSY2A BSP_BIT32(24)
126
127
/* field: BUSY2B - Busy Flag for CP B of DCP 2 */
128
#define TMS570_HTU_BUSY1_BUSY2B BSP_BIT32(16)
129
130
/* field: BUSY3A - Busy Flag for CP A of DCP 3 */
131
#define TMS570_HTU_BUSY1_BUSY3A BSP_BIT32(8)
132
133
/* field: BUSY3B - Busy Flag for CP B of DCP 3 */
134
#define TMS570_HTU_BUSY1_BUSY3B BSP_BIT32(0)
135
136
137
/*----------------------TMS570_HTU_BUSY2----------------------*/
138
/* field: BUSY4A - Busy Flag for CP A of DCP 4 */
139
#define TMS570_HTU_BUSY2_BUSY4A BSP_BIT32(24)
140
141
/* field: BUSY4B - Busy Flag for CP B of DCP 4 */
142
#define TMS570_HTU_BUSY2_BUSY4B BSP_BIT32(16)
143
144
/* field: BUSY5A - Busy Flag for CP A of DCP 5 */
145
#define TMS570_HTU_BUSY2_BUSY5A BSP_BIT32(8)
146
147
/* field: BUSY5B - Busy Flag for CP B of DCP 5 */
148
#define TMS570_HTU_BUSY2_BUSY5B BSP_BIT32(0)
149
150
151
/*----------------------TMS570_HTU_BUSY3----------------------*/
152
/* field: BUSY6A - Busy Flag for CP A of DCP 6 */
153
#define TMS570_HTU_BUSY3_BUSY6A BSP_BIT32(24)
154
155
/* field: BUSY6B - Busy Flag for CP B of DCP 6 */
156
#define TMS570_HTU_BUSY3_BUSY6B BSP_BIT32(16)
157
158
/* field: BUSY7A - Busy Flag for CP A of DCP 7 */
159
#define TMS570_HTU_BUSY3_BUSY7A BSP_BIT32(8)
160
161
/* field: BUSY7B - Busy Flag for CP B of DCP 7 */
162
#define TMS570_HTU_BUSY3_BUSY7B BSP_BIT32(0)
163
164
165
/*----------------------TMS570_HTU_ACPE----------------------*/
166
/* field: ERRF - Error Flag */
167
#define TMS570_HTU_ACPE_ERRF BSP_BIT32(31)
168
169
170
/*--------------------TMS570_HTU_RLBECTRL--------------------*/
171
/* field: BERINTENA - Bus Error Interrupt Enable Bit */
172
#define TMS570_HTU_RLBECTRL_BERINTENA BSP_BIT32(16)
173
174
/* field: CORL - Continue On Request Lost Error */
175
#define TMS570_HTU_RLBECTRL_CORL BSP_BIT32(8)
176
177
/* field: RLINTENA - Request Lost Interrupt Enable Bit */
178
#define TMS570_HTU_RLBECTRL_RLINTENA BSP_BIT32(0)
179
180
181
/*---------------------TMS570_HTU_BFINTS---------------------*/
182
/* field: BFINTENA - Bus Full Interrupt Enable Bits. */
183
#define TMS570_HTU_BFINTS_BFINTENA(val) BSP_FLD32(val,0, 15)
184
#define TMS570_HTU_BFINTS_BFINTENA_GET(reg) BSP_FLD32GET(reg,0, 15)
185
#define TMS570_HTU_BFINTS_BFINTENA_SET(reg,val) BSP_FLD32SET(reg, val,0, 15)
186
187
188
/*---------------------TMS570_HTU_BFINTC---------------------*/
189
/* field: BFINTDIS - */
190
#define TMS570_HTU_BFINTC_BFINTDIS(val) BSP_FLD32(val,0, 15)
191
#define TMS570_HTU_BFINTC_BFINTDIS_GET(reg) BSP_FLD32GET(reg,0, 15)
192
#define TMS570_HTU_BFINTC_BFINTDIS_SET(reg,val) BSP_FLD32SET(reg, val,0, 15)
193
194
195
/*---------------------TMS570_HTU_INTOFF0---------------------*/
196
/* field: INTTYPE0 - Interrupt Type of Interrupt Line 0. */
197
#define TMS570_HTU_INTOFF0_INTTYPE0(val) BSP_FLD32(val,8, 10)
198
#define TMS570_HTU_INTOFF0_INTTYPE0_GET(reg) BSP_FLD32GET(reg,8, 10)
199
#define TMS570_HTU_INTOFF0_INTTYPE0_SET(reg,val) BSP_FLD32SET(reg, val,8, 10)
200
201
/* field: CPOFF0 - CP Offset. */
202
#define TMS570_HTU_INTOFF0_CPOFF0(val) BSP_FLD32(val,0, 4)
203
#define TMS570_HTU_INTOFF0_CPOFF0_GET(reg) BSP_FLD32GET(reg,0, 4)
204
#define TMS570_HTU_INTOFF0_CPOFF0_SET(reg,val) BSP_FLD32SET(reg, val,0, 4)
205
206
207
/*---------------------TMS570_HTU_INTOFF1---------------------*/
208
/* field: INTTYPE1 - INTTYPE1 Interrupt Type of Interrupt Line 1. */
209
#define TMS570_HTU_INTOFF1_INTTYPE1(val) BSP_FLD32(val,8, 10)
210
#define TMS570_HTU_INTOFF1_INTTYPE1_GET(reg) BSP_FLD32GET(reg,8, 10)
211
#define TMS570_HTU_INTOFF1_INTTYPE1_SET(reg,val) BSP_FLD32SET(reg, val,8, 10)
212
213
/* field: CPOFF1 - CP Offset. */
214
#define TMS570_HTU_INTOFF1_CPOFF1(val) BSP_FLD32(val,0, 4)
215
#define TMS570_HTU_INTOFF1_CPOFF1_GET(reg) BSP_FLD32GET(reg,0, 4)
216
#define TMS570_HTU_INTOFF1_CPOFF1_SET(reg,val) BSP_FLD32SET(reg, val,0, 4)
217
218
219
/*-----------------------TMS570_HTU_BIM-----------------------*/
220
/* field: BIM - Buffer Initialization Mode */
221
#define TMS570_HTU_BIM_BIM(val) BSP_FLD32(val,0, 7)
222
#define TMS570_HTU_BIM_BIM_GET(reg) BSP_FLD32GET(reg,0, 7)
223
#define TMS570_HTU_BIM_BIM_SET(reg,val) BSP_FLD32SET(reg, val,0, 7)
224
225
226
/*---------------------TMS570_HTU_RLOSTFL---------------------*/
227
/* field: CPRLFL - CP Request Lost Flags */
228
#define TMS570_HTU_RLOSTFL_CPRLFL(val) BSP_FLD32(val,0, 15)
229
#define TMS570_HTU_RLOSTFL_CPRLFL_GET(reg) BSP_FLD32GET(reg,0, 15)
230
#define TMS570_HTU_RLOSTFL_CPRLFL_SET(reg,val) BSP_FLD32SET(reg, val,0, 15)
231
232
233
/*---------------------TMS570_HTU_BFINTFL---------------------*/
234
/* field: BFINTFL - Buffer Full Interrupt Flags */
235
#define TMS570_HTU_BFINTFL_BFINTFL(val) BSP_FLD32(val,0, 15)
236
#define TMS570_HTU_BFINTFL_BFINTFL_GET(reg) BSP_FLD32GET(reg,0, 15)
237
#define TMS570_HTU_BFINTFL_BFINTFL_SET(reg,val) BSP_FLD32SET(reg, val,0, 15)
238
239
240
/*--------------------TMS570_HTU_BERINTFL--------------------*/
241
/* field: BERINTFL - Bus Error Interrupt Flags */
242
#define TMS570_HTU_BERINTFL_BERINTFL(val) BSP_FLD32(val,0, 15)
243
#define TMS570_HTU_BERINTFL_BERINTFL_GET(reg) BSP_FLD32GET(reg,0, 15)
244
#define TMS570_HTU_BERINTFL_BERINTFL_SET(reg,val) BSP_FLD32SET(reg, val,0, 15)
245
246
247
/*----------------------TMS570_HTU_MP1S----------------------*/
248
/* field: STARTADDRESS1 - he start address defines at which main memory address the region begins. */
249
/* Whole 32 bits */
250
251
/*----------------------TMS570_HTU_MP1E----------------------*/
252
/* field: ENDADDRESS1 - The end address defines at which address the region ends. */
253
/* Whole 32 bits */
254
255
/*----------------------TMS570_HTU_DCTRL----------------------*/
256
/* field: CPNUM - CP Number. These bit fields indicate the CP which should cause the watch point to match. */
257
#define TMS570_HTU_DCTRL_CPNUM(val) BSP_FLD32(val,24, 27)
258
#define TMS570_HTU_DCTRL_CPNUM_GET(reg) BSP_FLD32GET(reg,24, 27)
259
#define TMS570_HTU_DCTRL_CPNUM_SET(reg,val) BSP_FLD32SET(reg, val,24, 27)
260
261
/* field: HTUDBGS - HTU Debug Status. */
262
#define TMS570_HTU_DCTRL_HTUDBGS BSP_BIT32(16)
263
264
/* field: DBREN - Debug Request Enable */
265
#define TMS570_HTU_DCTRL_DBREN BSP_BIT32(0)
266
267
268
/*-----------------------TMS570_HTU_WPR-----------------------*/
269
/* field: WP - Watch Point Register */
270
/* Whole 32 bits */
271
272
/*-----------------------TMS570_HTU_WMR-----------------------*/
273
/* field: WM - Watch Mask Register */
274
/* Whole 32 bits */
275
276
/*-----------------------TMS570_HTU_ID-----------------------*/
277
/* field: CLASS - Module Class */
278
#define TMS570_HTU_ID_CLASS(val) BSP_FLD32(val,16, 23)
279
#define TMS570_HTU_ID_CLASS_GET(reg) BSP_FLD32GET(reg,16, 23)
280
#define TMS570_HTU_ID_CLASS_SET(reg,val) BSP_FLD32SET(reg, val,16, 23)
281
282
/* field: TYPE - Subtype within a Class */
283
#define TMS570_HTU_ID_TYPE(val) BSP_FLD32(val,8, 15)
284
#define TMS570_HTU_ID_TYPE_GET(reg) BSP_FLD32GET(reg,8, 15)
285
#define TMS570_HTU_ID_TYPE_SET(reg,val) BSP_FLD32SET(reg, val,8, 15)
286
287
/* field: REV - Module Revision Number */
288
#define TMS570_HTU_ID_REV(val) BSP_FLD32(val,0, 7)
289
#define TMS570_HTU_ID_REV_GET(reg) BSP_FLD32GET(reg,0, 7)
290
#define TMS570_HTU_ID_REV_SET(reg,val) BSP_FLD32SET(reg, val,0, 7)
291
292
293
/*-----------------------TMS570_HTU_PCR-----------------------*/
294
/* field: COPE - Continue on Parity Error */
295
#define TMS570_HTU_PCR_COPE BSP_BIT32(16)
296
297
/* field: TEST - Test. */
298
#define TMS570_HTU_PCR_TEST BSP_BIT32(8)
299
300
/* field: PARITY_ENA - Enable/Disable Parity Checking. */
301
#define TMS570_HTU_PCR_PARITY_ENA(val) BSP_FLD32(val,0, 3)
302
#define TMS570_HTU_PCR_PARITY_ENA_GET(reg) BSP_FLD32GET(reg,0, 3)
303
#define TMS570_HTU_PCR_PARITY_ENA_SET(reg,val) BSP_FLD32SET(reg, val,0, 3)
304
305
306
/*-----------------------TMS570_HTU_PAR-----------------------*/
307
/* field: PEFT - Parity Error Fault Flag. */
308
#define TMS570_HTU_PAR_PEFT BSP_BIT32(16)
309
310
/* field: PAOFF - PAOFF */
311
#define TMS570_HTU_PAR_PAOFF(val) BSP_FLD32(val,0, 8)
312
#define TMS570_HTU_PAR_PAOFF_GET(reg) BSP_FLD32GET(reg,0, 8)
313
#define TMS570_HTU_PAR_PAOFF_SET(reg,val) BSP_FLD32SET(reg, val,0, 8)
314
315
316
/*----------------------TMS570_HTU_MPCS----------------------*/
317
/* field: CPNUM0 - Control Packet Number for single memory protection region configuration. */
318
#define TMS570_HTU_MPCS_CPNUM0(val) BSP_FLD32(val,24, 27)
319
#define TMS570_HTU_MPCS_CPNUM0_GET(reg) BSP_FLD32GET(reg,24, 27)
320
#define TMS570_HTU_MPCS_CPNUM0_SET(reg,val) BSP_FLD32SET(reg, val,24, 27)
321
322
/* field: MPEFT1 - MPEFT1 */
323
#define TMS570_HTU_MPCS_MPEFT1 BSP_BIT32(17)
324
325
/* field: MPEFT0 - Memory Protection Error Fault Flag 0. */
326
#define TMS570_HTU_MPCS_MPEFT0 BSP_BIT32(16)
327
328
/* field: CPNUM1 - Control Packet Number for single memory protection region configuration. */
329
#define TMS570_HTU_MPCS_CPNUM1(val) BSP_FLD32(val,8, 11)
330
#define TMS570_HTU_MPCS_CPNUM1_GET(reg) BSP_FLD32GET(reg,8, 11)
331
#define TMS570_HTU_MPCS_CPNUM1_SET(reg,val) BSP_FLD32SET(reg, val,8, 11)
332
333
334
/*----------------------TMS570_HTU_MP0S----------------------*/
335
/* field: ISTARTADDRESS0 - The start address defines at which main memory address the region begins. */
336
/* Whole 32 bits */
337
338
/*----------------------TMS570_HTU_MP0E----------------------*/
339
/* field: ENDADDRESS0 - The end address defines at which address the region ends. */
340
/* Whole 32 bits */
341
342
343
#endif
/* LIBBSP_ARM_TMS570_HTU */
utility.h
This header file provides utility macros for BSPs.
tms570_htu_t
Definition:
reg_htu.h:54
Generated by
1.9.6