|
@@ -178,7 +178,7 @@ setup_resource(struct acpi_resource *acpi_res, void *data)
|
|
|
struct acpi_resource_address64 addr;
|
|
|
acpi_status status;
|
|
|
unsigned long flags;
|
|
|
- u64 start, end;
|
|
|
+ u64 start, orig_end, end;
|
|
|
|
|
|
status = resource_to_addr(acpi_res, &addr);
|
|
|
if (!ACPI_SUCCESS(status))
|
|
@@ -194,7 +194,21 @@ setup_resource(struct acpi_resource *acpi_res, void *data)
|
|
|
return AE_OK;
|
|
|
|
|
|
start = addr.minimum + addr.translation_offset;
|
|
|
- end = addr.maximum + addr.translation_offset;
|
|
|
+ orig_end = end = addr.maximum + addr.translation_offset;
|
|
|
+
|
|
|
+ /* Exclude non-addressable range or non-addressable portion of range */
|
|
|
+ end = min(end, (u64)iomem_resource.end);
|
|
|
+ if (end <= start) {
|
|
|
+ dev_info(&info->bridge->dev,
|
|
|
+ "host bridge window [%#llx-%#llx] "
|
|
|
+ "(ignored, not CPU addressable)\n", start, orig_end);
|
|
|
+ return AE_OK;
|
|
|
+ } else if (orig_end != end) {
|
|
|
+ dev_info(&info->bridge->dev,
|
|
|
+ "host bridge window [%#llx-%#llx] "
|
|
|
+ "([%#llx-%#llx] ignored, not CPU addressable)\n",
|
|
|
+ start, orig_end, end + 1, orig_end);
|
|
|
+ }
|
|
|
|
|
|
res = &info->res[info->res_num];
|
|
|
res->name = info->name;
|