这一部分是希望能够处理页错误、断点和系统调用

处理系统页错误

在发生了page fault之后,进入到系统中断中,然后经过_alltraps,进入到trap,再经过trap_dispatch分发,应该对中断类型为T_PGFLT的中断进行处理

MIT 6.828 xv6/jos LAB3-PARTB

当然,页错误也有内核页错误和用户页错误

MIT 6.828 xv6/jos LAB3-PARTB

处理断点

在JOS中,断点中断被“滥用”了,几乎是一种系统调用,用作调用系统的Monitor,实现很简单

MIT 6.828 xv6/jos LAB3-PARTB

系统调用

系统调用的汇编部分已经写好了

MIT 6.828 xv6/jos LAB3-PARTB

引发一个中断,中断号是T_SYSCALL,而具体的系统调用号写在了num中,也就是寄存器ax中,然后在trap_dispatch中,调用syscall就可以了

MIT 6.828 xv6/jos LAB3-PARTB

而syscall的实现如下所示

MIT 6.828 xv6/jos LAB3-PARTB

User-mode startup

在系统启动时刻加载的链接进内核的程序是user/hello.c

就是打印hello world和自己的环境信息

但是这里涉及到好几次的中断和系统调用

MIT 6.828 xv6/jos LAB3-PARTB

第一次调用系统调用sys_getenvid是

MIT 6.828 xv6/jos LAB3-PARTB

然后进入umain函数之后

MIT 6.828 xv6/jos LAB3-PARTB

这里输出了两次,所以会产生两次系统调用

当umain函数执行结束之后,回到Libmain函数,此时会执行exit函数,而exit函数内部会调用env_destroy

这样上面的中断和系统调用就都解释清楚了

Page fault and memory protection

非常重要的内容,保护内存,在进行内存操作的时候,检查当前的内存范围是不是当前进程可以访问的,如果不是的话,检查失败,结束进程

MIT 6.828 xv6/jos LAB3-PARTB

上面这段代码是参考别人的程序

检查给定的内存范围内的所有页,看当前的用户有没有权限访问

至此本次实验结束,折腾了一天半。。。

相关文章: