/touxiang.jpg

Zhou X's Blog

6.s081_lab4

Chapter 4 4.1RISC-V陷入机制 每个RISC-V CPU都有一组控制寄存器,内核通过向这些寄存器写入内容来告诉CPU如何处理陷阱,内核可以读取这

6.s081_lab3

Chapter 3 3.1页式硬件 该树的根是一个4096字节的页表页,其中包含512个PTE,每个PTE中包含该树下一级页表页的物理地址(PPN)。这些页中

6.s081_lab2

chapter 2 2.2用户态、核心态、系统调用 RISC-V分为三个模式machine mode,supervisor mode and user mode 在机器模式下执行的指令具有完全权限;CPU以机器模式启动。

6.s081_lab1

lab1 sleep 思路 直接将argv[1]赋值给sleep系统调用即可 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 #include "kernel/types.h" #include "kernel/stat.h" #include "user/user.h" int main(int argc, char *argv[]) { char *sleeptime_char; int sleeptime; if

Read_write_struct

关于结构体的读写 user space 可以通过fread和rwrite进行结构体的读写。 1 2 3 4 5 6 7 8 9 10 11 size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream) size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream) ptr − This is the pointer

6.828_lab3

For GCC 7 or later, after switching to lab3 branch an error like kernel panic at kern/pmap.c:147: PADDR called with invalid kva 00000000 will occur. This is a bug caused by the linker script, modify kern/kernel.ld as follow will fix it. 1 2 3 4 5 6 7 8 9 10 --- a/kern/kernel.ld +++ b/kern/kernel.ld @@ -50,6 +50,7 @@ SECTIONS .bss : { PROVIDE(edata = .); *(.bss) + *(COMMON) PROVIDE(end