Date: Tue, 23 Dec 2003 01:07:47 +0100 (CET) From: Barry Bouwsma <freebsd-misuser@remove-NOSPAM-to-reply.NOSPAM.dyndns.dk> To: Hackers Haven <freebsd-hackers@freebsd.org> Subject: pci_cfgintr: can't route an interrupt ... Message-ID: <200312230007.hBN07lr03615@NOSPAM.spam.NOSPAM.spam.NOSPAM.dyndns.dk>
next in thread | raw e-mail | index | archive | help
[Drop my IPv6-only address for any replies, or hostname-only for IPv4...] There was a thread about this in this list back in late may of 2003. I recently found a mainboard which exhibits this problem with one particular card I have -- a combi OHCI+EHCI USB card with firewire, and an on-card HiNT PCI-PCI bridge. This card worked mostly fine on a probably-older DEC Venturis machine. A roughly-same-age-as-the-found-board machine was tried before the boot- time interrupt storm was discovered and solved with -stable months ago, so I can't say how well it worked there. I can only quote from a NetBSD boot somewhat later in this message. I'm using FreeBSD-4 with hacked source from around September-ish right now, and here's part of the verbose boot on the ``new'' found machine that has this problem (166MHz Pentium)... bios32: Found BIOS32 Service Directory header at 0xc00fb950 bios32: Entry = 0xfbdd0 (c00fbdd0) Rev = 0 Len = 1 pcibios: PCI BIOS entry at 0xbe00 pnpbios: Found PnP BIOS data at 0xc00fcab0 pnpbios: Entry = f0000:cad8 Rev = 1.0 Other BIOS signatures found: ACPI: 00000000 [...] pcib1: <PCI to PCI bridge (vendor=3388 device=0021)> at device 10.0 on pci0 found-> vendor=0x1033, dev=0x0035, revid=0x41 class=0c-03-10, hdrtype=0x00, mfdev=1 subordinatebus=0 secondarybus=0 intpin=a, irq=12 map[10]: type 1, range 32, base d0000000, size 12 found-> vendor=0x1033, dev=0x0035, revid=0x41 class=0c-03-10, hdrtype=0x00, mfdev=0 subordinatebus=0 secondarybus=0 intpin=b, irq=255 map[10]: type 1, range 32, base d0001000, size 12 found-> vendor=0x1033, dev=0x00e0, revid=0x02 class=0c-03-20, hdrtype=0x00, mfdev=0 subordinatebus=0 secondarybus=0 intpin=c, irq=255 map[10]: type 1, range 32, base d0002000, size 8 found-> vendor=0x1106, dev=0x3044, revid=0x46 class=0c-00-10, hdrtype=0x00, mfdev=0 subordinatebus=0 secondarybus=0 intpin=a, irq=12 map[10]: type 1, range 32, base d0003000, size 11 map[14]: type 1, range 32, base 0000e000, size 7 pci1: <PCI bus> on pcib1 ohci0: <NEC uPD 9210 USB controller> mem 0xd0000000-0xd0000fff irq 12 at device 8.0 on pci1 using shared irq12. usb0: OHCI version 1.0 usb0: <NEC uPD 9210 USB controller> on ohci0 usb0: USB revision 1.0 uhub0: NEC OHCI root hub, class 9/0, rev 1.00/1.00, addr 1 uhub0: 3 ports with 3 removable, self powered [...] ohci1: <NEC uPD 9210 USB controller> mem 0xd0001000-0xd0001fff at device 8.1 on pci1 pci_cfgintr: can't route an interrupt to 1:8 INTB ohci1: Could not allocate irq device_probe_and_attach: ohci1 attach returned 6 pci1: <USB controller> (vendor=0x1033, dev=0x00e0) at 8.2 fwohci0: <VIA VT6306> port 0xe000-0xe07f mem 0xd0003000-0xd00037ff irq 12 at dev ice 11.0 on pci1 I'm able to use ohci0 as well as fwohci0; ohci1 and the ehci controller get irq=255 which -STABLE doesn't seem to be able to handle. On the other old machine, where it works, IRQs are assigned as shown: bios32: Found BIOS32 Service Directory header at 0xc00fff70 bios32: Entry = 0xfc716 (c00fc716) Rev = 0 Len = 1 pcibios: PCI BIOS entry at 0x246 pnpbios: Found PnP BIOS data at 0xc00f5870 pnpbios: Entry = f0000:ae95 Rev = 1.0 Other BIOS signatures found: ACPI: 00000000 [...] pcib1: <PCI to PCI bridge (vendor=3388 device=0021)> at device 11.0 on pci0 found-> vendor=0x1033, dev=0x0035, revid=0x41 class=0c-03-10, hdrtype=0x00, mfdev=1 subordinatebus=0 secondarybus=0 intpin=a, irq=11 map[10]: type 1, range 32, base fcfff000, size 12 found-> vendor=0x1033, dev=0x0035, revid=0x41 class=0c-03-10, hdrtype=0x00, mfdev=0 subordinatebus=0 secondarybus=0 intpin=b, irq=10 map[10]: type 1, range 32, base fcffe000, size 12 found-> vendor=0x1033, dev=0x00e0, revid=0x02 class=0c-03-20, hdrtype=0x00, mfdev=0 subordinatebus=0 secondarybus=0 intpin=c, irq=9 map[10]: type 1, range 32, base fcffdc00, size 8 found-> vendor=0x1106, dev=0x3044, revid=0x46 class=0c-00-10, hdrtype=0x00, mfdev=0 subordinatebus=0 secondarybus=0 intpin=a, irq=11 map[10]: type 1, range 32, base fcffd000, size 11 map[14]: type 1, range 32, base 0000fc80, size 7 pci1: <PCI bus> on pcib1 ohci0: <NEC uPD 9210 USB controller> mem 0xfcfff000-0xfcffffff irq 11 at device 8.0 on pci1 [...] ohci1: <NEC uPD 9210 USB controller> mem 0xfcffe000-0xfcffefff irq 10 at device 8.1 on pci1 ehci0: <NEC uPD 720100 USB 2.0 controller> mem 0xfcffdc00-0xfcffdcff irq 9 at de vice 8.2 on pci1 [...] fwohci0: <VIA VT6306> port 0xfc80-0xfcff mem 0xfcffd000-0xfcffd7ff irq 11 at dev ice 11.0 on pci1 using shared irq11. As I said, it appears to work without problem, though just before I swapped that old machine for the found board, I lost function of the USB mouse after many days of working flawlessly together with firewire disk activity, which problem I didn't bother to track down since it was the first time any such thing has happened to me. As I noted, I also tried this card under NetBSD many months ago on a motherboard of roughly the same vintage. Here's what NetBSD had to say at boot about it on that machine: BIOS32 rev. 0 found at 0xf8080 [...] ppb0 at pci0 dev 11 function 0: HiNT HB1 PCI-PCI Bridge (rev. 0x11) pci1 at ppb0 bus 1 pci1: i/o space, memory space enabled, rd/line, wr/inv ok ohci0 at pci1 dev 8 function 0: NEC USB Host Controller (rev. 0x41) ohci0: interrupting at irq 9 ohci0: OHCI version 1.0 usb at ohci0 not configured ohci1 at pci1 dev 8 function 1: NEC USB Host Controller (rev. 0x41) ohci1: interrupting at irq 9 ohci1: OHCI version 1.0 usb at ohci1 not configured ehci0 at pci1 dev 8 function 2: NEC USB Host Controller (rev. 0x02) ehci0: interrupting at irq 9 ehci0: EHCI version 0.95 ehci0: companion controllers, 3 ports each: ohci0 ohci1 usb1 at ehci0: USB revision 2.0 uhub1 at usb1 uhub1: NEC EHCI root hub, class 9/0, rev 2.00/1.00, addr 1 uhub1: 5 ports with 5 removable, self powered fwohci0 at pci1 dev 11 function 0: VIA Technologies VT3606 OHCI IEEE 1394 Contro ller (rev. 0x46) fwohci0: interrupting at irq 9 fwohci0: OHCI 1.0, 00:10:74:70:00:10:0b:f3, 400Mb/s, 2048 max_rec, 8 ir_ctx, 8 i t_ctx (hrm, haven't tried anything but FreeBSD 3.x and 4.x on the problematic newly-acquired board, sorry to say) Now, the ``new'' board appears to wedge solid at times with this card, accessing a firewire-attached drive. No debugger, no keyboard input, no numlock, no nuthin' that I can see, just power-cycle the thing. Would this probably be an interrupt issue? If so, would it possibly be related to fwohci sharing interrupts with many other cards, including the usb ohci? (my ohci code dates from a few months back, and I know there have been a good number of fixes) The devices sharing this IRQ are pcm0: <Forte Media FM801 Audio Controller> port 0x6100-0x617f irq 12 at device 9 .0 on pci0 ohci0: <NEC uPD 9210 USB controller> mem 0xd0000000-0xd0000fff irq 12 at device 8.0 on pci1 fwohci0: <VIA VT6306> port 0xe000-0xe07f mem 0xd0003000-0xd00037ff irq 12 at dev ice 11.0 on pci1 uhci0: <VIA 83C572 USB controller> port 0x6300-0x631f irq 12 at device 11.0 on p ci0 pci0: <USB controller> (vendor=0x1106, dev=0x3104) at 11.2 irq 12 At the moment, I'm running this machine with the combi-ohci+fw card swapped out for two separate uhci usb and fwohci firewire cards, also at irq12. No wedges yet after a day of operation. Now, I'll quote from this thread back late May, and pose questions: M. Warner Losh: > : > You lose. W/o a pci interrupt router, you can't use the cardbus > : > bridge. > : Good - so who/what should set up a PCI router ? the Bios ? > It depends. Really old machines routed interrupts to all PCI slots > and assigned devices found there an interrupt. Newer old machines > expect the PCI bridge driver of the OS to cope. Newer old machines > provide a BIOS interface to route them (which we can use). Newer > machines with ACPI have ACPI to do the routing. You might want to do Would my newly-found motherboard be a Really Old Machine, or is that what is happening in the DEC Venturis machine where it works? As shown above, they both have PCIBIOS shown in the verbose boot... This isn't a cardbus bridge, rather an on-card PCI bridge, for whatever difference that makes. I have at hand no newer machines than 100+MHz pentium vintage at least six years old -- certainly no ACPI -- so I can't compare in newer boxes, sorry. I could try NetBSD, which disk is currently in use in a different machine, to see how it copes with this board/card combination. thanks barry bouwsma dumpster-diving for motherboards better off left behind
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200312230007.hBN07lr03615>