中断向量表

(重定向自中斷向量

中断向量表(interrupt vector table)简称IVT,是有关中断进程的表格,是关系中断进程英语interrupt handler列表和中断请求英语interrupt request列表的数据结构。中断向量表的每一笔资料都对应一个中断,此内容称为中断向量。有些中断向量表中的中断向量会存放中断进程英语interrupt handler的位置。许多不同的处理器架构都有此一概念,但实现方式会依架构而不定。例如调度表英语dispatch table就是一种实现中断向量表的方式。

背景

编辑

大部分的处理器都有中断向量表,包括IntelAMDInfineon、Microchip[1]Atmel[2]、NXP、ARM[3][4]等厂牌的处理器。

中断进程

编辑

处理方式

编辑

中断向量表提供中断进程的方法有很多,最常见的是以下的三种:

事先定义

编辑

事先定义的方式会直接将程序计数器(PC)移到中断向量表中,其中存放的是可执行的程序档。理论上特别短的中断处理程序可以直接放在中断向量表内,不过实务上,中断向量表放的会是跳跃到对应中断处理程序(ISR)的跳跃指令。Intel 8080[5] Atmel AVR[6][7],所有8051以及Microchip处理器[8]都使用此一作法。

获取位置

编辑

获取位置(fetch)的方式中,中断向量表里的中断向量没有代码,只有中断进程的位置,有中断时,会用中断向量表查到中断进程位置,将指定位置填入程序计数器,执行那部分的程序[8]。此作法的中断向量表内,每一个内容都是对应中断进程的位置。所有Motorola/Freescale微处理器都使用此一方式[8]

中断应答

编辑

在中断应答(interrupt acknowledge)方法中,会由外部装置给CPU中断进程的编号。Intel Pentium处理器以及较旧的微处理器会使用此方法[8]

若CPU接收到中断时,会查看中断向量表中的中断进程,并将控制权转给中断进程。

相关条目

编辑

参考资料

编辑
  1. ^ "dsPIC33F Family Reference Manual" section 29.1.1 Interrupt Vector Table
  2. ^ "AVR Libc User Manual" section: Introduction to avr-libc's interrupt handling
  3. ^ Documentation – Arm Developer. developer.arm.com. [2020-07-26]. 
  4. ^ Documentation – Arm Developer – AArch64 exception vector table. developer.arm.com. [2020-07-26]. 
  5. ^ Intel 8080 Microcomputer Systems User's Manual. Intel Corporation. September 1975: 2–11 Interrupt Sequences. OCLC 2058546. OL 24210843M. 
  6. ^ Roger L. Traylor. "Interrupts: AVR interrupt servicing"
  7. ^ Gary Hill. "Atmel AVR Interrupt and Timing Subsystems: ATMEGA328P interrupt vector table"
  8. ^ 8.0 8.1 8.2 8.3 Huang, Han-Wat. Pic Microcontroller: An Introduction to Software and Hardware Interfacing. Cengage Learning. 2005: 247 [22 April 2013]. ISBN 978-1-4018-3967-3. 

外部链接

编辑