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

Linux 中断机制分析

中断分析最近工作繁忙,没有时间总结内核相关的一些东西。上次更新博客到了linux内核中断子系统。这次总结一下中断,也就是softirq。之后还会总结一些tasklet、工作队列机制。...这样的后果会造成有可能丢失外部中断。于是,linux内核设计出了一种架构,中断函数需要处理的任务分为两部分,一部分在中断处理函数中执行,这时系统关闭中断。...只有在进入了中断处理过程中之后才会开启硬件中断,如果在软件中断处理过程中有硬件中断嵌套,也不会再次调用中断,because硬件中断是软件中断处理过程中再次进入的,此时preempt_count已经记录了软件中断...Linux内核就中断方面就必须考虑平衡这三个方面的问题。而下面我要分析的__do_softirq函数就恰似在这三者之间打太极,游刃有余,面面俱到!...重新设置中断标记为0,set_softirq_pending重新设置中断标记为0,这样在之后重新开启中断之后硬件中断中又可以设置软件中断位。 7. 开启硬件中断 8.

8.6K91

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

linux为了实现这个特点,当中断发生的时候,硬中断处理那些短时间就可以完成的工作,而将那些处理事件比较长的工作,放到中断之后来完成,也就是中断(softirq)来完成。...(3)中断嵌套 Linux下硬中断是可以嵌套的,但是没有优先级的概念,也就是说任何一个新的中断都可以打断正在执行的中断,但同种中断除外。中断不能嵌套,但相同类型的中断可以在不同CPU上并行执行。...(4)中断指令 int是中断指令。 中断向量表是中断号和中断处理函数地址的对应表。 int n -- 触发软中断n。相应的中断处理函数的地址为:中断向量表地址 + 4 * n。...(5)硬中断中断的区别 中断是执行中断指令产生的,而硬中断是由外设引发的。 硬中断中断号是由中断控制器提供的,中断中断号由指令直接指出,无需使用中断控制器。...但一个中断不会抢占另一个中断,唯一可以抢占中断的是硬中断

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

中断中断_中断和硬中断的优先级

linux为了实现这个特点,当中断发生的时候,硬中断处理那些短时间 就可以完成的工作,而将那些处理事件比较长的工作,放到中断之后来完成,也就是中断(softirq)来完成。...(3) 中断嵌套 Linux下硬中断是可以嵌套的,但是没有优先级的概念,也就是说任何一个新的中断都可以打断正在执行的中断,但同种中断 除外。...中断不能嵌套,但相同类型的中断可以在不同CPU上并行执行。 (4) 中断指令 int是中断指令。 中断向量表是中断号和中断处理函数地址的对应表。 int n – 触发软中断n。...硬中断中断号是由中断控制器提供的,中断中断号由指令直接指出,无需使用中断控制器。 硬中断是可屏蔽的,中断不可屏蔽。...但一个中断不会抢占另一个中断,唯一可以抢占中断的是硬中断

2.6K40

Linux内核22-中断和tasklet

这对于时间苛刻的应用来说,这是一个很重要的属性,尤其是那些要求中断请求必须在毫秒级别响应的应用。 Linux2.6内核使用两种手段满足这项挑战:中断和tasklet,还有工作队列。...2 中断 Linux2.6内核中,中断的数量比较少。对于多数目的,这些tasklet足够了。因为不需要考虑重入,所以简单易用。...事实上,只使用了6类中断,如下表所示: 表4-9 Linux2.6中使用中断 中断 优先级 描述 HI_SOFTIRQ 0 处理高优先级的tasklet TIMER_SOFTIRQ 1 定时器中断...Linux中断处理程序总是从索引0开始执行。 2.1 中断使用的数据结构 中断的主要数据结构是softirq_vec数组,包含类型为softirq_action的32个元素。...这在Linux内核中是禁止的,因为其可延时函数的执行都是串行的。所以,在此需要禁止中断。 清除正在执行的中断对应掩码位。 执行local_irq_enable()使能中断

1.4K30

linux | 网络数据包softirq 中断与CPU

