1.. include:: ../../disclaimer-zh_CN.rst 2 3:Original: :doc:`../../../../core-api/irq/irq-affinity` 4:Translator: Yanteng Si <siyanteng@loongson.cn> 5 6.. _cn_irq-affinity.rst: 7 8 9============== 10SMP IRQ 亲和性 11============== 12 13变更记录: 14 - 作者:最初由Ingo Molnar <mingo@redhat.com>开始撰写 15 - 后期更新维护: Max Krasnyansky <maxk@qualcomm.com> 16 17 18/proc/irq/IRQ#/smp_affinity和/proc/irq/IRQ#/smp_affinity_list指定了哪些CPU能 19够关联到一个给定的IRQ源,这两个文件包含了这些指定cpu的cpu位掩码(smp_affinity)和cpu列 20表(smp_affinity_list)。它不允许关闭所有CPU, 同时如果IRQ控制器不支持中断请求亲和 21(IRQ affinity),那么所有cpu的默认值将保持不变(即关联到所有CPU). 22 23/proc/irq/default_smp_affinity指明了适用于所有非激活IRQ的默认亲和性掩码。一旦IRQ被 24分配/激活,它的亲和位掩码将被设置为默认掩码。然后可以如上所述改变它。默认掩码是0xffffffff。 25 26下面是一个先将IRQ44(eth1)限制在CPU0-3上,然后限制在CPU4-7上的例子(这是一个8CPU的SMP box) 27 28:: 29 30 [root@moon 44]# cd /proc/irq/44 31 [root@moon 44]# cat smp_affinity 32 ffffffff 33 34 [root@moon 44]# echo 0f > smp_affinity 35 [root@moon 44]# cat smp_affinity 36 0000000f 37 [root@moon 44]# ping -f h 38 PING hell (195.4.7.3): 56 data bytes 39 ... 40 --- hell ping statistics --- 41 6029 packets transmitted, 6027 packets received, 0% packet loss 42 round-trip min/avg/max = 0.1/0.1/0.4 ms 43 [root@moon 44]# cat /proc/interrupts | grep 'CPU\|44:' 44 CPU0 CPU1 CPU2 CPU3 CPU4 CPU5 CPU6 CPU7 45 44: 1068 1785 1785 1783 0 0 0 0 IO-APIC-level eth1 46 47从上面一行可以看出,IRQ44只传递给前四个处理器(0-3)。 48现在让我们把这个IRQ限制在CPU(4-7)。 49 50:: 51 52 [root@moon 44]# echo f0 > smp_affinity 53 [root@moon 44]# cat smp_affinity 54 000000f0 55 [root@moon 44]# ping -f h 56 PING hell (195.4.7.3): 56 data bytes 57 .. 58 --- hell ping statistics --- 59 2779 packets transmitted, 2777 packets received, 0% packet loss 60 round-trip min/avg/max = 0.1/0.5/585.4 ms 61 [root@moon 44]# cat /proc/interrupts | 'CPU\|44:' 62 CPU0 CPU1 CPU2 CPU3 CPU4 CPU5 CPU6 CPU7 63 44: 1068 1785 1785 1783 1784 1069 1070 1069 IO-APIC-level eth1 64 65这次IRQ44只传递给最后四个处理器。 66即CPU0-3的计数器没有变化。 67 68下面是一个将相同的irq(44)限制在cpus 1024到1031的例子 69 70:: 71 72 [root@moon 44]# echo 1024-1031 > smp_affinity_list 73 [root@moon 44]# cat smp_affinity_list 74 1024-1031 75 76需要注意的是,如果要用位掩码来做这件事,就需要32个为0的位掩码来追踪其相关的一个。 77