- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试了解 Linux 内核中的 NAPI 实现。这些是我的基本疑惑。
1) NAPI 禁用进一步的中断并使用轮询处理 skbs
中断处理程序是否应该禁用它?
如果是 - 禁用中断和处理实际轮询完成的 SOFTIRQ net_rx_action 之间的时间间隔是不是太多了。
2) 默认情况下,所有启用 NAPI 的驱动程序在接收到单个帧时会禁用中断并使用下半部分的轮询处理剩余的帧?还是只有当帧数 > 32(在 irq 处理程序中连续接收所有帧)时才切换到轮询模式?
3) 现在共享 IRQ -
最佳答案
我写了一份综合指南understanding, tuning, and optimizing the Linux network stack其中解释了有关网络驱动程序、NAPI 等的所有内容,因此请查看。
就您的问题而言:
设备 IRQ 应该在启用 NAPI 后由驱动程序的 IRQ 处理程序禁用。是的,有时间间隔,但应该很小。这是您必须做出的权衡决定的一部分:您更关心吞吐量还是延迟?根据具体情况,您可以适当优化网络堆栈。在任何情况下,大多数 NIC 都允许用户增加(或减少)用于跟踪传入网络数据的环形缓冲区的大小。因此,暂停是可以的,因为数据包只会排队等待稍后处理。
这取决于驱动程序,但一般来说,大多数驱动程序都会在 IRQ 处理程序中启用 NAPI 轮询模式,一旦它被触发(通常)调用 napi_schedule
。您可以找到有关如何 NAPI is enabled for the Intel igb driver here. 的演练。请注意,IRQ 处理程序不一定会针对每个数据包触发。您可以使用称为 interrupt coalescing 的功能调整大多数卡上 IRQ 处理程序的触发速率。 .某些 NIC 可能不支持此选项。
其他设备的 IRQ 处理程序将在 IRQ 触发时执行,因为 IRQ 处理程序在 CPU 上具有非常高的优先级。 NAPI 轮询循环(在 SoftIRQ 中运行)将在处理设备 IRQ 的任何 CPU 上运行。因此,如果您有多个 NIC 和多个 CPU,您可以调整每个 NIC 的 IRQ 的 IRQ 亲和性,以防止特定 NIC 饿死。
关于您在评论中提到的例子:
say NIC 1 and NIC 2 share IRQ line , lets assume NIC 1 is low load , NIC 2 high load and NIC 1 receives interrupt, driver of NIC 1 would disable interrupt until it's softirq is handled , say that time gap as t1 . So for time t1 NIC 2 interrupts are too disabled, right?
这取决于驱动程序,但在正常情况下,NIC 1 仅在执行 IRQ 处理程序时禁用中断。对 napi_schedule
的调用告诉 softirq 代码它应该开始运行,如果它还没有开始的话。 softirq 代码异步运行,因此没有 NIC 1 不等待 softirq 被处理。
现在,就共享 IRQ 而言:再次取决于设备和驱动程序。驱动程序应该以能够处理共享 IRQ 的方式编写。如果驱动程序禁用正在共享的 IRQ,则共享该 IRQ 的所有设备都不会接收中断。这会很糟糕。某些设备解决此问题的一种方法是允许驱动程序读取/写入特定寄存器,从而导致该特定设备停止生成中断。这是首选解决方案,因为它不会阻止其他设备生成相同的 IRQ。
当 NAPI 的 IRQ 被禁用时,这意味着驱动程序要求 NIC 硬件停止发送 IRQ。因此,同一行(对于其他设备)上的其他 IRQ 仍将继续处理。这是 Intel igb driver 如何实现的示例通过写入寄存器关闭该设备的 IRQ。
关于linux - NAPI 中断禁用和处理共享中断线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38607348/
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
Linux 管道可以缓冲多少数据?这是可配置的吗? 如果管道的两端在同一个进程中,但线程不同,这会有什么不同吗? 请注意:这个“同一个进程,两个线程”的问题是理论上的边栏,真正的问题是关于缓冲的。 最
我找到了here [最后一页] 一种有趣的通过 Linux 启动 Linux 的方法。不幸的是,它只是被提及,我在网上找不到任何有用的链接。那么有人听说过一种避免引导加载程序而使用 Linux 的方法
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我试图了解 ld-linux.so 如何在 Linux 上解析对版本化符号的引用。我有以下文件: 测试.c: void f(); int main() { f(); } a.c 和 b.c:
与 RetroPie 的工作原理类似,我可以使用 Linux 应用程序作为我的桌面环境吗?我实际上并不需要像实际桌面和安装应用程序这样的东西。我只需要一种干净简单的方法来在 RaspberryPi 上
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve thi
有什么方法可以覆盖现有的源代码,我应该用 PyQt、PyGTK、Java 等从头开始构建吗? 最佳答案 如果您指的是软件本身而不是它所连接的存储库,那么自定义应用程序的方法就是 fork 项目。据我所
我的情况是:我在一个磁盘上安装了两个 linux。我将第一个安装在/dev/sda1 中,然后在/dev/sda2 中安装第二个然后我运行第一个系统,我写了一个脚本来在第一个系统运行时更新它。
我在 i2c-0 总线上使用地址为 0x3f 的系统监视器设备。该设备在设备树中配置有 pmbus 驱动程序。 问题是,加载 linux 内核时,这个“Sysmon”设备没有供电。因此,当我在总线 0
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
我正试图在 linux 模块中分配一大块内存,而 kalloc 做不到。 我知道唯一的方法是使用 alloc_bootmem(unsigned long size) 但我只能从 linux 内核而不是
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我有 .sh 文件来运行应用程序。在该文件中,我想动态设置服务器名称,而不是每次都配置。 我尝试了以下方法,它在 CentOS 中运行良好。 nohup /voip/java/jdk1.8.0_71/
我是在 Linux 上开发嵌入式 C++ 程序的新手。我有我的 Debian 操作系统,我在其中开发和编译了我的 C++ 项目(一个简单的控制台进程)。 我想将我的应用程序放到另一个 Debian 操
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 4 年前。 Improve this ques
我使用4.19.78版本的稳定内核,我想找到带有企鹅二进制数据的C数组。系统启动时显示。我需要在哪里搜索该内容? 我在 include/linux/linux_logo.h 文件中只找到了一些 Log
我知道可以使用 gdb 的服务器模式远程调试代码,我知道可以调试针对另一种架构交叉编译的代码,但是是否可以更进一步,从远程调试 Linux 应用程序OS X 使用 gdbserver? 最佳答案 当然
是否有任何可能的方法来运行在另一个 Linux 上编译的二进制文件?我知道当然最简单的是在另一台机器上重建它,但假设我们唯一能得到的是一个二进制文件,那么这可能与否? (我知道这可能并不容易,但我只是
我是一名优秀的程序员,十分优秀!