Linux 在每个 CPU 上会创建一个 ksoftirqd 内核线程。 softirqs 是在 Linux 内核编译时就确定好的,例如网络收包对应的 NET_RX_SOFTIRQ 中断。...-5.15.4/net/core/dev.c 注册网卡收发包(RX/TX)中断处理函数 open_softirq(NET_TX_SOFTIRQ, net_tx_action); open_softirq...硬中断是昂贵的,因为它们不能被中断。即使有中断 合并(稍后详细描述),中断处理程序将独占一个 CPU 内核 完全地。NAPI 的设计允许驱动程序进入轮询模式而不是被 为每个需要的数据包接收硬中断。...在正常操作下,会引发初始硬中断或 IRQ,然后是 SoftIRQ 处理程序 它使用 NAPI 例程轮询卡。轮询例程有一个预算,它决定了 允许代码的 CPU 时间。.../about-linux-smp_affinity https://web.archive.org/web/20200225050436/http://blog.yufeng.info/archives

2.6K20

中断和实时性

中断和实时性 翻译自:Software interrupts and realtime Linux内核的中断("softirq")机制有些奇怪,在早期的Linux和处理机制下比较晦涩,且仅有极少的内核开发人员会直接接触中断...在很早以前,Linux存在32个硬中断向量,并为每个向量分配一个设备驱动或相关的任务。...大部分驱动在很早以前就已经跟中断分进行了分离(驱动仍然会使用中断,但需要通过中间APIs,如tasklets和timers)。...但有一种例外:由硬中断引发的中断不能使用这种方式处理。由于无法将硬中断与一个特定的线程进行关联,因此不能使用对应的线程做必要的处理。这种情况下会将这些中断交给ksoftirqd 进程处理。...参考: Linux中断 - softirq

2.1K20

linux mysql 连接_linux 连接的使用

连接是linux中一个常用命令,它的功能是为某一个文件在另外一个位置建立一个同不的链接。 具体用法是:ln -s 源文件 目标文件。...在Linux的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号(Inode Index)。在Linux中,多个文件名指向同一索引节点是存在的。一般这种连接就是硬连接。...【连接】 另外一种连接称之为符号连接(Symbolic Link),也叫连接。链接文件有类似于Windows的快捷方式。它实际上是一个特殊的文件。...使用方式 创建链接 ln -s [源文件或目录] [目标文件或目录] 例: 当前路径创建test 引向/var/www/test 文件夹 ln –s /var/www/test test 创建/...var/test 引向/var/www/test 文件夹 ln –s /var/www/test /var/test 删除链接 和删除普通的文件是一样的,删除都是使用rm来进行操作 例: 删除test

12.1K30

中断通信简介

中断通信简介中断通信是进程间通信的一种常见方式,它基于信号机制,允许不同进程之间进行通信。在中断通信中,一个进程向另一个进程发送特定的信号,接收进程捕获信号并执行相应的处理。...中断通信的实现步骤如下:信号发送:发送进程使用kill()函数向接收进程发送信号,信号类型可以自行指定。...信号接收:接收进程可以通过signal()函数注册对应信号的处理函数,或者使用类似函数指定对应信号的处理方式。...signal()函数概述signal()函数是UNIX/Linux系统中用于注册信号处理程序的系统调用。...\n"); while (1) { // Process operations } return 0;}SIG_IGN使用使用SIG_IGN参数可以忽略特定信号,使得程序不受其影响

13310

进程通信 中断 signal()解读

中断通信 进程间通信方式有多种,其中中断通信是一种常见的方式,它基于信号机制,可以在不同进程之间进行通信。...中断通信的实现方式是,一个进程向另一个进程发送一个特定的信号,该信号被接收进程捕获,并进行相应的处理。...中断通信的步骤如下: 1)发送进程通过kill()函数向接收进程发送信号,信号类型可以自行指定。...需要注意的是,中断通信是一种异步通信方式,即发送进程和接收进程之间并不存在直接的同步机制。...因此,在设计使用中断通信的系统时,需要充分考虑这种异步机制所带来的影响。 signal() 概述 signal()函数是UNIX/Linux中的一个系统调用,用于注册信号处理程序。

