- 有"spoc"标记的题是要求拿清华学分的同学要在实体课上完成,并按时提交到学生对应的ucore_code和os_exercises的git repo上。
- 第一个用户进程创建有什么特殊的?
- 系统调用的参数传递过程?
- getpid的返回值放在什么地方了?
- 尝试在进程运行过程中获取内核堆栈和用户堆栈的调用栈?
- 尝试在进程运行过程中获取内核空间中各进程相同的页表项(代码段)和不同的页表项(内核堆栈)?
- 在do_execve中进程清空父进程时,当前进程是哪一个?在什么时候开始使用新加载进程的地址空间?
- 新加载进程的第一级页表的建立代码在哪?
- 第一个内核线程和第一个用户进程的创建有什么不同?
- 尝试跟踪分析新创建的用户进程的开始执行过程?
- 为什么新进程的内核堆栈可以先于进程地址空间复制进行创建?
- 进程复制的代码在哪?复制了哪些内容?
- 进程复制过程中有哪些修改?为什么要修改?
- 什么是写时复制?
- 写时复制的页表在什么时候进行复制?共享地址空间和写时复制有什么不同?
请准备一个空闲u盘,然后请参考如下网址完成练习
注意,grub_kernel的源码在ucore_lab的lab1_X的git branch上,位于
ucore_lab/labcodes_answer/lab1_result
(报告可课后完成)请理解grub multiboot spec的含义,并分析ucore_lab是如何实现符合grub multiboot spec的,并形成spoc练习报告。
需写练习报告和简单编码,完成后放到git server 对应的git repo中
- 用户进程的启动、运行、就绪、等待、退出
- 用户进程的管理与简单调度
- 用户进程的上下文切换过程
- 用户进程的特权级切换过程
- 用户进程的创建过程并完成资源占用
- 用户进程的退出过程并完成资源回收
注意,请关注:内核如何创建用户进程的?用户进程是如何在用户态开始执行的?用户态的堆栈是保存在哪里的?
阅读代码,在现有基础上再增加一个用户进程A,并通过增加cprintf函数到ucore代码中,
能够把个人思考题和上述知识点中的内容展示出来:即在ucore运行过程中通过cprintf
函数来完整地展现出来进程A相关的动态执行和内部数据/状态变化的细节。(约全面细致约好)
请完成如下练习,完成代码填写,并形成spoc练习报告