【问题标题】:Is the maximum interrupt frequency for the linux kernel in Hz, kHz, MHz, or GHz?linux内核的最大中断频率是Hz、kHz、MHz还是GHz?
【发布时间】:2013-04-06 13:17:07
【问题描述】:

在我开始之前:是的,我知道答案是 architecture dependent - 我只是对一个大概的数字感兴趣,就数量级而言。

linux内核对中断频率有上限吗?

背景:我想在 Linux 中与摄像头模块交互。该模块有一个时钟并行数据输出(8 位,大约 650kHz),我想从中读取数据并将其存储在缓冲区中,以便通过例如 /dev/camera 访问。

我编写了一个基本驱动程序,它正在监视相应的中断线。如果我将一根电线挂在中断引脚上,我会因白噪声而中断。但是,如果我连接更高频率的信号(来自 555 定时器的 atm ~250kHz),则不会触发中断。 (我已经通过 /proc/interrupts 确认了这一点)

我的想法是,这可能是由于处理器上的 GPIO 模块无法处理如此高的频率(这很愚蠢 - 这不是特别高),也可能是内核问题。人们怎么看?

【问题讨论】:

    标签: linux linux-kernel interrupt


    【解决方案1】:

    这样看。现代 CPU 每秒执行大约 109 条指令。

    为了处理中断,您需要执行大约 100-1000 条指令(保存上下文、执行 I/O、中断处理结束信号、恢复上下文)。这会给你大约每秒 106 - 107 个中断。

    如果您将所有时间都花在处理中断上,那么系统和程序的其余部分将一无所有。

    因此,考虑 105 个中断/秒 (100 KHz) 是最大实际中断率。

    电路可能会施加其他限制,我对这方面不太熟悉。但是内核不太可能以某种方式明确限制中断率。我看不出有什么好的理由,我认为这也不是一件容易的事。

    现在,像 DMA 这样的东西可以让您在输入/输出数据的每个字节上都没有中断,而是在几千字节甚至兆字节的缓冲区上。例如。您准备好数据以在内存缓冲区中输出,并告诉 DMA 控制器它现在可以将其从缓冲区中发送出去。完成后,它将触发一个中断信号传输完成,您将能够启动另一个。它在另一个传输方向上的工作方式相同。当整个缓冲区被输入数据填满时,你会得到一个中断。

    如果您只能以较低的速率接收中断,我认为您可能会面临硬件限制。

    【讨论】:

    • 嗯,有了现代多核处理器,一个核心在中断处理后没有剩余时间也不是世界末日。
    • @BenVoigt 可能是。我知道,如果在 Windows Vista+ 上完成 DPC 的时间过长(这可能是由于大量中断处理造成的),系统就会蓝屏。
    • 碰巧,我相信你在这两个方面都是对的,@AlexeyFrunze。我摆弄了我芯片上的 GPIO 中断设置(文档很糟糕,看起来去抖动寄存器上的时钟实际上是主中断时钟),当我连接高频信号时,我可以可靠地挂起内核:P换句话说,内核 ISR 的开销似乎在 1k - 10k 指令范围内,因此最大速率为
    猜你喜欢
    • 2012-11-12
    • 1970-01-01
    • 2015-08-27
    • 2014-11-16
    • 2014-04-26
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多