18030

中断通信及signal()解读

中断通信 进程间通信方式有多种,其中中断通信是一种常见的方式,它基于信号机制,可以在不同进程之间进行通信。...中断通信的实现方式是,一个进程向另一个进程发送一个特定的信号,该信号被接收进程捕获,并进行相应的处理。...中断通信的步骤如下: 1)发送进程通过kill()函数向接收进程发送信号,信号类型可以自行指定。...需要注意的是,中断通信是一种异步通信方式,即发送进程和接收进程之间并不存在直接的同步机制。...因此,在设计使用中断通信的系统时,需要充分考虑这种异步机制所带来的影响。 signal() 概述 signal()函数是UNIX/Linux中的一个系统调用,用于注册信号处理程序。

34820

CPU中断概念与案例

# 注:如果你在实践过程中现象不明显,可以尝试把 100 调小,比如调成 10 甚至 1 $ hping3 -S -p 80 -i u1 xxx.xxx.xxx.xxx 1.2 分析过程 1、CPU使用率不高但是中断已经到了...2 概念 2.1 中断概念 linux中断会打断CPU当前的工作,中断一般都设计的短小精悍。...但是也为了解决中断处理程序执行时间过长和中断丢失的问题,Linux中断分为两个阶段: 上半部用来快速处理中断,它在中断禁止模式下运行,主要处理硬件相关和时间敏感的工作 下半部用来延迟处理上半部未完成的工作...不过要注意的是,中断不只包括了刚刚所讲的硬件设备中断处理程序的下半部,一些内核自定义的事件也属于中断,比如内核调度和RCU 锁(Read-Copy Update 的缩写,RCU是 Linux 内核中最常用的锁之一...另外,刚刚提到过,中断实际上是以内核线程的方式运行的,每个 CPU 都对应一个中断内核线程,这个中断内核线程就叫做 ksoftirqd/CPU 编号。那要怎么查看这些线程的运行状况呢?

1.4K20

中断会吃掉你多少CPU?

我们没必要啃明白中断的所有原理,但从一名追求性能的开发者的角度来看,我们有必要了解以下问题: 1、一次中断的开销到底多大? 2、你的服务器上被中断吃掉了多少CPU时间?...所以现代的Linux又发明了软件中断,配合硬中断来处理网络IO。硬中断你可以理解只是个收包的,把包收取回来放到“家里”就完事,很快就能完成,这样不耽误CPU响应其它外部高优先级的中断。...中断消耗的CPU周期相对比硬中断要多不少,所以我们本文来重点关注中断的开销。 2 中断的开销估算 前面大致介绍了中断的来龙去脉,好了直接进入本文的主题上,中断开销到底多大。...让我们将他们进行一个简单的对比: 1)和系统调用开销对比 《深入理解Linux内核-第五章》开头的一句话,很形象地把中断和系统调用两个不相关的概念联系了起来,巧妙地找到了这二者之间的相似处。...大家感兴趣的,可以继续阅读《深入理解Linux内核》的-第五章。 根据前文的实验结果,进程上下文切换开销是3us-5us。

1.3K20

记录一个中断问题

前些天发现XEN虚拟机上的Nginx服务器存在一个问题:中断过高,而且大部分都集中在同一个CPU,一旦系统繁忙,此CPU就会成为木桶的短板。...在问题服务器上运行「top」命令可以很明显看到「si」存在异样,大部分中断都集中在 1 号CPU上,其它的CPU完全使不上劲儿: shell> top Cpu0: 11.3%us, 4.7%sy,...说明:如果希望多个CPU参与中断处理的话,可以使用类似下面的语法: echo 3,5 > /proc/irq/45/smp_affinity_list echo 0-7 > /proc/irq/45/smp_affinity_list...好消息是Linux支持RPS,通俗点来说就是在软件层面模拟实现硬件的多队列网卡功能。...最后,推荐看看香草总结的一些关于中断方面的资料和工具,很全面。

