IA-32e模式下的异常处理

Posted megachen

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了IA-32e模式下的异常处理相关的知识,希望对你有一定的参考价值。

系统异常处理

CPU如果调用系统异常处理程序

需要的数据结构
  • IDT_Table: 中断向量表, 在中断向量表中的每一项都是一个中断描述符(中断门或者陷阱门), 一个中断描述符中的几位是段选择符
  • GDT或者LDT
处理过程(没有特权变化的情况)
  • 中断向量号 -> IDT -> 中断描述符 -> 段选择子 -> GDT/LDT -> 段描述符 -> 基地址, 同时得知中断描述符保存的段内偏移量 -> 中断处理程序
处理过程(有特权变化的情况)
  • CPU将EFLAGS, CS, EIP, Error Code都压入栈

注意

  • 中断和异常向量都在一张IDT表中, IDT表总共256项
  • IDT表的前32项都是异常向量
  • 我们已经在head.S程序的前半部分手动初始化了一下IDT(是不完整的初始化), 在head.S程序的后半阶段我们setup IDT表示, 给这256个异常和中断向量的异常处理程序都设置为同一个目标代码地址, 都是显示一串字符串"Error! Unknown interrupt or fault at RIP"
  • 初始化完毕IDT之后, 紧接着我们要初始化TSS
真正进入到内核程度之后的系统异常处理
  • 在trap.c文件中对每一个异常都提供一个异常处理函数(trap, interrupt, system)

以上是关于IA-32e模式下的异常处理的主要内容,如果未能解决你的问题,请参考以下文章

IIS7 集成管道模式下的异常处理

发布模式下的异常,而不是调试模式下的异常

计算机系统之汇编---IA32处理器数据格式及数据操作

SEH结构化异常处理

drf自定义异常处理

Windows下的异常处理和堆栈跟踪(MinGW/gcc)