<1> 任务0的堆栈问题
一直不明白schedule.c里的task_union的stack和user_stack是什么关系,head.s里就设置了esp指向user_stack, 却一直没有用到task_union,直到看到INIT_TASK才明白,从进入保护模式到跳转进用户态都是用的user_stack这个栈,而任务0的tss中的esp0指向task_union的stack, 也就是当任务0再跳转进内核态时才用task_union的栈。总结起来就是从进入保护模式到初始化完成,user_stack用作内核态栈,进入用户态后user_stack用做用户态栈,task_union的stack用做内核态栈。
<2> 内核态寻址问题
内核代码段和数据段基址为0, 段限长为16M,而且在head.s中所设置的前四个页表与物理内存页是一一对应的,所以在内核态可以直接寻址16M内存(0.11版只支持16M内存),也即线性地址和物理地址相等。
<3>物理地址分配
<4>线性地址分配
每个任务占64M的线性地址空间,任务0实际只用了0-64M的前640KB,因为段限长被设成了640KB。因为最多支持64个任务,所以总共使用了4G的线性地址空间。