75230

Linux内核中的中断、tasklet和工作队列具体解释

引言 中断、tasklet和工作队列并非Linux内核中一直存在的机制,而是由更早版本号的内核中的“下半部”(bottom half)演变而来。 下半部的机制实际上包含五种,但2.6版本号的内核中。...所以中断必须设计为可重入的函数(同意多个CPU同一时候操作),因此也须要使用自旋锁来保其数据结构。...系统使用I/O APIC,在处理完本地时钟中断时。 local_bh_enable,即开启本地中断时。 SMP系统中。...因此假设不须要中断的并行特性,tasklet就是最好的选择。也就是说tasklet是中断的一种特殊使用方法。即延迟情况下的串行运行。...当中断处理运行时, 它处理高优先级 tasklet 在其它中断之前,仅仅有具有低响应周期要求的驱动才应使用这个函数, 可避免其它软件中断处理引入的附加周期. tasklet_kill(struct

1.9K30

Linux中断处理

中断处理 - 上半部(硬中断) 由于 APIC中断控制器 有点小复杂,所以本文主要通过 8259A中断控制器 来介绍Linux中断的处理过程。...中断处理 - 下半部(中断) 由于中断处理一般在关闭中断的情况下执行,所以中断处理不能太耗时,否则后续发生的中断就不能实时地被处理。...鉴于这个原因,Linux中断处理分为两个部分,上半部 和 下半部,上半部 在前面已经介绍过,接下来就介绍一下 下半部 的执行。...softirq机制 中断下半部 由 softirq(中断) 机制来实现的,在Linux内核中,有一个名为 softirq_vec 的数组,如下: static struct softirq_action...NET_TX_SOFTIRQ 和 NET_RX_SOFTIRQ 特定用于网络子模块的中断(不作介绍)。

6.6K20

Linux中断 - IDT

中断描述符项定义 当中断发生,cpu获取到中断向量后,查找IDT中断描述符表得到相应的中断描述符,再根据中断描述符记录的信息来作权限判断,运行级别转换,最终调用相应的中断处理程序; 这里涉及到Linux...pre-cpu的中断栈,还是使用IST的中断栈; type表示所中断是何种类型,目前有以下四种: enum { GATE_INTERRUPT = 0xE, //中断门 GATE_TRAP...中断门, DPL = 0 只能从内核态调用,使用TSS.IST[]作为中断栈 */ #define ISTG(_vector, _addr, _ist) \ G(_vector...传统系统调用的实现 这里所说的传统系统调用主要指旧的32位系统使用 int 0x80软件中断来进入内核态,实现的系统调用。...硬件中断相关IDT的初始化也是在Linux启动时完成,在start_kernel中通过调用init_IRQ完成,我们来看一下: void __init init_IRQ(void) { int

6.5K10

点个外卖,我把「中断」搞懂了

---- 如何定位中断 CPU 使用率过高的问题? 要想知道当前的系统的中断情况,我们可以使用 top 命令查看,下面是一台服务器上的 top 的数据: ?...上图中的黄色部分 si,就是 CPU 在中断上的使用率,而且可以发现,每个 CPU 使用率都不高,两个 CPU 的使用率虽然只有 3% 和 4% 左右,但是都是用在中断上了。...---- 总结 为了避免由于中断处理程序执行时间过长,而影响正常进程的调度,Linux中断处理程序分为上半部和下半部: 上半部,对应硬中断,由硬件触发中断,用来快速处理中断; 下半部,对应中断,...由内核触发中断,用来异步处理上半部未完成的工作; Linux 中的中断包括网络收发、定时、调度、RCU 锁等各种类型,可以通过查看 /proc/softirqs 来观察中断的累计中断次数情况,如果要实时查看中断次数的变化率...如果在 top 命令发现,CPU 在中断上的使用率比较高,而且 CPU 使用率最高的进程也是中断 ksoftirqd 的时候,这种一般可以认为系统的开销被中断占据了。

1.2K31
领券