CPU中断绑定——计算 SMP IRQ Affinity

计算 SMP IRQ Affinity

前天咱们讨论了如何绑定特定的硬件中断到特定的 CPU 上,分散和平衡各个中断到不一样的 CPU 上以获取更大性能的处理能力。上篇限于篇幅的关系,没有来得及进一步说明 “echo 2 > /proc/irq/90/smp_affinity” 中的 ”2“ 是怎么来的,这实际上是个二进制数字,表明 00000010,00000001 表明 CPU0 的话,00000010 就表明 CPU1, “echo 2 > /proc/irq/90/smp_affinity” 的意思就是说把 90 中断绑定到 00000010(CPU1)上。因此各个 CPU 用二进制和十六进制表示就是:post

               Binary       Hex 
    CPU 0    00000001         1 
    CPU 1    00000010         2
    CPU 2    00000100         4
    CPU 3    00001000         8

若是我想把 IRQ 绑定到 CPU2 上就是 00000100=4:性能

# echo "4" > /proc/irq/90/smp_affinity

若是我想把 IRQ 同时平衡到 CPU0 和 CPU2 上就是 00000001+00000100=00000101=5spa

# echo "5" > /proc/irq/90/smp_affinity

须要注意的是,在手动绑定 IRQ 到 CPU 以前须要先停掉 irqbalance 这个服务,irqbalance 是个服务进程、是用来自动绑定和平衡 IRQ 的:code

# /etc/init.d/irqbalance stop

还有一个限制就是,IO-APIC 有两种工做模式:logic 和 physical,在 logic 模式下 IO-APIC 能够同时分布同一种 IO 中断到8颗 CPU (core) 上(受到 bitmask 寄存器的限制,由于 bitmask 只有8位长。);在 physical 模式下不能同时分布同一中断到不一样 CPU 上,好比,不能让 eth0 中断同时由 CPU0 和 CPU1 处理,这个时候只能定位 eth0 到 CPU0、eth1 到 CPU1,也就是说 eth0 中断不能像 logic 模式那样能够同时由多个 CPU 处理。orm

相关文章
相关标签/搜索