中断向量表
(重定向自中斷向量)
中断向量表(interrupt vector table)简称IVT,是有关中断进程的表格,是关系中断进程列表和中断请求列表的数据结构。中断向量表的每一笔资料都对应一个中断,此内容称为中断向量。有些中断向量表中的中断向量会存放中断进程的位置。许多不同的处理器架构都有此一概念,但实现方式会依架构而不定。例如调度表就是一种实现中断向量表的方式。
背景
编辑大部分的处理器都有中断向量表,包括Intel、AMD、Infineon、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接收到中断时,会查看中断向量表中的中断进程,并将控制权转给中断进程。
相关条目
编辑- 中断描述表(x86架构的实现)
参考资料
编辑- ^ "dsPIC33F Family Reference Manual" section 29.1.1 Interrupt Vector Table
- ^ "AVR Libc User Manual" section: Introduction to avr-libc's interrupt handling
- ^ Documentation – Arm Developer. developer.arm.com. [2020-07-26].
- ^ Documentation – Arm Developer – AArch64 exception vector table. developer.arm.com. [2020-07-26].
- ^ Intel 8080 Microcomputer Systems User's Manual. Intel Corporation. September 1975: 2–11 Interrupt Sequences. OCLC 2058546. OL 24210843M.
- ^ Roger L. Traylor. "Interrupts: AVR interrupt servicing"
- ^ Gary Hill. "Atmel AVR Interrupt and Timing Subsystems: ATMEGA328P interrupt vector table"
- ^ 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.
外部链接
编辑- Intel® Architecture Software Developer's Manual, Volume 3: System Programming Guide 互联网档案馆的存档,存档日期2009-02-16.
- Intel 64 and IA-32 Architectures Software Developer’s Manual, Volume 3A:System Programming Guide, Part 1 (see CHAPTER 6, INTERRUPT AND EXCEPTION HANDLING and CHAPTER 10, ADVANCED PROGRAMMABLE INTERRUPT CONTROLLER)]
- Motorola M68000 Exception and Vector Table,存档于互联网档案馆(存档日期 2016-03-04)