diff options
author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2007-12-19 22:55:05 -0500 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2007-12-20 00:18:16 -0500 |
commit | 553aa7659bc0e188348f64e978343ed984eb6e56 (patch) | |
tree | 8c27968b7fa745c4bca9e573962ea6877f487014 /arch/powerpc/kernel | |
parent | be8cbcd8896670a01ead7a29e33ffe29604ed734 (diff) |
[POWERPC] Disable PCI IO/Mem on a device when resources can't be allocated
This patch changes the PowerPC PCI code to disable IO and/or Memory
decoding on a PCI device when a resource of that type failed to be
allocated. This is done to avoid having unallocated dangling BARs
enabled that might try to decode on top of other devices.
If a proper resource is assigned later on, then pci_enable_device()
will take care of re-enabling decoding.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch/powerpc/kernel')
-rw-r--r-- | arch/powerpc/kernel/pci-common.c | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/arch/powerpc/kernel/pci-common.c b/arch/powerpc/kernel/pci-common.c index 1037b3a093ee..88838b0f8b90 100644 --- a/arch/powerpc/kernel/pci-common.c +++ b/arch/powerpc/kernel/pci-common.c | |||
@@ -1034,7 +1034,7 @@ clear_resource: | |||
1034 | } | 1034 | } |
1035 | } | 1035 | } |
1036 | 1036 | ||
1037 | static inline void __devinit alloc_resource(struct pci_dev *dev, int idx) | 1037 | static inline int __devinit alloc_resource(struct pci_dev *dev, int idx) |
1038 | { | 1038 | { |
1039 | struct resource *pr, *r = &dev->resource[idx]; | 1039 | struct resource *pr, *r = &dev->resource[idx]; |
1040 | 1040 | ||
@@ -1058,7 +1058,10 @@ static inline void __devinit alloc_resource(struct pci_dev *dev, int idx) | |||
1058 | r->flags |= IORESOURCE_UNSET; | 1058 | r->flags |= IORESOURCE_UNSET; |
1059 | r->end -= r->start; | 1059 | r->end -= r->start; |
1060 | r->start = 0; | 1060 | r->start = 0; |
1061 | |||
1062 | return -EBUSY; | ||
1061 | } | 1063 | } |
1064 | return 0; | ||
1062 | } | 1065 | } |
1063 | 1066 | ||
1064 | static void __init pcibios_allocate_resources(int pass) | 1067 | static void __init pcibios_allocate_resources(int pass) |
@@ -1080,8 +1083,12 @@ static void __init pcibios_allocate_resources(int pass) | |||
1080 | disabled = !(command & PCI_COMMAND_IO); | 1083 | disabled = !(command & PCI_COMMAND_IO); |
1081 | else | 1084 | else |
1082 | disabled = !(command & PCI_COMMAND_MEMORY); | 1085 | disabled = !(command & PCI_COMMAND_MEMORY); |
1083 | if (pass == disabled) | 1086 | if (pass == disabled && alloc_resource(dev, idx)) { |
1084 | alloc_resource(dev, idx); | 1087 | command &= ~(r->flags & (IORESOURCE_IO | |
1088 | IORESOURCE_MEM)); | ||
1089 | pci_write_config_word(dev, | ||
1090 | PCI_COMMAND, command); | ||
1091 | } | ||
1085 | } | 1092 | } |
1086 | if (pass) | 1093 | if (pass) |
1087 | continue; | 1094 | continue; |