API Reference
The NEORV32 RISC-V Processor
Loading...
Searching...
No Matches
neorv32_sysinfo.h
Go to the documentation of this file.
1// ================================================================================ //
2// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //
3// Copyright (c) NEORV32 contributors. //
4// Copyright (c) 2020 - 2026 Stephan Nolting. All rights reserved. //
5// Licensed under the BSD-3-Clause license, see LICENSE for details. //
6// SPDX-License-Identifier: BSD-3-Clause //
7// ================================================================================ //
8
14#ifndef NEORV32_SYSINFO_H
15#define NEORV32_SYSINFO_H
16
17#include <neorv32.h>
18#include <stdint.h>
19
20/**********************************************************************/
25typedef volatile struct __attribute__((packed,aligned(4))) {
26 uint32_t CLK;
27 const uint32_t MISC;
28 const uint32_t SOC;
29 const uint32_t CACHE;
31
33#define NEORV32_SYSINFO ((neorv32_sysinfo_t*) (NEORV32_SYSINFO_BASE))
34
55
65//SYSINFO_SOC_reserved = 7, /**< SYSINFO_SOC (7) (r/-): reserved */
66//SYSINFO_SOC_reserved = 8, /**< SYSINFO_SOC (8) (r/-): reserved */
67//SYSINFO_SOC_reserved = 9, /**< SYSINFO_SOC (9) (r/-): reserved */
68//SYSINFO_SOC_reserved = 10, /**< SYSINFO_SOC (10) (r/-): reserved */
89 SYSINFO_SOC_SIM = 31
90};
91
111/**********************************************************************/
115inline uint32_t __attribute__ ((always_inline)) neorv32_sysinfo_is_sim(void) {
116 return (uint32_t)(NEORV32_SYSINFO->SOC >> SYSINFO_SOC_SIM);
117}
118
119/**********************************************************************/
123inline uint32_t __attribute__ ((always_inline)) neorv32_sysinfo_get_numcores(void) {
124 return (uint32_t)((NEORV32_SYSINFO->MISC >> SYSINFO_MISC_HART_LSB) & 0x0fu);
125}
126
127/**********************************************************************/
131inline uint32_t __attribute__ ((always_inline)) neorv32_sysinfo_get_imemsize(void) {
132 uint32_t tmp = (NEORV32_SYSINFO->MISC >> SYSINFO_MISC_IMEM_LSB) & 0xffu;
133 if (tmp) {
134 return (uint32_t)(1u << tmp);
135 }
136 return 0;
137}
138
139/**********************************************************************/
143inline uint32_t __attribute__ ((always_inline)) neorv32_sysinfo_get_dmemsize(void) {
144 uint32_t tmp = (NEORV32_SYSINFO->MISC >> SYSINFO_MISC_DMEM_LSB) & 0xffu;
145 if (tmp) {
146 return (uint32_t)(1u << tmp);
147 }
148 return 0;
149}
150
151/**********************************************************************/
155inline uint32_t __attribute__ ((always_inline)) neorv32_sysinfo_get_bootmode(void) {
156 return (uint32_t)((NEORV32_SYSINFO->MISC >> SYSINFO_MISC_BOOT_LSB) & 0x03u);
157}
158
159/**********************************************************************/
163inline uint32_t __attribute__ ((always_inline)) neorv32_sysinfo_get_intbustimeout(void) {
164 uint32_t tmp = (NEORV32_SYSINFO->MISC >> SYSINFO_MISC_ITMO_LSB) & 0x1fu;
165 if (tmp) {
166 return (uint32_t)(1u << tmp);
167 }
168 return 0;
169}
170
171/**********************************************************************/
175inline uint32_t __attribute__ ((always_inline)) neorv32_sysinfo_get_extbustimeout(void) {
176 uint32_t tmp = (NEORV32_SYSINFO->MISC >> SYSINFO_MISC_ETMO_LSB) & 0x1fu;
177 if (tmp) {
178 return (uint32_t)(1u << tmp);
179 }
180 return 0;
181}
182
183/**********************************************************************/
187inline uint32_t __attribute__ ((always_inline)) neorv32_sysinfo_get_clk(void) {
188 return NEORV32_SYSINFO->CLK;
189}
190
191/**********************************************************************/
195inline void __attribute__ ((always_inline)) neorv32_sysinfo_set_clk(uint32_t clock) {
196 NEORV32_SYSINFO->CLK = clock;
197}
198
199#endif // NEORV32_SYSINFO_H
Main NEORV32 core library / driver / HAL include file.
uint32_t neorv32_sysinfo_get_clk(void)
Definition neorv32_sysinfo.h:187
uint32_t neorv32_sysinfo_get_dmemsize(void)
Definition neorv32_sysinfo.h:143
#define NEORV32_SYSINFO
Definition neorv32_sysinfo.h:33
uint32_t neorv32_sysinfo_get_bootmode(void)
Definition neorv32_sysinfo.h:155
uint32_t neorv32_sysinfo_get_intbustimeout(void)
Definition neorv32_sysinfo.h:163
NEORV32_SYSINFO_CACHE_enum
Definition neorv32_sysinfo.h:93
@ SYSINFO_CACHE_BLOCK_SIZE_3
Definition neorv32_sysinfo.h:95
@ SYSINFO_CACHE_I_NUM_BLOCKS_3
Definition neorv32_sysinfo.h:98
@ SYSINFO_CACHE_UC_BEGIN_3
Definition neorv32_sysinfo.h:104
@ SYSINFO_CACHE_I_NUM_BLOCKS_0
Definition neorv32_sysinfo.h:97
@ SYSINFO_CACHE_D_NUM_BLOCKS_3
Definition neorv32_sysinfo.h:101
@ SYSINFO_CACHE_UC_BEGIN_0
Definition neorv32_sysinfo.h:103
@ SYSINFO_CACHE_BURSTS_EN
Definition neorv32_sysinfo.h:106
@ SYSINFO_CACHE_BLOCK_SIZE_0
Definition neorv32_sysinfo.h:94
@ SYSINFO_CACHE_D_NUM_BLOCKS_0
Definition neorv32_sysinfo.h:100
uint32_t neorv32_sysinfo_get_imemsize(void)
Definition neorv32_sysinfo.h:131
uint32_t neorv32_sysinfo_get_extbustimeout(void)
Definition neorv32_sysinfo.h:175
void neorv32_sysinfo_set_clk(uint32_t clock)
Definition neorv32_sysinfo.h:195
NEORV32_SYSINFO_MISC_enum
Definition neorv32_sysinfo.h:36
@ SYSINFO_MISC_ITMO_MSB
Definition neorv32_sysinfo.h:50
@ SYSINFO_MISC_DMEM_LSB
Definition neorv32_sysinfo.h:40
@ SYSINFO_MISC_ITMO_LSB
Definition neorv32_sysinfo.h:49
@ SYSINFO_MISC_ETMO_MSB
Definition neorv32_sysinfo.h:53
@ SYSINFO_MISC_IMEM_LSB
Definition neorv32_sysinfo.h:37
@ SYSINFO_MISC_BOOT_MSB
Definition neorv32_sysinfo.h:47
@ SYSINFO_MISC_IMEM_MBS
Definition neorv32_sysinfo.h:38
@ SYSINFO_MISC_DMEM_MSB
Definition neorv32_sysinfo.h:41
@ SYSINFO_MISC_HART_MSB
Definition neorv32_sysinfo.h:44
@ SYSINFO_MISC_BOOT_LSB
Definition neorv32_sysinfo.h:46
@ SYSINFO_MISC_HART_LSB
Definition neorv32_sysinfo.h:43
@ SYSINFO_MISC_ETMO_LSB
Definition neorv32_sysinfo.h:52
uint32_t neorv32_sysinfo_is_sim(void)
Definition neorv32_sysinfo.h:115
NEORV32_SYSINFO_SOC_enum
Definition neorv32_sysinfo.h:57
@ SYSINFO_SOC_ICACHE
Definition neorv32_sysinfo.h:63
@ SYSINFO_SOC_OCD_AUTH
Definition neorv32_sysinfo.h:69
@ SYSINFO_SOC_IO_NEOLED
Definition neorv32_sysinfo.h:84
@ SYSINFO_SOC_IO_TWI
Definition neorv32_sysinfo.h:77
@ SYSINFO_SOC_IO_UART0
Definition neorv32_sysinfo.h:75
@ SYSINFO_SOC_IO_DMA
Definition neorv32_sysinfo.h:72
@ SYSINFO_SOC_IO_SLINK
Definition neorv32_sysinfo.h:87
@ SYSINFO_SOC_IO_TWD
Definition neorv32_sysinfo.h:71
@ SYSINFO_SOC_OCD
Definition neorv32_sysinfo.h:62
@ SYSINFO_SOC_SIM
Definition neorv32_sysinfo.h:89
@ SYSINFO_SOC_IO_TRNG
Definition neorv32_sysinfo.h:81
@ SYSINFO_SOC_IO_GPTMR
Definition neorv32_sysinfo.h:86
@ SYSINFO_SOC_IO_SPI
Definition neorv32_sysinfo.h:76
@ SYSINFO_SOC_IO_UART1
Definition neorv32_sysinfo.h:83
@ SYSINFO_SOC_IO_TRACER
Definition neorv32_sysinfo.h:85
@ SYSINFO_SOC_DMEM
Definition neorv32_sysinfo.h:61
@ SYSINFO_SOC_IO_GPIO
Definition neorv32_sysinfo.h:73
@ SYSINFO_SOC_BOOTLOADER
Definition neorv32_sysinfo.h:58
@ SYSINFO_SOC_IO_SDI
Definition neorv32_sysinfo.h:82
@ SYSINFO_SOC_IO_PWM
Definition neorv32_sysinfo.h:78
@ SYSINFO_SOC_DCACHE
Definition neorv32_sysinfo.h:64
@ SYSINFO_SOC_IMEM
Definition neorv32_sysinfo.h:60
@ SYSINFO_SOC_IO_ONEWIRE
Definition neorv32_sysinfo.h:88
@ SYSINFO_SOC_IMEM_ROM
Definition neorv32_sysinfo.h:70
@ SYSINFO_SOC_IO_CLINT
Definition neorv32_sysinfo.h:74
@ SYSINFO_SOC_XBUS
Definition neorv32_sysinfo.h:59
@ SYSINFO_SOC_IO_CFS
Definition neorv32_sysinfo.h:80
@ SYSINFO_SOC_IO_WDT
Definition neorv32_sysinfo.h:79
uint32_t neorv32_sysinfo_get_numcores(void)
Definition neorv32_sysinfo.h:123
Definition neorv32_sysinfo.h:25
uint32_t CLK
Definition neorv32_sysinfo.h:26
const uint32_t MISC
Definition neorv32_sysinfo.h:27
const uint32_t SOC
Definition neorv32_sysinfo.h:28
const uint32_t CACHE
Definition neorv32_sysinfo.h:29