gpt4 book ai didi

c - RISC-V 跳转到中断处理程序

转载 作者:太空宇宙 更新时间:2023-11-04 04:10:48 26 4
gpt4 key购买 nike

你好,我正在写一个小内核来更好地理解 RISC-V。到目前为止,我设法使用 UART 并设置了一个简单的内存管理器。为了能够解析用户输入,我设置了一个中断处理程序并将其地址设置为 MTVEC。然后我在 MSTATUS 和 MIE 中启用了中断。之后,我通过 mmio 寄存器设置 MTIMECMP 并使用 WFI 永远循环(RISC-V 等待中断指令)。然后我注意到 MIP 包含预期的 0x8(这意味着机器模式定时器中断挂起)。唯一的问题是我的代码没有跳转到 MTVEC。我做错了什么?最好的问候,谢尔盖·特奥多里

来源:

void mtrap(){
uint8_t txt[0x100];
struct uart_t uart = { .reg = (uint32_t*) 0x10013000 };

stringFormat(txt, 0x100, "machine trap\r\n");
uart_write(&uart, txt, 0x100);
}

void main(){
uint8_t txt[0x100];
uint64_t mvendorid, marchid, mimpid, mhartid, mstatus, misa, mtvec, mie, mip, mcause;
struct clint_t clint = { .addr = 0x2000000 };
struct plic_t plic = { .reg = (uint32_t*) 0x0c000000 };
struct uart_t uart = { .reg = (uint32_t*) 0x10013000 };

asm volatile ("csrr %[reg], mvendorid" : [reg] "=r" (mvendorid));
asm volatile ("csrr %[reg], marchid" : [reg] "=r" (marchid));
asm volatile ("csrr %[reg], mimpid" : [reg] "=r" (mimpid));
asm volatile ("csrr %[reg], mhartid" : [reg] "=r" (mhartid));
asm volatile ("csrr %[reg], misa" : [reg] "=r" (misa));

// block all harts except hart 0
if(mhartid)
for(;;){ asm volatile ("wfi"); }

mm_init(0x84000000, 0x1bffe000); // addr: 2GB + 64MB & size: 512MB - 64MB - 8KB
uart_init(&uart);

stringFormat(txt, 0x100, "mvendorid=%x, marchid=%x, mimpid=%x, mhartid=%x, misa=%x\r\n", mvendorid, marchid, mimpid, mhartid, misa);
uart_write(&uart, txt, 0x100);

// check if pending interrupt
asm volatile ("csrr %[reg], mie" : [reg] "=r" (mie));
asm volatile ("csrr %[reg], mip" : [reg] "=r" (mip));
asm volatile ("csrr %[reg], mstatus" : [reg] "=r" (mstatus));
asm volatile ("csrr %[reg], mcause" : [reg] "=r" (mcause));
stringFormat(txt, 0x100, "mie=%x, mip=%x, mstatus=%x, mcause=%x\r\n", mie, mip, mstatus, mcause);
uart_write(&uart, txt, 0x100);

// set interrupt function or vector
asm volatile ("csrw mtvec, %[reg]" : : [reg] "r" (riscv_mtrap));
asm volatile ("csrr %[reg], mtvec" : [reg] "=r" (mtvec));
stringFormat(txt, 0x100, "mtvec=%x\r\n", mtvec);
uart_write(&uart, txt, 0x100);

// enable machine mode interrupts
asm volatile ("csrs mstatus, 0x8");

// enable interrupts
asm volatile ("csrs mie, 0x8");

// check if pending interrupt
asm volatile ("csrr %[reg], mie" : [reg] "=r" (mie));
asm volatile ("csrr %[reg], mip" : [reg] "=r" (mip));
asm volatile ("csrr %[reg], mstatus" : [reg] "=r" (mstatus));
asm volatile ("csrr %[reg], mcause" : [reg] "=r" (mcause));
stringFormat(txt, 0x100, "mie=%x, mip=%x, mstatus=%x, mcause=%x\r\n", mie, mip, mstatus, mcause);
uart_write(&uart, txt, 0x100);

// enable timer and wait for x cycles
clint_set_hart_timer(&clint, mhartid, 10);
for(mip = 0; mip < 0x100; mip++){}

// check if pending interrupt
asm volatile ("csrr %[reg], mie" : [reg] "=r" (mie));
asm volatile ("csrr %[reg], mip" : [reg] "=r" (mip));
asm volatile ("csrr %[reg], mstatus" : [reg] "=r" (mstatus));
asm volatile ("csrr %[reg], mcause" : [reg] "=r" (mcause));
stringFormat(txt, 0x100, "mie=%x, mip=%x, mstatus=%x, mcause=%x\r\n", mie, mip, mstatus, mcause);
uart_write(&uart, txt, 0x100);

for(;;){ asm volatile ("wfi"); }
}

汇编:

    .align 4
.globl riscv_mtrap
.type riscv_mtrap, @function
riscv_mtrap:
j mtrap
mret

输出:

mvendorid=0, marchid=0, mimpid=0, mhartid=0, misa=800000000014112d
mie=0, mip=0, mstatus=0, mcause=0
mtvec=80000010
mie=8, mip=0, mstatus=8, mcause=0
mie=8, mip=80, mstatus=8, mcause=0

最佳答案

发现错误。 asm volatile ("csrs mie, 0x8"); 启用软件中断。我必须 asm volatile ("csrw mie, 0x80");,现在可以了。

关于c - RISC-V 跳转到中断处理程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57870131/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com