📄 io-apic.txt
字号:
Most (all) Intel-MP compliant SMP boards have the so-called 'IO-APIC',which is an enhanced interrupt controller, it enables us to routehardware interrupts to multiple CPUs, or to CPU groups.Linux supports all variants of compliant SMP boards, including ones withmultiple IO-APICs. (multiple IO-APICs are used in high-end servers todistribute IRQ load further).There are (a few) known breakages in certain older boards, which bugs areusually worked around by the kernel. If your MP-compliant SMP board doesnot boot Linux, then consult the linux-smp mailing list archives first.If your box boots fine with enabled IO-APIC IRQs, then your/proc/interrupts will look like this one: ----------------------------> hell:~> cat /proc/interrupts CPU0 0: 1360293 IO-APIC-edge timer 1: 4 IO-APIC-edge keyboard 2: 0 XT-PIC cascade 13: 1 XT-PIC fpu 14: 1448 IO-APIC-edge ide0 16: 28232 IO-APIC-level Intel EtherExpress Pro 10/100 Ethernet 17: 51304 IO-APIC-level eth0 NMI: 0 ERR: 0 hell:~> <----------------------------some interrupts are still listed as 'XT PIC', but this is not a problem,none of those IRQ sources is performance-critical.in the unlikely case that your board does not create a working mp-table,you can use the pirq= boot parameter to 'hand-construct' IRQ entries. Thisis nontrivial though and cannot be automated. One sample /etc/lilo.confentry: append="pirq=15,11,10"the actual numbers depend on your system, on your PCI cards and on theirPCI slot position. Usually PCI slots are 'daisy chained' before they areconnected to the PCI chipset IRQ routing facility (the incoming PIRQ1-4lines): ,-. ,-. ,-. ,-. ,-. PIRQ4 ----| |-. ,-| |-. ,-| |-. ,-| |--------| | |S| \ / |S| \ / |S| \ / |S| |S| PIRQ3 ----|l|-. `/---|l|-. `/---|l|-. `/---|l|--------|l| |o| \/ |o| \/ |o| \/ |o| |o| PIRQ2 ----|t|-./`----|t|-./`----|t|-./`----|t|--------|t| |1| /\ |2| /\ |3| /\ |4| |5| PIRQ1 ----| |- `----| |- `----| |- `----| |--------| | `-' `-' `-' `-' `-'every PCI card emits a PCI IRQ, which can be INTA,INTB,INTC,INTD: ,-. INTD--| | |S| INTC--|l| |o| INTB--|t| |x| INTA--| | `-'These INTA-D PCI IRQs are always 'local to the card', their real meaningdepends on which slot they are in. If you look at the daisy chaining diagram,a card in slot4, issuing INTA IRQ, it will end up as a signal on PIRQ2 ofthe PCI chipset. Most cards issue INTA, this creates optimal distributionbetween the PIRQ lines. (distributing IRQ sources properly is not anecessity, PCI IRQs can be shared at will, but it's a good for performanceto have non shared interrupts). Slot5 should be used for videocards, theydo not use interrupts normally, thus they are not daisy chained either.so if you have your SCSI card (IRQ11) in Slot1, Tulip card (IRQ9) inSlot2, then you'll have to specify this pirq= line: append="pirq=11,9"the following script tries to figure out such a default pirq= line fromyour PCI configuration: echo -n pirq=; echo `scanpci | grep T_L | cut -c56-` | sed 's/ /,/g'note that this script wont work if you have skipped a few slots or if yourboard does not do default daisy-chaining. (or the IO-APIC has the PIRQ pinsconnected in some strange way). E.g. if in the above case you have your SCSIcard (IRQ11) in Slot3, and have Slot1 empty: append="pirq=0,9,11"[value '0' is a generic 'placeholder', reserved for empty (or non-IRQ emitting)slots.]generally, it's always possible to find out the correct pirq= settings, justpermute all IRQ numbers properly ... it will take some time though. An'incorrect' pirq line will cause the booting process to hang, or a devicewon't function properly (if it's inserted as eg. a module).If you have 2 PCI buses, then you can use up to 8 pirq values. Although suchboards tend to have a good configuration.Be prepared that it might happen that you need some strange pirq line: append="pirq=0,0,0,0,0,0,9,11"use smart try-and-err techniques to find out the correct pirq line ...good luck and mail to linux-smp@vger.kernel.org orlinux-kernel@vger.kernel.org if you have any problems that are not coveredby this document.-- mingo
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -