diff options
| -rw-r--r-- | arch/x86/pci/acpi.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/arch/x86/pci/acpi.c b/arch/x86/pci/acpi.c index 75ac3f856ea5..e31160216efb 100644 --- a/arch/x86/pci/acpi.c +++ b/arch/x86/pci/acpi.c | |||
| @@ -123,7 +123,7 @@ setup_resource(struct acpi_resource *acpi_res, void *data) | |||
| 123 | acpi_status status; | 123 | acpi_status status; |
| 124 | unsigned long flags; | 124 | unsigned long flags; |
| 125 | struct resource *root, *conflict; | 125 | struct resource *root, *conflict; |
| 126 | u64 start, end; | 126 | u64 start, end, max_len; |
| 127 | 127 | ||
| 128 | status = resource_to_addr(acpi_res, &addr); | 128 | status = resource_to_addr(acpi_res, &addr); |
| 129 | if (!ACPI_SUCCESS(status)) | 129 | if (!ACPI_SUCCESS(status)) |
| @@ -140,6 +140,17 @@ setup_resource(struct acpi_resource *acpi_res, void *data) | |||
| 140 | } else | 140 | } else |
| 141 | return AE_OK; | 141 | return AE_OK; |
| 142 | 142 | ||
| 143 | max_len = addr.maximum - addr.minimum + 1; | ||
| 144 | if (addr.address_length > max_len) { | ||
| 145 | dev_printk(KERN_DEBUG, &info->bridge->dev, | ||
| 146 | "host bridge window length %#llx doesn't fit in " | ||
| 147 | "%#llx-%#llx, trimming\n", | ||
| 148 | (unsigned long long) addr.address_length, | ||
| 149 | (unsigned long long) addr.minimum, | ||
| 150 | (unsigned long long) addr.maximum); | ||
| 151 | addr.address_length = max_len; | ||
| 152 | } | ||
| 153 | |||
| 143 | start = addr.minimum + addr.translation_offset; | 154 | start = addr.minimum + addr.translation_offset; |
| 144 | end = start + addr.address_length - 1; | 155 | end = start + addr.address_length - 1; |
| 145 | 156 | ||
