1,寄存器保护区域
寄存器保存区域位于TSS内偏移20H至5FH处,用于保存通用寄存器、段寄存器、指令指针和标志寄存器。 当TSS对应的任务正在执行时,保存区域是未定义的;在当前任务被切换出时,这些寄存器的当前值就保存在该区域。当下次切换回原任务时,再从保存区域恢复出这些寄存器的值,从而使处理器恢复成该任务换出前的状态,最终使任务能够恢复执行。
2,内层堆栈指针区域
为了有效地实现保护, 一个任务在不同的特权级下使用不同的堆栈。比如当从外层特权级3变换到内层特权级0时,任务使用的堆栈也同时从3级堆栈变换到0级堆栈;当从内层特权级0变换到外层特权级3时,任务使用的堆栈也同时从0级堆栈变换到3级堆栈。所以,一个任务可能具有四个堆栈,对应四个特权级。 四个堆栈需要四个堆栈指针。
TSS的内层堆栈指针区域中有三个堆栈指针, 他们都是48位的全指针(16位的选择子和32位的偏移), 分别指向0级、1级和2级堆栈的栈顶,依次存放在TSS中偏移4、12和20开始的位置。 当发生像内层转移时,则把适当的堆栈指针装入SS及ESP寄存器以变换到内层的堆栈,外层堆栈的指针保存在内层堆栈中。 没有指向3级的堆栈的指针,因为3级是最外层,所以任何一个向内层的转移都不吭能转移到3级。
但是,当特权级由内向外变换时, 并不把内层堆栈的指针保存到TSS的内层堆栈指针区域。 这表明向内层转移时,总是把内层堆栈认为是一个空栈,。 因此,不允许发生同级内层转移的递归, 一旦发生向某级内层转移,那么返回到外层的正常途径是相匹配的向外层返回。
- [游客] 考古 08/12 11:33
- [somniumchase] 我一运行就说没有数字 01/01 11:44
- [游客] 为什么啊 08/07 15:36
- [游客] 如果想快一些 就改下面这里 dx值改成1H delay: push ax 04/19 02:53
- [lshhjx] 注释在程序中很重要,楼主不知道吗? 12/08 13:40
- [biaggi] 看不明白,在下還須學習 11/06 08:11
- [游客] 我运行的时候直接显示Unkown filename跳出了- -请问怎么改 06/16 21:44
- [游客] 勿庸置疑,注释是好习惯。与人方便自己方便。 04/12 10:33
- [游客] 老实说,看着真心累呀! 04/07 18:37
- [游客] 很无语,初学者就多看书,不要动不动要别人注释,基础打好了,再自己注释,这样比别人帮你注释好得多 12/17 19:43
- [游客] windows 7是一个64Bit操作系统,它不兼容DOS,无法识别16Bit系统。重装系统wind 02/28 21:05
- [游客] windows 7是一个64Bit操作系统,它不兼容DOS,无法识别16Bit系统。重装系统wind 02/28 21:05
- [466987333] 你好,高手,我想请教一个问题。 我用的是win7操作系统,32位的,里面没有找masm目录,是不是 12/12 17:30
- [lanfioncc] 那个太高级了。。。我还有点看不懂。。不过谢谢!!! 11/27 11:23
- [yc2010] 实验16中的 table: dw sub1,sub2,sub3,sub4 可不可以改成呢? 09/11 09:08
- [yc2010] mov bl,ah mov bh,0 add bx,bx ----------->这里为 09/07 21:03
- [yc2010] 为什么要add bx,bx呢? 09/07 20:55
- [yc2010] 那是不是像table[bx],ds[bx]....等(内存单元)都是表示一个字节呢? 09/06 21:10
- [masmaster] 杨季文的《80X86汇编语言程序设计教程》 09/01 12:52
- [游客] to masmaster shl左移4位,那al传进来的4,5,6位背景色不就没了. 为什 09/01 11:00