sti指令导致奇怪问题
由于要在打印字符函数前后加上cli和sti关闭/打开中断以保证打印不会错乱。结果发现执行完sti指令以后后面一个正常的mov指令都直接报错,通过打开bochs的show dbg-all参数执行debug,结果显示如下:
通过上面来看是由于GP异常导致执行0008:c0001515这条指令报错。GP异常有可能是很多情况导致,查看GP异常手册:
链接:https://wiki.osdev.org/Exceptions#General_Protection_Fault
由于bochs后面打印除了error code=0x0042,所以肯定是文档里说的segment related异常:
把0x0042和这个格式对一下,结果发现是由于在idt里找不到中断导致的GP异常。
然后检查代码,发现在执行sti命令时idt还没有初始化,所以可能是在执行到0008:c0001515这条指令时中断过来了,然后在idt里没有找到合法的对应的入口就报了GP异常。所以问题不是0008:c0001515这条指令的问题。
问题代码:
解决方法是给这三条打印指令删除(sti就是打印方法里的),或者放到中断初始化之后。