1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-17 05:12:57 +01:00

cpu/riscv_common: convert to uword_t usage

Signed-off-by: Dylan Laduranty <dylan.laduranty@mesotic.com>
This commit is contained in:
Dylan Laduranty 2023-03-03 22:16:25 +01:00
parent 743ae3f095
commit 5f699eeed3
3 changed files with 14 additions and 11 deletions

View File

@ -30,6 +30,7 @@
#include "sched.h" #include "sched.h"
#include "plic.h" #include "plic.h"
#include "clic.h" #include "clic.h"
#include "architecture.h"
#include "vendor/riscv_csr.h" #include "vendor/riscv_csr.h"
@ -83,13 +84,13 @@ void riscv_irq_init(void)
* @brief Global trap and interrupt handler * @brief Global trap and interrupt handler
*/ */
__attribute((used)) __attribute((used))
static void handle_trap(uint32_t mcause) static void handle_trap(uword_t mcause)
{ {
/* Tell RIOT to set sched_context_switch_request instead of /* Tell RIOT to set sched_context_switch_request instead of
* calling thread_yield(). */ * calling thread_yield(). */
riscv_in_isr = 1; riscv_in_isr = 1;
uint32_t trap = mcause & CPU_CSR_MCAUSE_CAUSE_MSK; uword_t trap = mcause & CPU_CSR_MCAUSE_CAUSE_MSK;
/* Check for INT or TRAP */ /* Check for INT or TRAP */
if ((mcause & MCAUSE_INT) == MCAUSE_INT) { if ((mcause & MCAUSE_INT) == MCAUSE_INT) {
@ -129,7 +130,7 @@ static void handle_trap(uint32_t mcause)
sched_context_switch_request = 1; sched_context_switch_request = 1;
/* Increment the return program counter past the ecall /* Increment the return program counter past the ecall
* instruction */ * instruction */
uint32_t return_pc = read_csr(mepc); uword_t return_pc = read_csr(mepc);
write_csr(mepc, return_pc + 4); write_csr(mepc, return_pc + 4);
break; break;
} }
@ -137,8 +138,8 @@ static void handle_trap(uint32_t mcause)
#ifdef DEVELHELP #ifdef DEVELHELP
printf("Unhandled trap:\n"); printf("Unhandled trap:\n");
printf(" mcause: 0x%" PRIx32 "\n", trap); printf(" mcause: 0x%" PRIx32 "\n", trap);
printf(" mepc: 0x%lx\n", read_csr(mepc)); printf(" mepc: 0x%" PRIx32 "\n", read_csr(mepc));
printf(" mtval: 0x%lx\n", read_csr(mtval)); printf(" mtval: 0x%" PRIx32 "\n", read_csr(mtval));
#endif #endif
/* Unknown trap */ /* Unknown trap */
core_panic(PANIC_GENERAL_ERROR, "Unhandled trap"); core_panic(PANIC_GENERAL_ERROR, "Unhandled trap");

View File

@ -28,6 +28,7 @@
#include "assert.h" #include "assert.h"
#include "cpu.h" #include "cpu.h"
#include "plic.h" #include "plic.h"
#include "architecture.h"
/* Local macros to calculate register offsets */ /* Local macros to calculate register offsets */
#ifndef _REG32 #ifndef _REG32
@ -42,7 +43,7 @@ static plic_isr_cb_t _ext_isrs[PLIC_NUM_INTERRUPTS];
static inline volatile uint32_t *_get_claim_complete_addr(void) static inline volatile uint32_t *_get_claim_complete_addr(void)
{ {
uint32_t hart_id = read_csr(mhartid); uword_t hart_id = read_csr(mhartid);
/* Construct the claim address */ /* Construct the claim address */
return &PLIC_REG(PLIC_CLAIM_OFFSET + return &PLIC_REG(PLIC_CLAIM_OFFSET +
@ -51,7 +52,7 @@ static inline volatile uint32_t *_get_claim_complete_addr(void)
static inline volatile uint32_t *_get_threshold_addr(void) static inline volatile uint32_t *_get_threshold_addr(void)
{ {
uint32_t hart_id = read_csr(mhartid); uword_t hart_id = read_csr(mhartid);
/* Construct the claim address */ /* Construct the claim address */
return &PLIC_REG(PLIC_THRESHOLD_OFFSET + return &PLIC_REG(PLIC_THRESHOLD_OFFSET +
@ -60,7 +61,7 @@ static inline volatile uint32_t *_get_threshold_addr(void)
static inline volatile uint32_t *_get_irq_reg(unsigned irq) static inline volatile uint32_t *_get_irq_reg(unsigned irq)
{ {
uint32_t hart_id = read_csr(mhartid); uword_t hart_id = read_csr(mhartid);
return &PLIC_REG(PLIC_ENABLE_OFFSET + return &PLIC_REG(PLIC_ENABLE_OFFSET +
(hart_id << PLIC_ENABLE_SHIFT_PER_TARGET)) + (hart_id << PLIC_ENABLE_SHIFT_PER_TARGET)) +

View File

@ -25,6 +25,7 @@
#include "thread.h" #include "thread.h"
#include "sched.h" #include "sched.h"
#include "context_frame.h" #include "context_frame.h"
#include "architecture.h"
/** /**
* @brief Noticeable marker marking the beginning of a stack segment * @brief Noticeable marker marking the beginning of a stack segment
@ -101,11 +102,11 @@ char *thread_stack_init(thread_task_func_t task_func,
memset(sf, 0, sizeof(*sf)); memset(sf, 0, sizeof(*sf));
/* set initial reg values */ /* set initial reg values */
sf->pc = (uint32_t)task_func; sf->pc = (uword_t)task_func;
sf->a0 = (uint32_t)arg; sf->a0 = (uword_t)arg;
/* if the thread exits go to sched_task_exit() */ /* if the thread exits go to sched_task_exit() */
sf->ra = (uint32_t)sched_task_exit; sf->ra = (uword_t)sched_task_exit;
return (char *)stk_top; return (char *)stk_top;
} }