diff options
author | Tejun Heo <htejun@gmail.com> | 2008-01-30 04:20:04 -0500 |
---|---|---|
committer | Jeff Garzik <jeff@garzik.org> | 2008-02-01 12:26:44 -0500 |
commit | b95d58eaf20eb33c245a2172ec4ecf46bd832309 (patch) | |
tree | 432e1688aeb0b752a1c25c4cc6711b470b008fe9 /drivers/pci/pci.c | |
parent | 9f24e82d07e2c64467d0c0c04a798de56461fd4a (diff) |
pci: allow multiple calls to pcim_enable_device()
There's no reason not to allow multiple calls to pcim_enable_device().
Calls after the first one can simply be noop. All PCI resources will
be released when the initial pcim_enable_device() resource is
released.
This allows more flexibility to managed PCI users.
Signed-off-by: Tejun Heo <htejun@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'drivers/pci/pci.c')
-rw-r--r-- | drivers/pci/pci.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/pci/pci.c b/drivers/pci/pci.c index 71d561fda0a2..7d4ce906d207 100644 --- a/drivers/pci/pci.c +++ b/drivers/pci/pci.c | |||
@@ -823,7 +823,8 @@ int pcim_enable_device(struct pci_dev *pdev) | |||
823 | dr = get_pci_dr(pdev); | 823 | dr = get_pci_dr(pdev); |
824 | if (unlikely(!dr)) | 824 | if (unlikely(!dr)) |
825 | return -ENOMEM; | 825 | return -ENOMEM; |
826 | WARN_ON(!!dr->enabled); | 826 | if (dr->enabled) |
827 | return 0; | ||
827 | 828 | ||
828 | rc = pci_enable_device(pdev); | 829 | rc = pci_enable_device(pdev); |
829 | if (!rc) { | 830 | if (!rc) { |