svn commit: r298712 - in head/sys: dev/cardbus kern mips/nlm powerpc/ofw sparc64/pci sys

Marius Strobl marius at alchemy.franken.de
Wed Apr 27 19:43:06 UTC 2016


On Wed, Apr 27, 2016 at 10:54:42AM -0700, John Baldwin wrote:
> On Wednesday, April 27, 2016 05:49:42 PM John Baldwin wrote:
> > Author: jhb
> > Date: Wed Apr 27 17:49:42 2016
> > New Revision: 298712
> > URL: https://svnweb.freebsd.org/changeset/base/298712
> > 
> > Log:
> >   Add a bus_null_rescan() method that always fails with an error.
> >   
> >   Use this in place of kobj_error_method to disable BUS_RESCAN() on
> >   PCI drivers that do not use the "standard" scanning algorithm.
> 
> This should fix the build.
> 
> > Modified:
> >   head/sys/dev/cardbus/cardbus.c
> >   head/sys/kern/subr_bus.c
> >   head/sys/mips/nlm/xlp_pci.c
> >   head/sys/powerpc/ofw/ofw_pcibus.c
> >   head/sys/sparc64/pci/ofw_pcibus.c
> >   head/sys/sys/bus.h
> 
> Note that some of these drivers could be changed to use the "standard"
> scanning algorithm and support rescans if they moved some of their custom
> scanning logic into a pci_child_added callback.  This is generally true of
> all but cardbus except that the OFW busses use the OFW tree to drive
> scanning (so it seems they will add PCI devices that don't appear valid to
> a PCI scan but are in the OFW tree).

As for sparc64, the latter isn't true AFAICT, i. e. all PCI devices
added based on information obtained from the device tree should also
be found with the "standard" scanning method (apart from 2 or 3 known
dupes with partially incomplete information in the known device trees;
these nodes are skipped, though). Actually, IIRC "standard" PCI device
scanning is how things worked before the OFW_NEWPCI code was added in
r117119. However, OFW information is used for enumerating PCI busses
and devices since then so the order within FreeBSD matches connector/
port markings on chassis and add-on cards (i. e. on-board MACs end up
as bge[0-3], an add-on card gets bge4, analogous for multi-port cards,
same for HBAs etc.), which previously wasn't the case with "standard"
scanning. So what could work for sparc64 is to do a first pass still
based on OFW information and then a second one using the "standard"
scanning method, especially in the rescan case. However, given that
at least some sun4u models support PCI hot-plug it's also not totally
unthinkable that OFW nodes for PCI devices will be added/removed on
the fly; so far I just wasn't adventurous enough to give that a try,
though.

Marius



More information about the svn-src-head mailing list