Commit b89b7ea0 authored by Alan Stern's avatar Alan Stern Committed by Greg Kroah-Hartman

[PATCH] PCI: Move pci_dev_put outside a spinlock

This patch (as659) fixes a might_sleep problem in the PCI core, by moving
a call to pci_dev_put() outside the scope of a spinlock.
Signed-off-by: default avatarAlan Stern <stern@rowland.harvard.edu>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 8c4b2cf9
...@@ -246,9 +246,9 @@ pci_get_subsys(unsigned int vendor, unsigned int device, ...@@ -246,9 +246,9 @@ pci_get_subsys(unsigned int vendor, unsigned int device,
} }
dev = NULL; dev = NULL;
exit: exit:
pci_dev_put(from);
dev = pci_dev_get(dev); dev = pci_dev_get(dev);
spin_unlock(&pci_bus_lock); spin_unlock(&pci_bus_lock);
pci_dev_put(from);
return dev; return dev;
} }
...@@ -339,9 +339,9 @@ struct pci_dev *pci_get_class(unsigned int class, struct pci_dev *from) ...@@ -339,9 +339,9 @@ struct pci_dev *pci_get_class(unsigned int class, struct pci_dev *from)
} }
dev = NULL; dev = NULL;
exit: exit:
pci_dev_put(from);
dev = pci_dev_get(dev); dev = pci_dev_get(dev);
spin_unlock(&pci_bus_lock); spin_unlock(&pci_bus_lock);
pci_dev_put(from);
return dev; return dev;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment