▼ 中断是一个由硬件激发的过程,它中断当前正在执行的任何程序。
▼ 在Intel系列微处理器中,包括INTR和NMI(Non Maskable Interrupt)两个申请中断的引脚和一个响应INTR中断的引脚INTA。
▼ 软中断有INT、INTO、INT3和BOUND。其中,INTO和BOUND为条件中断。
▼ IF(interrupt flag,中断标志)和TF(trap flag)两个标志位。
▼ 中断返回指令是:IRET(IRETD)。
▼ 中断向量表(interrupt vector table)存于:000000H~0003FFH,共256个,每个4字节,共占1024字节。
▼ 中断向量(interrput vector)包含中断服务程序的入口地址(段地址+偏移地址)。
▼ 当微处理器执行完当前指令后,会按照下边给出的顺序检查下列条件以确定中断是否有效。
图1 确定中断前的条件检查
▼ 中断发生时的处理顺序如下:
图2 中断处理顺序
▼ 保护模式下,使用一组存储在中断描述表IDT(interrupt descriptor table)中的共256个中断描述符来取代中断向量。每个中断描述符长8字节,共256 × 8 = 2K字节。
图3 保护模式下的中断描述符
▼ 中断描述符表由中断描述表地址寄存器IDTR定位于系统中任何存储单元。
原文:http://www.cnblogs.com/AmitX-moten/p/4855112.html