• Linux:CPU中断绑定----计算 SMP IRQ Affinity


    “echo 2 > /proc/irq/33/smp_affinity” 中的 ”2“ 是怎么来的,这其实是个二进制数字,代表 00000010,00000001 代表 CPU0 的话,00000010 就代表 CPU1, “echo 2 > /proc/irq/33/smp_affinity” 的意思就是说把 33 中断绑定到 00000001(CPU0)上。所以各个 CPU 用二进制和十六进制表示就是:

    也就是说,Linux绑定CPU是通过掩码表示的,每个CPU对应1位,0表示关闭,1表示开启。

    如果想把 IRQ 绑定到 CPU2 上就是 00000100=4:

    echo "1" > /proc/irq/33/smp_affinity

     如果想把 IRQ 同时平衡到 CPU0 和 CPU2 上就是 00000001+00000100=00000101=5:

    echo "5" > /proc/irq/33/smp_affinity

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

    还有一个限制就是,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 处理。
       

  • 相关阅读:
    数字后端——DEF文件格式
    CF1899B 250 Thousand Tons of TNT
    遥遥领先的内存函数
    Mysql相关操作命令合集
    是否在业务中使用大语言模型?
    Java-网络编程(TCP-UDP)
    多媒体应用设计师 第1章 多媒体基础基础
    ShardingSphere数据分片
    Unity_彩色增强层级插件
    postgres 查看全部数据库
  • 原文地址:https://blog.csdn.net/hhd1988/article/details/126508274