首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux中断处理

中断处理 - 上半部(硬中断) 由于 APIC中断控制器 有点小复杂,所以本文主要通过 8259A中断控制器 来介绍Linux中断处理过程。...: handler: 中断处理入口函数,handler 第一个参数是中断号,第二个参数是设备对应ID,第三个参数是中断发生时由内核保存各个寄存器值。...这里要注意是,如果中断处理过程能够开启中断,那么就把中断打开(因为CPU接收到中断信号时会关闭中断)。...鉴于这个原因,Linux中断处理分为两个部分,上半部 和 下半部,上半部 在前面已经介绍过,接下来就介绍一下 下半部 执行。...softirq机制 中断下半部 由 softirq(软中断) 机制来实现,在Linux内核中,有一个名为 softirq_vec 数组,如下: static struct softirq_action

6.5K20

Linux中断 - IDT

[toc] 如何设置IDT IDT 中断描述符表定义 中断描述符表简单来说说是定义了发生中断/异常时,CPU按这张表中定义行为来处理对应中断/异常。...中断描述符项定义 当中断发生,cpu获取到中断向量后,查找IDT中断描述符表得到相应中断描述符,再根据中断描述符记录信息来作权限判断,运行级别转换,最终调用相应中断处理程序; 这里涉及到Linux...IDT 中断描述符表本身存储 IDT 中断描述符表物理地址存储在IDTR寄存器中,这个寄存器存储了IDT基地址和长度。...传统系统调用相关 IDT 设置 Linux系统启动过程中内核压解后最终都调用到start_kernel, 在这里会调用trap_init, 然后又会调用idt_setup_traps: void...硬件中断相关IDT初始化也是在Linux启动时完成,在start_kernel中通过调用init_IRQ完成,我们来看一下: void __init init_IRQ(void) { int

6.5K10
您找到你想要的搜索结果了吗?
是的
没有找到

Linux内核硬中断中断原理和实现

如果中断线是激活中断控制器就把电信号发送给处理器某个特定引脚。处理器于是立即停止自己正在做事,跳到中断处理程序入口点,进行中断处理。...linux为了实现这个特点,当中断发生时候,硬中断处理那些短时间就可以完成工作,而将那些处理事件比较长工作,放到中断之后来完成,也就是软中断(softirq)来完成。...(3)中断嵌套 Linux下硬中断是可以嵌套,但是没有优先级概念,也就是说任何一个新中断都可以打断正在执行中断,但同种中断除外。软中断不能嵌套,但相同类型中断可以在不同CPU上并行执行。...(4)软中断指令 int是软中断指令。 中断向量表是中断号和中断处理函数地址对应表。 int n -- 触发软中断n。相应中断处理函数地址为:中断向量表地址 + 4 * n。...(5)硬中断和软中断区别 软中断是执行中断指令产生,而硬中断是由外设引发。 硬中断中断号是由中断控制器提供,软中断中断号由指令直接指出,无需使用中断控制器。

21.3K21

Linux系统中断硬件框架

资料下载 coding无法使用浏览器打开,必须用git工具下载: git clone https://e.coding.net/weidongshan/linux/doc_and_source_for_drivers.git...它们都有自己寄存器,可以进行相关设置:使能中断中断状态、中断类型等等。 中断控制器 各种中断源发出中断信号,汇聚到中断控制器。 可以在中断控制器中设置各个中断优先级。...中断控制器会向CPU发出中断信号,CPU可以读取中断控制器寄存器,判断当前处理是哪个中断。...CPU也有自己寄存器,可以设置它来使能/禁止中断,这是中断处理总开关。...把中断发给CPU 3.2.3 NVIC 多个中断源汇聚到NVIC,NVIC职责就是从多个中断源中取出优先级最高中断,向CPU发出中断信号。

4.4K40

Linux中断可以嵌套吗?

问答 问:Linux中断可以嵌套吗? 答:以前是可以嵌套,现在不可以!...历史 早前Linux内核版本,中断分为两种: 快中断申请时候带IRQF_DISABLED标记,在IRQ HANDLER里面不允许新中断进来; 慢中断申请时候不带IRQF_DISABLED标记...老Linux内核中,如果一个中断服务程序不想被别的中断打断,我们能看到这样代码: request_irq(FLOPPY_IRQ, floppy_interrupt,\ - IRQF_DISABLED...也就是说,从这个commit开始,实际Linux已经不再支持中断嵌套, 也没有快慢中断概念了,IRQF_DISABLED标记也作废了。...Linux内核会在如下2个时候重新开启CPSR对IRQ响应: 从IRQ HANDLER返回中断底半部SOFTIRQ 从IRQ HANDLER返回一个线程上下文 从1大家可以看出,SOFTIRQ里面是可以响应中断

5.2K31

Linux 中断处理浅析

最近在研究异步消息处理, 突然想起linux内核中断处理, 里面由始至终都贯穿着”重要事马上做, 不重要事推后做”异步处理思想....由于这一步是在开中断条件下进行,这里还可能发生新中断中断嵌套),然后新中断对应中断处理又将开始一个新第一阶段~第三阶段。在新这个第三阶段中,可能又会触发新中断。...中断处理这几个阶段中不能调用可能导致睡眠函数(包括分配内存); 对于第一个问题, 较新linux内核增加了ksoftirqd内核线程, 如果持续处理softirq超过一定数量, 则结束中断处理过程...据说在montavista(一种嵌入式实时linux)中, 将内核中断机制做了修改. (某些中断)中断处理过程被赋予了task结构, 能够被内核调度. 解决了上述两个问题....(montavista目标是实时性, 这样做法牺牲了一定整体性能.) 工作队列 linux基线版本内核在解决上述问题上, 提供了workqueue机制.

7.3K80

扒开 Linux 中断底裤之 workqueue

workqueue 是除了 softirq 和 tasklet 以外最常用下半部机制之一。workqueue 本质是把 work 交给一个内核线程,在进程上下文调度时候执行。...或者 pool_workqueue 指针 entry:用于添加到其他队列上 func:工作任务处理函数,在内核线程中回调 workqueue_struct : 工作集合。...workqueue 和 work 是一对多关系。内核中工作队列分为两种: bound:绑定处理器工作队列,每个 worker 创建内核线程绑定到特定 CPU 上运行。...数量 idle_list:处于 IDLE 状态 worker 添加到本链表 busy_hash:工作状态 worker 添加到本哈希表中 workers:worker_pool 管理 worker...经过上面两个阶段初始化,workqueue 子系统基本就已经将数据结构关联建立好了,当有 work 来进行调度时候,就可以进行处理了。

1.9K51

linux 中断机制《Rice linux 学习笔记》

这篇文章以按键为例子讲解linux中断原理,中断架构,中断实现。 在我们开发中,检测按键是否触发,无非就两种方法—轮询和中断。作者认为两种方法最大区别就是CPU利用率。...Linux中断原理: 中断:处理器异常一种,它是一种特殊电信号,用硬件发给处理器,处理器接收到中断后,会马上向操作系统反映此信号到来,然后就由操作系统负责处理这些新到来数据。...unsigned int irq, irq_handler_t handler, unsigned long flags, const char *name, void *dev); 其中: irq:要申请中断号...dev:与request_irq参数dev必须一致,将request_irq指定dev传递给这个参数; Linux中断处理分析: 第一种方式:应用层读,不管什么情况下,都会返回。...第二种方式:应用层读,只有按键按下时候,才会返回。 Linux中断实现: 这里例子采用等待队列方式实现(也就是上述第二种方法)。

