I rebuilt the latest Fedora 2 kernel update to enable
preempt and
IO-APIC. I'm not yet sure about preempt, but IO-APIC has been
acting weird.
It gave me more interrupts (up to 21 instead of 15), but the devices
were distributed suboptimal.
How odd. Usually with a real APIC, the interrupts get distributed so they
are uniquely assigned to devices.
Maybe your BIOS is weird, or maybe it needs a "Reset PnP data", or the
"PnP
OS Installed" option set to OFF.
Without APIC, the nvidia module was alone on its own
interrupt, the
EMU10K1 was alone, the ide and eth modules were on separate interrupts,
etc. Quite ok.
Sounds like you didn't have a problem to fix. Why did you enable APIC? On
most of my systems with real APICs, I don't get a unique assignment of IRQs
unless I enable APIC support.
Note! ACPI eats an IRQ (9) almost always.
BTW, anyone has any measurements on how bad it is to
put essential
devices on the same interrupt? (in terms of xruns)
It's not the "really bad thing" it used to be, however it does take
additional time to determine the source of the interrupt. PCI was designed
around a model where IRQ sharing was an important part of the spec. It's
not the total-brokenness in the way ISA-era IRQ conflicts were.
Keep in mind also, that the IRQ priority is a bit strange. It goes (from
highest to lowest priority):
0,1,2(9),10,11,12,13,14,15,3,4,5,6,7,8
IRQ 2 is exactly the same as IRQ 9. In an 8-bit ISA card, it would termed
2, and in a 16-bit ISA/PCI slot it's 9.
Ideally, you want the least-latency-sensitive devices on the lower priority
interrupts and the most latency-sensitive on the higher priority interrupts.
Low-latency linux kernels generally get "out" of top-halves of their
interrupt handlers pretty quickly, thus allowed the servicing of another IRQ
pretty quickly.
=MB=
--
A focus on Quality.