中断(interrupt)、异常(exception)、陷入(trap)

本文详细阐述了中断、异常及陷阱三个概念的区别,并通过具体的例子帮助读者理解这些概念的实际应用。介绍了中断是为了设备与CPU之间的通信,异常是由当前执行进程产生的错误或陷阱,而陷阱主要用于调试。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

实际上,本书没有必要严格地去区分什么是中断,什么是异常。由于本章要用到一点中断和异常的概念,所以这里稍微作一个介绍。
中断:是为了设备与CPU之间的通信。典型的有如服务请求,任务完成提醒等。比如我们熟知的时钟中断,硬盘读写服务请求中断。中断的发生与系统处在用户态还是在内核态无关,只决定于EFLAGS寄存器的一个标志位。我们熟悉的sti, cli两条指令就是用来设置这个标志位,然后决定是否允许中断。在单个CPU的系统中,这也是保护临界区的一种简便方法。中断是异步的,因为从逻辑上来说,中断的产生与当前正在执行的进程无关。事实上,中断是如此有用,Linux用它来统计时钟,进行硬盘读写等。
异常:异常是由当前正在执行的进程产生。异常包括很多方面,有出错(fault),有陷入(trap),也有可编程异常(programmable exception)。出错(fault)和陷入(trap)最重要的一点区别是他们发生时所保存的EIP值的不同。出错(fault)保存的EIP指向触发异常的那条指令;而陷入(trap)保存的EIP指向触发异常的那条指令的下一条指令。因此,当从异常返回时,出错(fault)会重新执行那条指令;而陷入(trap)就不会重新执行。这一点实际上也是相当重要的,比如我们熟悉的缺页异常(page fault),由于是fault,所以当缺页异常处理完成之后,还会去尝试重新执行那条触发异常的指令(那时多半情况是不再缺页)。陷入的最主要的应用是在调试中,被调试的进程遇到你设置的断点,会停下来等待你的处理,等到你让其重新执行了,它当然不会再去执行已经执行过的断点指令。

可编程中断:这类中断可由编程者用int指令来触发。在Linux中,使用了一个,也是唯一的一个可编程中断,就是int 0x80系统调用。硬件对可编程中断的处理与对trap的处理类似,即从这类异常返回时也是返回到触发异常的下一条指令。关于可编程中断,还有另外一种说法:软件中断(software interrupt),其实是一个意思





最近看了些内核的书,发现这区分这三个概念是很有必要的。下面是笔者查了些资料总结出来的,供大家借鉴,不对的地方还请指出。

1.        中断(zhong duan)
(1)        是由由CPU外部产生的,对CPU来说,是被动的。
(2)        当中断发生时,CPU将下一条指令,也就是接下来要执行的指令的地址压入栈作为中断服务的返回地址。

2.        陷入 (xian ru)
(1)        是由CPU本身在执行程序过程中产生的。它是由专设的指令,如X86中的“INT n”,在程序中有意产生的,是主动的。
(2)        同中断一样,当陷入发生时,CPU将下一条指令,也就是接下来要执行的指令的地址压入栈,作为中断服务的返回地址。

3.        异常(yi chang)
(1)        是由于CPU因无法完成一些指令而产生的,如除以0、映射失败,等等。
(2)        当异常发生时,CPU将当前指令的地址(而不是下一条指令的地址)压入栈,作为异常服务的返回地址。这样,就可以在异常处理返回时完成未竟完成的事业。
(3)        这个特殊性是在CPU的内部电路实现的,而不需由软件干预。即是由Intel实现的,和微软没关系。

4.
(1)        中断、陷入、异常概念很想象,可是有很大区别,严格分清是很有必要的。
(2)        从以上概念我们不难分清,所谓“页面中断“是不对的,应该叫”页面异常“才对。

### 操作系统中断异常处理机制解释 #### 中断异常定义 中断Interrupt)和异常Exception)指明系统、处理器或当前执行程序(或任务)的某处出现了一个事件,此事件需要处理器立即进行处理[^3]。通常情况下,中断是在程序执行过程中随机发生的,主要响应来自硬件的信号,用于处理外部事件,例如外设的服务请求;而异常则是在处理器执行指令时检测到了错误条件所触发,如除零错误等。 #### 类型区分 对于异常而言,其被细分为三种不同类型:陷阱(Trap)、故障(Fault)以及中止(Abort)。这些类型的差异在于发生的原因及其后续处理方式的不同。当遇到特定情况下的非法操作或者预期内的操作失败时会触发陷阱;如果某个指令试图访问不存在的数据页面,则会产生页错误即属于故障的一种形式;至于中止则是更为严重的状况下才会产生的,它往往意味着遇到了不可恢复性的严重问题。 #### CPU状态转换 当中断异常发生之后,为了能够安全有效地完成相应的处理工作,CPU必须从用户模式转变为内核模式。这是因为操作系统在管理诸如进程调度、资源分配等工作时需要用到一些仅限于核心层使用的特权命令。这种转变使得OS获得了整个计算环境内的最高权限以便更好地协调各项活动并维持系统的稳定运行[^2]。 #### 流程概述 一旦接收到中断信号或是发生了异常情形后,系统将会保存现场信息——即将所有寄存器的内容复制到堆栈上以备将来恢复之需。接着调用对应的中断/异常服务例程(ISR),这个过程可能涉及到查找中断向量表来定位具体的ISR地址。最后,在完成了必要的处理逻辑之后再返回至原先被打断的地方继续往下执行未完成的任务[^1]。 ```python def handle_interrupt_or_exception(): save_context() # Save the current execution context to stack vector_table_address = get_vector_table_entry(interrupt_number) call_isr(vector_table_address) # Call Interrupt Service Routine based on address from table restore_context_and_resume_execution() ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值