summaryrefslogtreecommitdiff
path: root/arch
diff options
context:
space:
mode:
authorJesse Barnes <jbarnes@hobbes.lan>2008-07-17 03:21:47 +0400
committerJesse Barnes <jbarnes@virtuousgeek.org>2008-07-17 03:21:47 +0400
commit58b6e5538460be358fdf1286d9a2fbcfcc2cfaba (patch)
tree58bd7f466a55905ad7a03a714b55d8da6ed81447 /arch
parent9fce1bc956c21dfe0f46be028f18c4d5057f2bd7 (diff)
downloadlinux-58b6e5538460be358fdf1286d9a2fbcfcc2cfaba.tar.xz
Revert "x86/PCI: ACPI based PCI gap calculation"
This reverts commit 809d9a8f93bd8504dcc34b16bbfdfd1a8c9bb1ed. This one isn't quite ready for prime time. It needs more testing and additional feedback from the ACPI guys.
Diffstat (limited to 'arch')
-rw-r--r--arch/x86/pci/acpi.c80
1 files changed, 0 insertions, 80 deletions
diff --git a/arch/x86/pci/acpi.c b/arch/x86/pci/acpi.c
index d1ffb5709174..d95de2f199cd 100644
--- a/arch/x86/pci/acpi.c
+++ b/arch/x86/pci/acpi.c
@@ -4,7 +4,6 @@
#include <linux/irq.h>
#include <linux/dmi.h>
#include <asm/numa.h>
-#include <asm/e820.h>
#include "pci.h"
struct pci_root_info {
@@ -15,11 +14,6 @@ struct pci_root_info {
int busnum;
};
-struct gap_info {
- unsigned long gapstart;
- unsigned long gapsize;
-};
-
static acpi_status
resource_to_addr(struct acpi_resource *resource,
struct acpi_resource_address64 *addr)
@@ -116,78 +110,6 @@ adjust_transparent_bridge_resources(struct pci_bus *bus)
}
}
-static acpi_status search_gap(struct acpi_resource *resource, void *data)
-{
- struct acpi_resource_address64 addr;
- acpi_status status;
- struct gap_info *gap = data;
- unsigned long long start_addr, end_addr;
-
- status = resource_to_addr(resource, &addr);
- if (ACPI_SUCCESS(status) &&
- addr.resource_type == ACPI_MEMORY_RANGE &&
- addr.address_length > gap->gapsize) {
- start_addr = addr.minimum + addr.translation_offset;
- /*
- * We want space only in the 32bit address range
- */
- if (start_addr < UINT_MAX) {
- end_addr = start_addr + addr.address_length;
- e820_search_gap(&gap->gapstart, &gap->gapsize,
- start_addr, end_addr);
- }
- }
-
- return AE_OK;
-}
-
-/*
- * Search for a hole in the 32 bit address space for PCI to assign MMIO
- * resources, for hotplug or unconfigured resources.
- * We query the CRS object of the PCI root device to look for possible producer
- * resources in the tree and consider these while calulating the start address
- * for this hole.
- */
-static void pci_setup_gap(acpi_handle *handle)
-{
- struct gap_info gap;
- acpi_status status;
-
- gap.gapstart = 0;
- gap.gapsize = 0x400000;
-
- status = acpi_walk_resources(handle, METHOD_NAME__CRS,
- search_gap, &gap);
-
- if (ACPI_SUCCESS(status)) {
- unsigned long round;
-
- if (!gap.gapstart) {
- printk(KERN_ERR "ACPI: Warning: Cannot find a gap "
- "in the 32bit address range for PCI\n"
- "ACPI: PCI devices may collide with "
- "hotpluggable memory address range\n");
- }
- /*
- * Round the gapstart, uses the same logic as in
- * e820_gap_setup
- */
- round = 0x100000;
- while ((gap.gapsize >> 4) > round)
- round += round;
- /* Fun with two's complement */
- pci_mem_start = (gap.gapstart + round) & -round;
-
- printk(KERN_INFO "ACPI: PCI resources should "
- "start at %lx (gap: %lx:%lx)\n",
- pci_mem_start, gap.gapstart, gap.gapsize);
- } else {
- printk(KERN_ERR "ACPI: Error while searching for gap in "
- "the 32bit address range for PCI\n");
- }
-}
-
-
static void
get_current_resources(struct acpi_device *device, int busnum,
int domain, struct pci_bus *bus)
@@ -293,8 +215,6 @@ struct pci_bus * __devinit pci_acpi_scan_root(struct acpi_device *device, int do
if (bus && (pci_probe & PCI_USE__CRS))
get_current_resources(device, busnum, domain, bus);
-
- pci_setup_gap(device->handle);
return bus;
}