1 #pragma once
2
3 #include "DragonOS/stdint.h"
4 #include <common/stddef.h>
5 #include <stdbool.h>
6
7 // RISC-V 没有直接的开启/关闭中断的指令,你需要通过修改CSR寄存器来实现
8 // 你可能需要在你的中断处理程序中处理这些操作
9
10 #define nop() __asm__ __volatile__("nop\n\t")
11
12 // RISC-V 没有 hlt 指令,你可能需要使用 wfi 指令来等待中断
13 #define hlt() __asm__ __volatile__("wfi\n\t")
14
15 // RISC-V 没有 pause 指令,你可能需要使用其他方法来实现处理器等待
16
17 // RISC-V 使用 fence 指令来实现内存屏障
18 #define io_mfence() __asm__ __volatile__("fence rw,rw\n\t" ::: "memory")
19 #define io_sfence() __asm__ __volatile__("fence w,w\n\t" ::: "memory")
20 #define io_lfence() __asm__ __volatile__("fence r,r\n\t" ::: "memory")
21
22 // 开启中断
23 #define sti() __asm__ __volatile__("csrsi mstatus, 8\n\t" ::: "memory")
24
25 // 关闭中断
26 #define cli() __asm__ __volatile__("csrci mstatus, 8\n\t" ::: "memory")
27
28 // 从io口读入8个bit
io_in8(unsigned short port)29 unsigned char io_in8(unsigned short port) {
30 while (1)
31 ;
32 }
33
34 // 从io口读入32个bit
io_in32(unsigned short port)35 unsigned int io_in32(unsigned short port) {
36 while (1)
37 ;
38 }
39
40 // 输出8个bit到输出端口
io_out8(unsigned short port,unsigned char value)41 void io_out8(unsigned short port, unsigned char value) {
42 while (1)
43 ;
44 }
45
46 // 输出32个bit到输出端口
io_out32(unsigned short port,unsigned int value)47 void io_out32(unsigned short port, unsigned int value) {
48 while (1)
49 ;
50 }
51
52 /**
53 * @brief 验证地址空间是否为用户地址空间
54 *
55 * @param addr_start 地址起始值
56 * @param length 地址长度
57 * @return true
58 * @return false
59 */
verify_area(uint64_t addr_start,uint64_t length)60 bool verify_area(uint64_t addr_start, uint64_t length) {
61 while (1)
62 ;
63 }