第二周 :实验链接
实验1 trace
trace函数: 参数为一个整数mask。他的bit为1的位置决定了需要trace的syscall函数,比如trace 32, 32 = 100000, 1所在的位置是第5位(从0开始,右往左),查看syscall.h文件,编号为5的函数是sys_read(). 因此trace 32 xxx。 会打印xxx命令中涉及read函数的信息
过程:
-
Add $U/_trace to UPROGS in Makefile
-
在user/user.h中添加 trace的声明
int trace(int);
-
在user/usys.pl添加, usys.pl会生成汇编usys.S,而这个usys.S会使用
ecall
进入内核entry("trace");
-
在kernel/syscall.h中为trace添加一个号码
#define SYS_trace 22
-
在 kernel/sysproc.c 添加并实现 sys_trace(), 需要使用一个结构体proc (见 kernel/proc.h)。从用户空间获取system calls参数的方法在kernel/syscall.c, 可以在kernel/sysproc.c找到它们的使用实例。
uint64 sys_trace(void) {
int mask;
argint(0, &mask);
struct proc* proc = myproc();
proc->tracemask = mask;
return 0;
}
- 修改 fork() 将proc中新的变量也复制到child里面
np->tracemask = p