Implement a PCI bus rescan method.
authorjhb <jhb@FreeBSD.org>
Wed, 27 Apr 2016 16:31:12 +0000 (16:31 +0000)
committerjhb <jhb@FreeBSD.org>
Wed, 27 Apr 2016 16:31:12 +0000 (16:31 +0000)
commitc97e88d8d27379822b48e87c286771f02ec6230b
tree1dfb549dd2b02d536680e720de4a0da58313b464
parente05c6840a1464552cb7462d76fbae2a9e3bc86d0
Implement a PCI bus rescan method.

Rescanning a PCI bus uses the following steps:
- Fetch the current set of child devices and save it in the 'devlist'
  array.
- Allocate a parallel array 'unchanged' initalized with NULL pointers.
- Scan the bus checking each slot (and each function on slots with a
  multifunction device).
- If a valid function is found, look for a matching device in the 'devlist'
  array.  If a device is found, save the pointer in the 'unchanged' array.
  If a device is not found, add a new device.
- After the scan has finished, walk the 'devlist' array deleting any
  devices that do not have a matching pointer in the 'unchanged' array.
- Finally, fetch an updated set of child devices and explicitly attach any
  devices that are not present in the 'unchanged' array.

This builds on the previous changes to move subclass data management into
pci_alloc_devinfo(), pci_child_added(), and bus_child_deleted().

Subclasses of the PCI bus use custom rescan logic explicitly override the
rescan method to disable rescans.

Differential Revision: https://reviews.freebsd.org/D6018
sys/dev/cardbus/cardbus.c
sys/dev/pci/pci.c
sys/dev/pci/pci_private.h
sys/mips/nlm/xlp_pci.c
sys/powerpc/ofw/ofw_pcibus.c
sys/sparc64/pci/ofw_pcibus.c