由 于处于特权级0的代码不能直接把控制权转移到特权级3的代码中执行,但中断返回操作是可以的,因此当初始化GDT、IDT和定时芯片结束后,我们就利用中 断返回指令IRET来启动第1个任务。具体实现方法是在初始堆栈init_stack中人工设置一个返回环境,即把任务0的TSS段选择符加载到任务寄存 器LTR中、LDT段选择符加载到LDTR中以后,把任务0的用户栈指针(0x17:init_stack)和代码指针(0x0f:task0)以及标志 寄存器值压入栈中,然后执行中断返回指令IRET。该指令会弹出堆栈上的堆栈指针作为任务0用户栈指针,恢复假设的任务0的标志寄存器内容,并且弹出栈中 代码指针放入CS:EIP寄存器中,从而开始执行任务0的代码,完成了从特权级0到特权级3代码的控制转移。
理解这段代码的关键在于iret。
处理器在执行iret指令的时候,根据是否发生特权级变化来决定是否切换堆栈,而在这里,我们正式利用特权级变换,导致执行iret的时候发生了切换堆栈,处理器会从当前堆栈中弹出SS:ESP作为新的堆栈使用。

本文介绍了一种在不同特权级间进行任务切换的方法。通过在初始堆栈中设置特定的返回环境,并利用中断返回指令IRET,可以实现在特权级0到特权级3之间的控制转移。关键步骤包括设置TSS段选择符、LDT段选择符以及任务0的用户栈指针和代码指针。
654

被折叠的 条评论
为什么被折叠?



