The patch titled remove drivers/pci/search.c:pci_find_device_reverse() has been added to the -mm tree. Its filename is remove-drivers-pci-searchcpci_find_device_reverse.patch See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this ------------------------------------------------------ Subject: remove drivers/pci/search.c:pci_find_device_reverse() From: Adrian Bunk <bunk@xxxxxxxxx> After "ide: complete switch to pci_get" we can remove the no longer used pci_find_device_reverse(). akpm: normally we'd withdraw this after a warning period, with EXPORT_UNUSED_SYMBOL(). But Alan says Normally - but for the fact pci_find_device{_reverse} is unsafe on any box with any kind of pci hotplug events. It really needs to die. It is not hotplug safe. The alternative would be to export it only with !CONFIG_HOTPLUG (which is what my test kernel does for both this and pci_find_device()). If we do that then to all intents and purposes it vanishes from most standard builds The conversion is also trivial Signed-off-by: Adrian Bunk <bunk@xxxxxxxxx> Acked-by: Alan Cox <alan@xxxxxxxxxx> Cc: Greg KH <greg@xxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxx> --- drivers/pci/search.c | 38 -------------------------------------- include/linux/pci.h | 1 - 2 files changed, 39 deletions(-) diff -puN drivers/pci/search.c~remove-drivers-pci-searchcpci_find_device_reverse drivers/pci/search.c --- a/drivers/pci/search.c~remove-drivers-pci-searchcpci_find_device_reverse +++ a/drivers/pci/search.c @@ -340,43 +340,6 @@ exit: } /** - * pci_find_device_reverse - begin or continue searching for a PCI device by vendor/device id - * @vendor: PCI vendor id to match, or %PCI_ANY_ID to match all vendor ids - * @device: PCI device id to match, or %PCI_ANY_ID to match all device ids - * @from: Previous PCI device found in search, or %NULL for new search. - * - * Iterates through the list of known PCI devices in the reverse order of - * pci_find_device(). - * If a PCI device is found with a matching @vendor and @device, a pointer to - * its device structure is returned. Otherwise, %NULL is returned. - * A new search is initiated by passing %NULL as the @from argument. - * Otherwise if @from is not %NULL, searches continue from previous device - * on the global list. - */ -struct pci_dev * -pci_find_device_reverse(unsigned int vendor, unsigned int device, const struct pci_dev *from) -{ - struct list_head *n; - struct pci_dev *dev; - - WARN_ON(in_interrupt()); - down_read(&pci_bus_sem); - n = from ? from->global_list.prev : pci_devices.prev; - - while (n && (n != &pci_devices)) { - dev = pci_dev_g(n); - if ((vendor == PCI_ANY_ID || dev->vendor == vendor) && - (device == PCI_ANY_ID || dev->device == device)) - goto exit; - n = n->prev; - } - dev = NULL; -exit: - up_read(&pci_bus_sem); - return dev; -} - -/** * pci_get_class - begin or continue searching for a PCI device by class * @class: search for a PCI device with this class designation * @from: Previous PCI device found in search, or %NULL for new search. @@ -452,7 +415,6 @@ EXPORT_SYMBOL(pci_dev_present); EXPORT_SYMBOL(pci_find_present); EXPORT_SYMBOL(pci_find_device); -EXPORT_SYMBOL(pci_find_device_reverse); EXPORT_SYMBOL(pci_find_slot); /* For boot time work */ EXPORT_SYMBOL(pci_find_bus); diff -puN include/linux/pci.h~remove-drivers-pci-searchcpci_find_device_reverse include/linux/pci.h --- a/include/linux/pci.h~remove-drivers-pci-searchcpci_find_device_reverse +++ a/include/linux/pci.h @@ -463,7 +463,6 @@ extern void pci_sort_breadthfirst(void); /* Generic PCI functions exported to card drivers */ struct pci_dev *pci_find_device (unsigned int vendor, unsigned int device, const struct pci_dev *from); -struct pci_dev *pci_find_device_reverse (unsigned int vendor, unsigned int device, const struct pci_dev *from); struct pci_dev *pci_find_slot (unsigned int bus, unsigned int devfn); int pci_find_capability (struct pci_dev *dev, int cap); int pci_find_next_capability (struct pci_dev *dev, u8 pos, int cap); _ Patches currently in -mm which might be from bunk@xxxxxxxxx are origin.patch make-drivers-acpi-baycdrive_bays-static.patch git-alsa.patch tidy-gregkh-driver-udev-compatible-hack.patch drivers-media-video-cafe_ccicc-make-a-function-static.patch git-gfs2-nmw.patch git-mtd.patch git-net.patch net-uninline-skb_put-fix.patch git-pcmcia.patch git-scsi-misc.patch drivers-scsi-small-cleanups.patch drivers-scsi-aic7xxx-aic79xx_corec-make-ahd_match_scb-static.patch drivers-scsi-advansysc-cleanups.patch megaraid-fix-warnings-when-config_proc_fs=n.patch drivers-scsi-dpt_i2oc-remove-dead-code.patch acx1xx-wireless-driver.patch drivers-edac-make-code-static.patch remove-drivers-pci-searchcpci_find_device_reverse.patch ext4_ext_split-remove-dead-code.patch the-scheduled-removal-of-some-oss-options.patch fs-reiser4-possible-cleanups.patch reiser4-possible-cleanups-2.patch gtod-persistent-clock-support-i386-i386-unexport-read_persistent_clock.patch updated-i386-convert-to-clock-event-devices-arch-i386-kernel-apicc-make-a-function-static.patch updated-i386-convert-to-clock-event-devices-remove-arch-i386-kernel-time_hpetchpet_reenable.patch slim-main-patch-security-slim-slm_mainc-make-2-functions-static.patch slab-cache-shrinker-statistics.patch debug-shared-irqs-kconfig-fix.patch i386-enable-4k-stacks-by-default.patch mutex-subsystem-synchro-test-module.patch - To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html