15#ifndef ZEPHYR_INCLUDE_ARCH_RISCV_ARCH_H_
16#define ZEPHYR_INCLUDE_ARCH_RISCV_ARCH_H_
23#if defined(CONFIG_USERSPACE)
34#define ARCH_STACK_PTR_ALIGN 16
36#ifdef CONFIG_PMP_STACK_GUARD
48#define Z_RISCV_STACK_GUARD_SIZE \
49 ROUND_UP(sizeof(z_arch_esf_t) + CONFIG_PMP_STACK_GUARD_MIN_SIZE, \
64#define ARCH_KERNEL_STACK_RESERVED Z_RISCV_STACK_GUARD_SIZE
67#define Z_RISCV_STACK_GUARD_SIZE 0
70#ifdef CONFIG_MPU_REQUIRES_POWER_OF_TWO_ALIGNMENT
107#define ARCH_THREAD_STACK_RESERVED Z_RISCV_STACK_GUARD_SIZE
108#define ARCH_THREAD_STACK_SIZE_ADJUST(size) \
109 Z_POW2_CEIL(MAX(size, CONFIG_PRIVILEGED_STACK_SIZE))
110#define ARCH_THREAD_STACK_OBJ_ALIGN(size) \
111 ARCH_THREAD_STACK_SIZE_ADJUST(size)
130#define ARCH_THREAD_STACK_RESERVED \
131 ROUND_UP(Z_RISCV_STACK_GUARD_SIZE + CONFIG_PRIVILEGED_STACK_SIZE, \
132 ARCH_STACK_PTR_ALIGN)
148#define MSTATUS_IEN (1UL << 3)
149#define MSTATUS_MPP_M (3UL << 11)
150#define MSTATUS_MPIE_EN (1UL << 7)
151#define MSTATUS_FS_INIT (1UL << 13)
152#define MSTATUS_FS_MASK ((1UL << 13) | (1UL << 14))
163#define MSTATUS_DEF_RESTORE (MSTATUS_MPP_M | MSTATUS_MPIE_EN)
182#define K_MEM_PARTITION_P_RW_U_RW ((k_mem_partition_attr_t) \
184#define K_MEM_PARTITION_P_RW_U_RO ((k_mem_partition_attr_t) \
186#define K_MEM_PARTITION_P_RW_U_NA ((k_mem_partition_attr_t) \
188#define K_MEM_PARTITION_P_RO_U_RO ((k_mem_partition_attr_t) \
190#define K_MEM_PARTITION_P_RO_U_NA ((k_mem_partition_attr_t) \
192#define K_MEM_PARTITION_P_NA_U_NA ((k_mem_partition_attr_t) \
196#define K_MEM_PARTITION_P_RWX_U_RWX ((k_mem_partition_attr_t) \
197 {PMP_R | PMP_W | PMP_X})
198#define K_MEM_PARTITION_P_RX_U_RX ((k_mem_partition_attr_t) \
214void z_irq_spurious(
const void *unused);
216#if defined(CONFIG_RISCV_HAS_PLIC)
217#define ARCH_IRQ_CONNECT(irq_p, priority_p, isr_p, isr_param_p, flags_p) \
219 Z_ISR_DECLARE(irq_p, 0, isr_p, isr_param_p); \
220 arch_irq_priority_set(irq_p, priority_p); \
222#elif defined(CONFIG_NUCLEI_ECLIC)
223void nuclei_eclic_irq_priority_set(
unsigned int irq,
unsigned int prio,
unsigned int flags);
224#define ARCH_IRQ_CONNECT(irq_p, priority_p, isr_p, isr_param_p, flags_p) \
226 Z_ISR_DECLARE(irq_p, 0, isr_p, isr_param_p); \
227 nuclei_eclic_irq_priority_set(irq_p, priority_p, flags_p); \
230#define ARCH_IRQ_CONNECT(irq_p, priority_p, isr_p, isr_param_p, flags_p) \
232 Z_ISR_DECLARE(irq_p, 0, isr_p, isr_param_p); \
244 __asm__
volatile (
"csrrc %0, mstatus, %1"
258 __asm__
volatile (
"csrs mstatus, %0"
271 __asm__
volatile(
"nop");
296#if defined(CONFIG_SOC_FAMILY_RISCV_PRIVILEGE)
uint32_t k_mem_partition_attr_t
Definition: arch.h:210
RISCV specific syscall header.
Per-arch thread definition.
#define ALWAYS_INLINE
Definition: common.h:124
flags
Definition: http_parser.h:131
Public interface for configuring interrupts.
void arch_irq_disable(unsigned int irq)
uint64_t sys_clock_cycle_get_64(void)
int arch_irq_is_enabled(unsigned int irq)
uint32_t sys_clock_cycle_get_32(void)
void arch_irq_enable(unsigned int irq)
static ALWAYS_INLINE void arch_nop(void)
Definition: arch.h:269
static ALWAYS_INLINE unsigned int arch_irq_lock(void)
Definition: arch.h:240
#define MSTATUS_IEN
Definition: arch.h:148
static ALWAYS_INLINE void arch_irq_unlock(unsigned int key)
Definition: arch.h:256
static uint32_t arch_k_cycle_get_32(void)
Definition: arch.h:276
void arch_irq_priority_set(unsigned int irq, unsigned int prio)
static uint64_t arch_k_cycle_get_64(void)
Definition: arch.h:283
static ALWAYS_INLINE bool arch_irq_unlocked(unsigned int key)
Definition: arch.h:264
RISCV public error handling.
RISCV public exception handling.
static k_spinlock_key_t key
Definition: spinlock_error_case.c:14
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
__UINT64_TYPE__ uint64_t
Definition: stdint.h:91
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
unsigned int pmp_update_nr
Definition: arch.h:207
uint8_t pmp_attr
Definition: arch.h:203
Software-managed ISR table.