简单多任务内核执行两个任务,在8253时间芯片的中断处理timer_interrupt中使用ljmp实现切换任务,可在中断处理函数中,执行ljmp命令后,任务是切换到了新任务,还是在iret返回后新任务呢?本文利用bochs自带的调试功能,分析一下任务切换过程。
1,由任务0进入timer_interrupt后,段寄存器状态如下:

任务寄存器的段选择符为:0x20,代表任务0的的RSS段描述符
2.执行ljmp后,程序跳转到任务1执行。过程截图如下。
3.继续单步执行,下一次进入timer_interrupt后,按照规划切换回任务0(段选择符0x20),切换前任务状态寄存器状态如下。

4.执行后,段寄存器状态如下,执行后。

5.如上图,下条要执行的指令为内存地址:0x150的 jmp .+17,该条指令为步骤2的下一条指令,该条指令跳转到内存地址:0x163执行。

由上述分析可知,简单多任务内核执行流程如下。


本文详细分析了一个简单多任务内核在8253时间芯片中断处理中的任务切换过程。通过Bochs的调试功能,观察到 ljmp 命令在中断处理函数timer_interrupt中触发任务切换,任务从任务0切换到任务1。在中断返回后,系统按预期回到任务0继续执行。通过对中断处理前后段寄存器状态的对比,揭示了任务切换的具体步骤和流程。
3000





