Zephyr Project API 4.0.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
nios2.h
Go to the documentation of this file.
1#ifndef ZEPHYR_INCLUDE_ARCH_NIOS2_NIOS2_H_
2#define ZEPHYR_INCLUDE_ARCH_NIOS2_NIOS2_H_
3
4/* SPDX-License-Identifier: Xnet */
5
6/******************************************************************************
7* *
8* License Agreement *
9* *
10* Copyright (c) 2008 Altera Corporation, San Jose, California, USA. *
11* All rights reserved. *
12* *
13* Permission is hereby granted, free of charge, to any person obtaining a *
14* copy of this software and associated documentation files (the "Software"), *
15* to deal in the Software without restriction, including without limitation *
16* the rights to use, copy, modify, merge, publish, distribute, sublicense, *
17* and/or sell copies of the Software, and to permit persons to whom the *
18* Software is furnished to do so, subject to the following conditions: *
19* *
20* The above copyright notice and this permission notice shall be included in *
21* all copies or substantial portions of the Software. *
22* *
23* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR *
24* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, *
25* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE *
26* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER *
27* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING *
28* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER *
29* DEALINGS IN THE SOFTWARE. *
30* *
31* This agreement shall be governed in all respects by the laws of the State *
32* of California and by the laws of the United States of America. *
33* *
34******************************************************************************/
35
36/*
37 * This header provides processor specific macros for accessing the Nios2
38 * control registers.
39 */
40
41#ifdef __cplusplus
42extern "C"
43{
44#endif /* __cplusplus */
45
46/*
47 * Number of available IRQs in internal interrupt controller.
48 */
49#define NIOS2_NIRQ 32
50
51/* Size in bits of registers */
52#define SYSTEM_BUS_WIDTH 32
53
54#ifndef _ASMLANGUAGE
55
56#include <zephyr/types.h>
57#include <zephyr/arch/cpu.h>
58#include <zephyr/sys/sys_io.h>
59
60/*
61 * Functions for accessing select Nios II general-purpose registers.
62 */
63
64/* ET (Exception Temporary) register */
65static inline uint32_t _nios2_read_et(void)
66{
67 uint32_t et;
68
69 __asm__("mov %0, et" : "=r" (et));
70 return et;
71}
72
73static inline void _nios2_write_et(uint32_t et)
74{
75 __asm__ volatile("mov et, %z0" : : "rM" (et));
76}
77
78static inline uint32_t _nios2_read_sp(void)
79{
80 uint32_t sp;
81
82 __asm__("mov %0, sp" : "=r" (sp));
83 return sp;
84}
85
86/*
87 * Functions for useful processor instructions.
88 */
89static inline void z_nios2_break(void)
90{
91 __asm__ volatile("break");
92}
93
94static inline void _nios2_report_stack_overflow(void)
95{
96 __asm__ volatile("break 3");
97}
98
99/*
100 * Low-level cache management functions
101 */
102static inline void _nios2_dcache_addr_flush(void *addr)
103{
104 __asm__ volatile ("flushda (%0)" :: "r" (addr));
105}
106
107static inline void z_nios2_dcache_flush(uint32_t offset)
108{
109 __asm__ volatile ("flushd (%0)" :: "r" (offset));
110}
111
112static inline void z_nios2_icache_flush(uint32_t offset)
113{
114 __asm__ volatile ("flushi %0" :: "r" (offset));
115}
116
117static inline void z_nios2_pipeline_flush(void)
118{
119 __asm__ volatile ("flushp");
120}
121
122/*
123 * Functions for reading/writing control registers
124 */
125
144
145/* XXX I would prefer to define these as static inline functions for
146 * type checking purposes. However if -O0 is used (i.e. CONFIG_DEBUG is on)
147 * we get errors "Control register number must be in range 0-31 for
148 * __builtin_rdctl" with the following code:
149 *
150 * static inline uint32_t z_nios2_creg_read(enum nios2_creg reg)
151 * {
152 * return __builtin_rdctl(reg);
153 * }
154 *
155 * This compiles just fine with -Os.
156 */
157#define z_nios2_creg_read(reg) __builtin_rdctl(reg)
158#define z_nios2_creg_write(reg, val) __builtin_wrctl(reg, val)
159
160#define z_nios2_get_register_address(base, regnum) \
161 ((void *)(((uint8_t *)base) + ((regnum) * (SYSTEM_BUS_WIDTH / 8))))
162
163static inline void _nios2_reg_write(void *base, int regnum, uint32_t data)
164{
165 sys_write32(data,
166 (mm_reg_t)z_nios2_get_register_address(base, regnum));
167}
168
169static inline uint32_t _nios2_reg_read(void *base, int regnum)
170{
171 return sys_read32((mm_reg_t)z_nios2_get_register_address(base, regnum));
172}
173
174#endif /* _ASMLANGUAGE */
175
176/*
177 * Nios II control registers that are always present
178 */
179#define NIOS2_STATUS status
180#define NIOS2_ESTATUS estatus
181#define NIOS2_BSTATUS bstatus
182#define NIOS2_IENABLE ienable
183#define NIOS2_IPENDING ipending
184#define NIOS2_CPUID cpuid
185
186/*
187 * Bit masks & offsets for Nios II control registers.
188 * The presence and size of a field is sometimes dependent on the Nios II
189 * configuration. Bit masks for every possible field and the maximum size of
190 * that field are defined.
191 *
192 * All bit-masks are expressed relative to the position
193 * of the data with a register. To read data that is LSB-
194 * aligned, the register read data should be masked, then
195 * right-shifted by the designated "OFST" macro value. The
196 * opposite should be used for register writes when starting
197 * with LSB-aligned data.
198 */
199
200/* STATUS, ESTATUS, BSTATUS, and SSTATUS registers */
201#define NIOS2_STATUS_PIE_MSK (0x00000001)
202#define NIOS2_STATUS_PIE_OFST (0)
203#define NIOS2_STATUS_U_MSK (0x00000002)
204#define NIOS2_STATUS_U_OFST (1)
205#define NIOS2_STATUS_EH_MSK (0x00000004)
206#define NIOS2_STATUS_EH_OFST (2)
207#define NIOS2_STATUS_IH_MSK (0x00000008)
208#define NIOS2_STATUS_IH_OFST (3)
209#define NIOS2_STATUS_IL_MSK (0x000003f0)
210#define NIOS2_STATUS_IL_OFST (4)
211#define NIOS2_STATUS_CRS_MSK (0x0000fc00)
212#define NIOS2_STATUS_CRS_OFST (10)
213#define NIOS2_STATUS_PRS_MSK (0x003f0000)
214#define NIOS2_STATUS_PRS_OFST (16)
215#define NIOS2_STATUS_NMI_MSK (0x00400000)
216#define NIOS2_STATUS_NMI_OFST (22)
217#define NIOS2_STATUS_RSIE_MSK (0x00800000)
218#define NIOS2_STATUS_RSIE_OFST (23)
219#define NIOS2_STATUS_SRS_MSK (0x80000000)
220#define NIOS2_STATUS_SRS_OFST (31)
221
222/* EXCEPTION register */
223#define NIOS2_EXCEPTION_REG_CAUSE_MASK (0x0000007c)
224#define NIOS2_EXCEPTION_REG_CAUSE_OFST (2)
225#define NIOS2_EXCEPTION_REG_ECCFTL_MASK (0x80000000)
226#define NIOS2_EXCEPTION_REG_ECCFTL_OFST (31)
227
228/* PTEADDR (Page Table Entry Address) register */
229#define NIOS2_PTEADDR_REG_VPN_OFST 2
230#define NIOS2_PTEADDR_REG_VPN_MASK 0x3ffffc
231#define NIOS2_PTEADDR_REG_PTBASE_OFST 22
232#define NIOS2_PTEADDR_REG_PTBASE_MASK 0xffc00000
233
234/* TLBACC (TLB Access) register */
235#define NIOS2_TLBACC_REG_PFN_OFST 0
236#define NIOS2_TLBACC_REG_PFN_MASK 0xfffff
237#define NIOS2_TLBACC_REG_G_OFST 20
238#define NIOS2_TLBACC_REG_G_MASK 0x100000
239#define NIOS2_TLBACC_REG_X_OFST 21
240#define NIOS2_TLBACC_REG_X_MASK 0x200000
241#define NIOS2_TLBACC_REG_W_OFST 22
242#define NIOS2_TLBACC_REG_W_MASK 0x400000
243#define NIOS2_TLBACC_REG_R_OFST 23
244#define NIOS2_TLBACC_REG_R_MASK 0x800000
245#define NIOS2_TLBACC_REG_C_OFST 24
246#define NIOS2_TLBACC_REG_C_MASK 0x1000000
247#define NIOS2_TLBACC_REG_IG_OFST 25
248#define NIOS2_TLBACC_REG_IG_MASK 0xfe000000
249
250/* TLBMISC (TLB Miscellaneous) register */
251#define NIOS2_TLBMISC_REG_D_OFST 0
252#define NIOS2_TLBMISC_REG_D_MASK 0x1
253#define NIOS2_TLBMISC_REG_PERM_OFST 1
254#define NIOS2_TLBMISC_REG_PERM_MASK 0x2
255#define NIOS2_TLBMISC_REG_BAD_OFST 2
256#define NIOS2_TLBMISC_REG_BAD_MASK 0x4
257#define NIOS2_TLBMISC_REG_DBL_OFST 3
258#define NIOS2_TLBMISC_REG_DBL_MASK 0x8
259#define NIOS2_TLBMISC_REG_PID_OFST 4
260#define NIOS2_TLBMISC_REG_PID_MASK 0x3fff0
261#define NIOS2_TLBMISC_REG_WE_OFST 18
262#define NIOS2_TLBMISC_REG_WE_MASK 0x40000
263#define NIOS2_TLBMISC_REG_RD_OFST 19
264#define NIOS2_TLBMISC_REG_RD_MASK 0x80000
265#define NIOS2_TLBMISC_REG_WAY_OFST 20
266#define NIOS2_TLBMISC_REG_WAY_MASK 0xf00000
267#define NIOS2_TLBMISC_REG_EE_OFST 24
268#define NIOS2_TLBMISC_REG_EE_MASK 0x1000000
269
270/* ECCINJ (ECC Inject) register */
271#define NIOS2_ECCINJ_REG_RF_OFST 0
272#define NIOS2_ECCINJ_REG_RF_MASK 0x3
273#define NIOS2_ECCINJ_REG_ICTAG_OFST 2
274#define NIOS2_ECCINJ_REG_ICTAG_MASK 0xc
275#define NIOS2_ECCINJ_REG_ICDAT_OFST 4
276#define NIOS2_ECCINJ_REG_ICDAT_MASK 0x30
277#define NIOS2_ECCINJ_REG_DCTAG_OFST 6
278#define NIOS2_ECCINJ_REG_DCTAG_MASK 0xc0
279#define NIOS2_ECCINJ_REG_DCDAT_OFST 8
280#define NIOS2_ECCINJ_REG_DCDAT_MASK 0x300
281#define NIOS2_ECCINJ_REG_TLB_OFST 10
282#define NIOS2_ECCINJ_REG_TLB_MASK 0xc00
283#define NIOS2_ECCINJ_REG_DTCM0_OFST 12
284#define NIOS2_ECCINJ_REG_DTCM0_MASK 0x3000
285#define NIOS2_ECCINJ_REG_DTCM1_OFST 14
286#define NIOS2_ECCINJ_REG_DTCM1_MASK 0xc000
287#define NIOS2_ECCINJ_REG_DTCM2_OFST 16
288#define NIOS2_ECCINJ_REG_DTCM2_MASK 0x30000
289#define NIOS2_ECCINJ_REG_DTCM3_OFST 18
290#define NIOS2_ECCINJ_REG_DTCM3_MASK 0xc0000
291
292/* CONFIG register */
293#define NIOS2_CONFIG_REG_PE_MASK (0x00000001)
294#define NIOS2_CONFIG_REG_PE_OFST (0)
295#define NIOS2_CONFIG_REG_ANI_MASK (0x00000002)
296#define NIOS2_CONFIG_REG_ANI_OFST (1)
297#define NIOS2_CONFIG_REG_ECCEN_MASK (0x00000004)
298#define NIOS2_CONFIG_REG_ECCEN_OFST (2)
299#define NIOS2_CONFIG_REG_ECCEXC_MASK (0x00000008)
300#define NIOS2_CONFIG_REG_ECCEXC_OFST (3)
301
302/* MPUBASE (MPU Base Address) Register */
303#define NIOS2_MPUBASE_D_MASK (0x00000001)
304#define NIOS2_MPUBASE_D_OFST (0)
305#define NIOS2_MPUBASE_INDEX_MASK (0x0000003e)
306#define NIOS2_MPUBASE_INDEX_OFST (1)
307#define NIOS2_MPUBASE_BASE_ADDR_MASK (0xffffffc0)
308#define NIOS2_MPUBASE_BASE_ADDR_OFST (6)
309
310/* MPUACC (MPU Access) Register */
311#define NIOS2_MPUACC_LIMIT_MASK (0xffffffc0)
312#define NIOS2_MPUACC_LIMIT_OFST (6)
313#define NIOS2_MPUACC_MASK_MASK (0xffffffc0)
314#define NIOS2_MPUACC_MASK_OFST (6)
315#define NIOS2_MPUACC_C_MASK (0x00000020)
316#define NIOS2_MPUACC_C_OFST (5)
317#define NIOS2_MPUACC_PERM_MASK (0x0000001c)
318#define NIOS2_MPUACC_PERM_OFST (2)
319#define NIOS2_MPUACC_RD_MASK (0x00000002)
320#define NIOS2_MPUACC_RD_OFST (1)
321#define NIOS2_MPUACC_WR_MASK (0x00000001)
322#define NIOS2_MPUACC_WR_OFST (0)
323
324#ifdef __cplusplus
325}
326#endif /* __cplusplus */
327
328#endif /* ZEPHYR_INCLUDE_ARCH_NIOS2_NIOS2_H_ */
nios2_creg
Definition nios2.h:126
@ NIOS2_CR_ESTATUS
Definition nios2.h:128
@ NIOS2_CR_MPUACC
Definition nios2.h:142
@ NIOS2_CR_TLBACC
Definition nios2.h:136
@ NIOS2_CR_IPENDING
Definition nios2.h:131
@ NIOS2_CR_BSTATUS
Definition nios2.h:129
@ NIOS2_CR_BADADDR
Definition nios2.h:139
@ NIOS2_CR_TLBMISC
Definition nios2.h:137
@ NIOS2_CR_CONFIG
Definition nios2.h:140
@ NIOS2_CR_STATUS
Definition nios2.h:127
@ NIOS2_CR_MPUBASE
Definition nios2.h:141
@ NIOS2_CR_EXCEPTION
Definition nios2.h:134
@ NIOS2_CR_ECCINJ
Definition nios2.h:138
@ NIOS2_CR_CPUID
Definition nios2.h:132
@ NIOS2_CR_PTEADDR
Definition nios2.h:135
@ NIOS2_CR_IENABLE
Definition nios2.h:130
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
static ALWAYS_INLINE void sys_write32(uint32_t data, mem_addr_t addr)
Definition sys-io-common.h:70
static ALWAYS_INLINE uint32_t sys_read32(mem_addr_t addr)
Definition sys-io-common.h:59
uintptr_t mm_reg_t
Definition sys_io.h:20