Linux 中断聚合:提高性能与可靠性 (linux 中断聚合)

在现代计算机中,中断是处理器和外部设备之间的通信方式。设备需要与计算机交互时,会发送一个中断信号,将控制权移交给操作系统,由操作系统负责处理该中断并调用相应的设备驱动程序。而设备的中断处理程序,则可以在完成任务后将控制权返还回操作系统。

在 Linux 操作系统中,中断是一个非常重要的机制,对系统的性能和可靠性都有很大的影响。随着计算机系统的进一步发展和性能的提高,中断处理成为系统性能的瓶颈之一。为了提高系统的性能和可靠性,Linux 内核引入了中断聚合(Interrupt Aggregation)机制。本文将详细介绍 Linux 中断聚合的原理、实现和应用,以及其对系统性能和可靠性的影响。

一、中断聚合的原理和实现

中断聚合是将多个中断请求合并成一个,由操作系统一次性处理的一项技术。例如,多个网络包到达网络接口时,会产生多个网络中断请求,中断聚合将这些中断请求合并成一个,由操作系统一次性处理,从而减少了中断处理的次数,提高了系统的性能。中断聚合的基本原理是:将多个中断请求合并成一个,让一次中断处理可以同时处理多个请求。这需要对硬件和操作系统进行改造,以支持中断聚合机制。

在硬件层面上,中断聚合需要支持多个中断请求的排队和缓存,使多个中断请求可以以较小的存储空间暂存下来,等待一次性处理。在操作系统层面上,中断聚合需要有一个中断聚合引擎(Interrupt Coalescing Engine),负责将多个中断请求合并成一个,并将其交给操作系统处理。在 Linux 内核中,中断聚合的实现是通过软件层面的方式实现的,即使用了 NAPI(New API)机制。

NAPI 机制是 Linux 内核中一种高效的网络中断处理机制,通过合并和压缩网络中断请求,降低了 CPU 的中断处理负载。其基本原理是:在接受网络流量时,先将数据存入环形缓冲区中,当缓冲区满时,中断引擎会触发一次中断处理程序,并将缓冲的大块数据一次性处理。

二、中断聚合的应用和影响

中断聚合机制的应用领域不仅限于网络,还可以应用到存储系统、图形系统等领域。中断聚合可以大大减少中断的数量和中断处理的开销,提高了系统的性能和可靠性。相比传统的中断处理方式,中断聚合机制的性能提升可以达到 3 倍以上,且系统的吞吐量和响应时间也有所改善。

另外,中断聚合还具有降低 CPU 能耗的优点。中断聚合机制可以减少 CPU 的中断响应频率,因此可以延长 CPU 上下文切换的时间间隔,降低系统的功耗和温度。通过中断聚合技术,计算机系统的能效比可以提高几倍,极大地降低了系统的运行成本。

三、中断聚合的局限和解决方案

中断聚合机制虽然可以提高系统的性能和可靠性,但也存在一些局限性。由于中断聚合机制需要缓存和排队多个中断请求,因此会带来一定的延迟。特别是在低延迟和高吞吐量应用中,中断聚合的延迟可能会成为瓶颈。此外,在单核或低核心数的系统中,可能不够有效,因为中断聚合需要多核心的支持才能发挥其更佳性能。

为了解决这些局限性,可以采用多种局部调整和系统优化方案。例如,可以针对特定的应用和设备进行中断聚合优化,以降低延迟和提高吞吐量。还可以通过优化中断处理程序和中断代价的方式,来降低中断处理的负担和功耗。此外,可采用基于多核的聚合方案,来提高中断聚合的并发性和侧缘效应,以进一步提高性能和可靠性。

中断聚合是 Linux 操作系统中一个重要的功能,可有效提高系统的性能和可靠性。通过合并和压缩多个中断请求,中断聚合可以降低中断的数量和处理负载,提高计算机系统的吞吐量和响应时间。虽然中断聚合存在一些局限性,但通过合理的优化和系统设计,可以克服其局限,更大程度地发挥其优点。

相关问题拓展阅读:

Linux内核中断之获取中断号

Linux内核中可使用 platform_get_irq() 函数获取 dts 文吵灶件中设置的中断号。

函数原型: int platform_get_irq(struct platform_device *dev, unsigned int num)

定义文件: drivers\base\platform.c

中断号获取函数 platform_get_irq() 调用流程如盯知下:

rk3399 使用的是 GICv3 ,对应 irq_domain->name 。

文件: drivers/irqchip/irq-gic-v3.c 。

translate() 函数实现如下:

以 RockPI 4A 单板 Debian 系统Linux 4.4内核中的获取 HDMI 中断号为例。

1、查找中断号

从手册“Rockchip RK3399 TRM V1.3 Part1.pdf”中,可以查到 HDMI_IRQ 中断号,即55。

2、 dts 配置

文件: arch/arm64/boot/dts/rockchip/rk3399.dtsi

hdmi 使用的是 GIC_SPI 中断,按照 gic_irq_domain_translate() 函数中处理,需要将中断号55减去32,得到 dts 中的中断号23。

注: interrupts =

3、驱动函数

文凯碰消件: drivers\gpu\drm\rockchip\dw_hdmi-rockchip.c

此时, irq 返回值为55。

后续会介绍 GIC 和中断注册等实现函数。

linux应用层怎么select底层的中断

我也不完全理解,但是比你知道的多点。

Linux中,分内核态和用户态。

你写的所有的驱动,都是出于内核态->可以直接使用内核相关资源;

应用层,都是用户态->无法直接操作底层的东西 -> 想要操作,比如获得权限,切换到内核态,然后才能操作。

你这里的需求,我的理解是:

对应你这句

“在中断服务程序中操作另一个外设”

不知道你的目的和打算用的手段是啥

一般的,ISR中,操作别的设备,常见的是:

设置对应的(比如该硬件本身,或者别的设备B的)寄存器的对应的位,以便通知其某种事情发送或状态变化了。

然后设备B会:

要么是由于(被修改了寄存器而)发生了中断,然后可以接着处理其所要做的事情;

要么是一直轮训,检测对应的某种资源释放变化,比如上面被改的寄存器的对应的位,发现变化了,再去调用你的函数,做对应的处理。

注意:

中断,不论是哪个设备的中断,都不应该占用(CPU)太长时间

-> 导致别的中断或服务无法及时运行

关于linux 中断聚合的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » Linux 中断聚合:提高性能与可靠性 (linux 中断聚合)