控制转移基本上可分为两种:同一任务内的控制转移和任务间的控制转移(任务切换)。同一任务内的控制转移又分为:段内转移,特权及不变的段间转移和特权级变换的段间转移。
在保护模式下,段间转移的目标位置由选择子和偏移构成的地址表示,常把它称为目标地址。
使用JMP和CALL还可分为段间直接转移和段间间接转移两类。 如果指令JMP和CALL在指令中直接含有目标地址指针,那么就是段间直接转移;如果指令中含有指向包含目标地址指针的门描述符或TSS描述符的指针,那么就是段间间接转移。
向目标代码段转移的步骤:
1.判断目标地址指针内的选择子指示的描述符是否为空描述符。目标代码段描述符不能为空描述符,也即选择子的高14位不能为0.
2.从全局或者局部描述符表内读出目标代码段描述符。由选择子内T1位,确定使用全局描述符表还是局部描述符表。
3.根据情况,检测描述符类型是否正确;调整RPL。
4.把目标代码段描述符内的有关内容装载到CS高速缓冲寄存器。
5.判别目标地址指针内的偏移是否越出代码段。目标地址指针内的偏移必须不超过目标代码段界限。
6.装载CS段寄存器和指令寄存器EIP;CPL存入CS内选择子的RPL字段。
DPL表示目标代码段描述符特权将:
1.对于非一致代码段,要求CPL=DPL,RPL<=DPL;对于一致代码段,要求CPL>=DPL.
2.代码段必须存在,即描述符中P位必须为1.
通常描述符特权级DPL规定了对应段的特权级。如果描述符描述的是数据段,那么DPL就规定了访问该数据段的最外层特权级(准则:只有相同或更高特权级的代码才能访问相应的数据段);如果描述符是代码段,那么DPL就规定了执行该代码段所需要的CPL。对于一致代码段,要求CPL>=DPL,也就是说,一直代码段描述符中的DPL,规定可以转移到一致代码段的最内层特权级。例如:3级的程序可以转移到任何一致的代码段,而0级的程序只允许转移到DPL等于0的一致代码段。一致代码段是一种特别的村村段。这种存储段,为在多个特权级执行的程序,提供对子例程的共享支持,而不要改变特权级。