Subject: change to PCI interrupt mapping coming soon..
To: None <tech-kern@netbsd.org, netbsd-ports@netbsd.org,>
From: Bill Sommerfeld <sommerfeld@orchard.arlington.ma.us>
List: tech-ports
Date: 12/27/2000 23:20:15
As discussed a little while back, I will soon (tomorrow?) be
committing changes to the PCI interrupt mapping API to simultaneously
simplify it and increase its flexibility.

I'll commit a pci_intr(9) man page along with the change..

Quick summary:

 - pci_intr_map() was passed 4 parameters identifying the interrupt
pint which in all cases came from "struct pci_attach_args".
 - on many/most platforms it only needed one or two of these parameters.
 - Certain ways of doing interrupt mapping on x86 systems using the
Intel Multiprocessor spec need additional parameters not included in
the pci_intr_map arg list (namely, the unswizzled bus tag).
 - these parameters are present in "struct pci_attach_args"

So, the obvious answer is to just simplify the API and pass a "struct
pci_attach_args *" to pci_intr_map()

99% of PCI drivers need only a one-line change:

diff -u -r1.11 if_fxp_pci.c
--- dev/pci/if_fxp_pci.c        2000/09/27 10:54:55     1.11
+++ dev/pci/if_fxp_pci.c        2000/12/28 02:30:09
@@ -369,8 +369,7 @@
        /*
         * Map and establish our interrupt.
         */
-       if (pci_intr_map(pc, pa->pa_intrtag, pa->pa_intrpin,
-           pa->pa_intrline, &ih)) {
+       if (pci_intr_map(pa, &ih)) {
                printf("%s: couldn't map interrupt\n", sc->sc_dev.dv_xname);
                return;
        }

				- Bill