4.7K10

linux内核缺页中断处理

MMU可以做虚拟地址到物理地址转换,使用MMU我们就可以使用更多内存空间,因为程序具有局部性原理,我们可以将暂时用不到数据存放到磁盘,当访问到时会发生缺页中断,从磁盘中将所需要数据加载到内存。...7.当磁盘中断发生时,表明该页已经被装入,页表已经更新可以反映他位置,页框也标记位正常状态。 8.恢复发生缺页中断指令以前状态,程序计数器重新指向这条指令。...9.调度引发缺页中断进程,操作系统返回调用他汇编例程 10.该例程恢复寄存器和其他状态信息,返回到用户空间继续执行,就好像缺页中断没有发生过。...linux内核对缺页异常处理流程很复杂,但是基本思想和上述流程差不多。...下面看linux基本处理流程: 内核处理缺页异常主函数就是do_page_fault: /* * 缺页异常处理函数 * pt_regs 各个寄存器值 * error_code,由硬件产生:

10.6K21

Linux中断下半部机制对比

Linux有以下几种下半部机制: 软中断 tasklet workqueue threaded irq  中断服务程序一般都是在中断请求关闭条件下执行,以避免嵌套而使中断控制复杂化。...因此,Linux内核目标就是尽可能快处理完中断请求,尽其所能把更多处理向后推迟。...例如,假设一个数据块已经达到了网线,当中断控制器接受到这个中断请求信号时,Linux内核只是简单地标志数据到来了,然后让处理器恢复到它以前运行状态,其余处理稍后再进行(如把数据移入一个缓冲区,接受数据进程就可以在缓冲区找到数据...我们这节先讲中断线程,其接口如下: /include/linux/interrupt.h extern int __must_check request_threaded_irq(unsigned int...linux中断线程化(threaded irq)和工作队列(work queue)异同 两者差异: 1、调度优先级不同: threaded irq handler所在进程(内核线程),调度类别是SCHED_FIFO

10410

Linux中断虚拟化(一)

作者简介 王柏生 资深技术专家,先后就职于中科院软件所、红旗Linux和百度,现任百度主任架构师。在操作系统、虚拟化技术、分布式系统、云计算、自动驾驶等相关领域耕耘多年,有着丰富实践经验。...著有畅销书《深度探索Linux操作系统》(2013年出版)。 谢广军 计算机专业博士,毕业于南开大学计算机系。资深技术专家,多年IT行业工作经验。...本文内容节选自《深度探索Linux虚拟化技术》,已获得机械工业出版社华章公司授权。...因此,在本章中,我们简单介绍硬件中断基本原理,然后结合中断基本原理讨论如何虚拟化中断芯片。...虚拟中断 在探讨Guest模式CPU处理中断前,我们首先回顾一下物理CPU是如何响应中断

6.2K30

Linux中断虚拟化(二)

作者简介 王柏生 资深技术专家,先后就职于中科院软件所、红旗Linux和百度,现任百度主任架构师。在操作系统、虚拟化技术、分布式系统、云计算、自动驾驶等相关领域耕耘多年,有着丰富实践经验。...著有畅销书《深度探索Linux操作系统》(2013年出版)。 谢广军 计算机专业博士,毕业于南开大学计算机系。资深技术专家,多年IT行业工作经验。...本文内容节选自《深度探索Linux虚拟化技术》,已获得机械工业出版社华章公司授权。...,如果有中断请求,则运行对应中断服务程序,然后返回被中断计算任务继续执行。...第2部分是获取正在被CPU处理中断优先级中断优先级,通过这里,读者更能具体理解了8259A为什么需要这些寄存器记录中断状态。

5.7K10

Linux中断机制分析

中断分析最近工作繁忙,没有时间总结内核相关一些东西。上次更新博客到了linux内核中断子系统。这次总结一下软中断,也就是softirq。之后还会总结一些tasklet、工作队列机制。...这样后果会造成有可能丢失外部中断。于是,linux内核设计出了一种架构,中断函数需要处理任务分为两部分,一部分在中断处理函数中执行,这时系统关闭中断。...在linux系统进程数据结构里,有这么一个数据结构 #define preempt_count()(current_thread_info()->preempt_count), 利用preempt_count...对于ARM架构CPU不存在中断嵌套中调用软件中断问题,因为ARM架构CPU在处理硬件中断过程中是关闭掉中断。...Linux内核就中断方面就必须考虑平衡这三个方面的问题。而下面我要分析__do_softirq函数就恰似在这三者之间打太极,游刃有余,面面俱到!

8.6K91

Linux 中断子系统(二):GIC 中断控制器

我们重点要看肯定是中间 GIC 部分,GIC 将众多中断源分为 分为三类: ①、SPI(Shared Peripheral Interrupt),共享外设中断,该中断来自于外设,所有 Core 共享中断...中断源有很多,为了区分这些不同中断源肯定要给他们分配一个唯一 ID,这些 ID 就是中断 ID。...分发器收集所有的中断源,可以控制每个中断优先级,它总是将优先级最高中断事件发送到 CPU 接口端。分发器端要做主要 工作如下: ①、全局中断使能控制。 ②、控制每一个中断使能或者关闭。...③、设置每个中断优先级。 ④、设置每个中断目标处理器列表。 ⑤、设置每个外部中断触发模式:电平触发或边沿触发。 ⑥、设置每个中断属于组 0 还是组 1。...寄存器分布,不同东西寄存器开头不一样: GIC-v 3中断号规定如下,来源于ARM官方文档。 最主要区别就是增加了 LPI 这个中断类型,是基于消息中断

5.5K20

Linux BSP实战课(中断篇):中断控制器硬件实现

中断在系统中作用 中断机制在处理器中扮演着一个至关重要角色,它是处理器异步响应外围设备请求核心方式。...从技术深层次来看,中断是处理器在正常运行过程中,因外部或内部事件(如外围设备输入/输出请求、异常错误等)而暂时中断当前执行程序,转而执行特定中断服务程序(Interrupt Service Routine...系统调度是操作系统根据一定策略选择下一个要执行进程或线程过程。当中断发生时,处理器可能会根据中断类型和优先级来决定是否切换当前执行上下文,从而实现任务快速切换和调度。...SPI (Shared Peripheral Interrupt):公用外部设备中断,也定义为共享中断中断产生后,可以分发到某一个CPU上。比如按键触发一个中断,手机触摸屏触发中断。...LPI 始终是基于消息中断,它们配置保存在表中而不是寄存器。比如 PCIe MSI/MSI-x 中断

15210

Linux中断系统如何调用详解

Linux中,当阻塞于某个慢系统调用进程捕获一个信号,则该系统调用就会被中断,转而执行信号处理函数,这就是被中断系统调用。...,函数将返回失败,同时errno被置为EINTR 只有中断信号SA_RESTART标志有效时,系统调用才会自动重启 下面我们编写代码,分别验证上述几种情形,其中系统调用选择read,中断信号选择SIGALRM...,中断信号由alarm产生。...//act.sa_flag |= SA_INTERRUPT; //SA_INTERRUPT是sigaction默认处理方式,即不自动重启被中断系统调用 //实际上,不管act.sa_flags...由于对被中断系统调用处理方式差异性,因此对应用程序来说,与被中断系统调用相关问题是: 应用程序无法保证总是知道信号处理函数注册方式,以及是否设置了SA_RESTART标志 可移植代码必须显式处理关键函数出错返回

2.5K10

Linux中断机制:硬件处理,初始化和中断处理

来源: CSDN | phenix_lord专栏 硬件处理 最近解决一个关于Linux中断问题,把相关机制整理了一遍,记录在此。...不同外部设备、不同体系结构、不同OS其中断实现机制都有差别,本文对应OS为linux3.4版本,外部设备为PCI设备、系统为X86。...对应I/O APIC和local APIC组合,其连接方式见下图 ? 针对X86中断控制器硬件和linux对这些硬件初始化,在《interrupt in linux》中有很详细描述。...中断执行CPU 通过中断初始化过程我们知道:中断在那个CPU上执行,取决于在那个CPU上申请了vector并配置了对应中断控制器(比如local APIC)。...如果想要改变一个中断执行CPU,必须重新申请vector并配置中断控制器。

7.7K30

Linux 中断子系统(三):中断处理知识点大全

更多介绍请参看 Linux 内核源代码自带文档:linux-4.14/Documentation/IRQ-affinity.txt /proc/irq/{IRQ}/smp_affinity /proc...Linux 抢占机制 GIC 中断控制器支持中断优先级抢占,一个高优先级中断可以抢占一个低优先级且处于active状态中断,即GIC仲裁单元会记录和比较当前优先级最高pending状态,然后去抢占当前中断...所以 Linux 下: 1、高优先级中断无法抢占正在执行低优先级中断。 2、同处于 pending 状态中断,优先响应高优先级中断进行处理。...如果低优先级中断处于 active 状态,是不可以被抢占,这是前后关系。抢占只存在于同时是pending 状态时候。 Linux 为什么中断不允许休眠?...对于这类中断linux kernel有一套复杂机制来处理,你可以通过command line参数(noirqdebug)来控制开关该功能。

4.7K20

Linux中断下半部实现机制

中断上、下半部产生背景 由于内核中中断不允许嵌套,在程序进入中断后,系统会关闭中断接收,这段时间内,其他中断都无法处理导致中断无法响应,因此需要当前进入中断子服务函数越快越好。...但是在一些特殊情况下,中断要处理事情可能是复杂且冗长,为解决这种问题, 中断上下半部概念顺势而生。将中断拆成两部分,上半部用来处理紧急事情;下半部用来处理不紧急事情。 2....tasklet是以软中断形式实现,软中断优先级仅次于硬件中断,在进入软件中断时,硬件中断会被打开,因此软件中断可被硬件中断打断。 使用: 软中断实现服务子函数,优先级高,影响系统执行效率。 a....在退出函数,销毁: tasklet_kill(&kpd_keymap_tasklet); (2) 工作队列方式: 在tasklet方式中,虽然开中断了,期间可处理系统各种中断,但是软中断优先级也会导致其他线程无法运行...(3) 线程中断:由于工作队列每次只能处理一个中断下半部,但是内核支持多线程,因此出现为每一个中断下半部开辟一个线程处理。将多个中断下半部线程分配给多个CPU上执行,提高效率。

3.1K10
领券