关于分页机制的一个疑惑: 我在看杨季文《80x86汇编语言程序设计》,看到分页机制的时候,遇到了一个小小的疑惑: 原书505页: 在建立好页映射表后,启用分页机制所要做的操作是简单的,只要把控制寄存器中的最高位设置为1。具体指令如下: MOV EAX, CR0 OR EAX, 80000000H MOV CR0, EAX JMP SHORT PageE PageE: xxxxxxxxx
在启用分页机制前,线性地址就是物理地址。在启用分页机制后,线性地址要通过分页机制的转换,才成为物理地址。尽管使用一条转移指令,可清除预取的指令,但随后在取指令时使用的线性地址就要经过转换才能成为物理地址。为了保证顺利过渡,在启用分页机制之后的过渡阶段,仍要维持线性地址等同于物理地址。为了做到这一点,在建立页映射表时,必须使实现过渡的代码所在的线性地址空间页映射到具有相同地址的物理地址空间页。
我对“了保证顺利过渡,在启用分页机制之后的过渡阶段,仍要维持线性地址等同于物理地址。”这句话不理解。首先,为何需要过渡代码?跳转之后的代码如果存在页映射,不就可以直接执行了吗?其次,即便需要,为何要保证维持线性地址等同于物理地址? 忘高手赐教! 谢谢
|