简单多任务内核执行两个任务,在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执行。
由上述分析可知,简单多任务内核执行流程如下。