中断和异常的建立

来源:互联网 发布:莱昂纳德体测数据 编辑:程序博客网 时间:2024/04/28 00:46

中断和异常比较相似,它们的区别是当CPU处理完中断后还会继续执行触发中断后的语句;而异常是CPU在执行时碰到了错误,转而去执行错误处理程序,执行完后,按照异常的不同可能会继续执行触发异常后的第一条语句,也可能会继续执行触发异常的语句或者退出执行。在实模式下,对于中断或异常号和处理程序的对应由中断向量表完成,而在保护模式下,对应由IDT完成。IDT是中断描述符表,即实模式下的中断向量表,在它里面保存的是中断门(TYPE=e),陷阱门(TYPE=f)和任务门(TYPE=5)。

中断分为硬中断和软中断,软中断可以由int指令模拟,int指令也可以模拟异常的发生,它和中断之间的区别是如果用int触发异常,则CPU会保存一个错误码到堆栈,而如果用int指令触发中断,则不会保存错误码。中断执行总的过程是向量号-->IDT-->中断门-->GDT。需要注意的是中断门中低两字节的偏移是对GDT中描述符的基地址而言的,在执行时,CPU会将GDT中段描述符的基地址+中断门偏移地址得到处理程序的地址。

 

上面的代码还没有打开8259A中的中断,如果要打开,则要设置相应的OCW1,如打开时钟中断,则

mov al,11111110b

out 0x21,al

同时,还要用sti指令设置IF=1。

现在还存在的问题是ret指令时,系统总会崩溃,应该是堆栈的问题,所以处理程序最后都死循环了。

原创粉丝点击