Commit 11981687 authored by Chris Metcalf's avatar Chris Metcalf

tile PCI RC: eliminate pci_controller.mem_resources field

The .mem_resources[] field in the pci_controller struct
is now obsoleted by the .mem_space and .io_space fields.
Signed-off-by: default avatarChris Metcalf <cmetcalf@tilera.com>
parent 1c43649a
...@@ -173,9 +173,6 @@ struct pci_controller { ...@@ -173,9 +173,6 @@ struct pci_controller {
/* Table that maps the INTx numbers to Linux irq numbers. */ /* Table that maps the INTx numbers to Linux irq numbers. */
int irq_intx_table[4]; int irq_intx_table[4];
/* Address ranges that are routed to this controller/bridge. */
struct resource mem_resources[3];
}; };
extern struct pci_controller pci_controllers[TILEGX_NUM_TRIO * TILEGX_TRIO_PCIES]; extern struct pci_controller pci_controllers[TILEGX_NUM_TRIO * TILEGX_TRIO_PCIES];
......
...@@ -929,9 +929,6 @@ int __init pcibios_init(void) ...@@ -929,9 +929,6 @@ int __init pcibios_init(void)
struct pci_controller *controller = &pci_controllers[i]; struct pci_controller *controller = &pci_controllers[i];
gxio_trio_context_t *trio_context = controller->trio; gxio_trio_context_t *trio_context = controller->trio;
struct pci_bus *root_bus = pci_controllers[i].root_bus; struct pci_bus *root_bus = pci_controllers[i].root_bus;
struct pci_bus *next_bus;
uint32_t bus_address_hi;
struct pci_dev *dev;
int ret; int ret;
int j; int j;
...@@ -945,35 +942,6 @@ int __init pcibios_init(void) ...@@ -945,35 +942,6 @@ int __init pcibios_init(void)
/* Configure the max_payload_size values for this domain. */ /* Configure the max_payload_size values for this domain. */
fixup_read_and_payload_sizes(controller); fixup_read_and_payload_sizes(controller);
list_for_each_entry(dev, &root_bus->devices, bus_list) {
/* Find the PCI host controller, ie. the 1st bridge. */
if ((dev->class >> 8) == PCI_CLASS_BRIDGE_PCI &&
(PCI_SLOT(dev->devfn) == 0)) {
next_bus = dev->subordinate;
pci_controllers[i].mem_resources[0] =
*next_bus->resource[0];
pci_controllers[i].mem_resources[1] =
*next_bus->resource[1];
pci_controllers[i].mem_resources[2] =
*next_bus->resource[2];
break;
}
}
if (pci_controllers[i].mem_resources[1].flags & IORESOURCE_MEM)
bus_address_hi =
pci_controllers[i].mem_resources[1].start >> 32;
else if (pci_controllers[i].mem_resources[2].flags & IORESOURCE_PREFETCH)
bus_address_hi =
pci_controllers[i].mem_resources[2].start >> 32;
else {
/* This is unlikely. */
pr_err("PCI: no memory resources on TRIO %d mac %d\n",
controller->trio_index, controller->mac);
continue;
}
/* /*
* Alloc a PIO region for PCI memory access for each RC port. * Alloc a PIO region for PCI memory access for each RC port.
*/ */
...@@ -1153,16 +1121,13 @@ void __iomem *ioremap(resource_size_t phys_addr, unsigned long size) ...@@ -1153,16 +1121,13 @@ void __iomem *ioremap(resource_size_t phys_addr, unsigned long size)
resource_size_t start; resource_size_t start;
resource_size_t end; resource_size_t end;
int trio_fd; int trio_fd;
int i, j; int i;
start = phys_addr; start = phys_addr;
end = phys_addr + size - 1; end = phys_addr + size - 1;
/* /*
* In the following, each PCI controller's mem_resources[1] * By searching phys_addr in each controller's mem_space, we can
* represents its (non-prefetchable) PCI memory resource and
* mem_resources[2] refers to its prefetchable PCI memory resource.
* By searching phys_addr in each controller's mem_resources[], we can
* determine the controller that should accept the PCI memory access. * determine the controller that should accept the PCI memory access.
*/ */
...@@ -1174,25 +1139,18 @@ void __iomem *ioremap(resource_size_t phys_addr, unsigned long size) ...@@ -1174,25 +1139,18 @@ void __iomem *ioremap(resource_size_t phys_addr, unsigned long size)
if (pci_controllers[i].root_bus == NULL) if (pci_controllers[i].root_bus == NULL)
continue; continue;
for (j = 1; j < 3; j++) { bar_start = pci_controllers[i].mem_space.start;
bar_start = bar_end = pci_controllers[i].mem_space.end;
pci_controllers[i].mem_resources[j].start;
bar_end =
pci_controllers[i].mem_resources[j].end;
if ((start >= bar_start) && (end <= bar_end)) { if ((start >= bar_start) && (end <= bar_end)) {
controller = &pci_controllers[i]; controller = &pci_controllers[i];
break;
goto got_it;
}
} }
} }
if (controller == NULL) if (controller == NULL)
return NULL; return NULL;
got_it:
trio_fd = controller->trio->fd; trio_fd = controller->trio->fd;
/* Convert the resource start to the bus address offset. */ /* Convert the resource start to the bus address offset. */
...@@ -1225,10 +1183,8 @@ void __iomem *ioport_map(unsigned long port, unsigned int size) ...@@ -1225,10 +1183,8 @@ void __iomem *ioport_map(unsigned long port, unsigned int size)
end = port + size - 1; end = port + size - 1;
/* /*
* In the following, each PCI controller's mem_resources[0] * By searching the port in each controller's io_space, we can
* represents its PCI I/O resource. By searching port in each * determine the controller that should accept the PCI I/O access.
* controller's mem_resources[0], we can determine the controller
* that should accept the PCI I/O access.
*/ */
for (i = 0; i < num_rc_controllers; i++) { for (i = 0; i < num_rc_controllers; i++) {
...@@ -1239,21 +1195,18 @@ void __iomem *ioport_map(unsigned long port, unsigned int size) ...@@ -1239,21 +1195,18 @@ void __iomem *ioport_map(unsigned long port, unsigned int size)
if (pci_controllers[i].root_bus == NULL) if (pci_controllers[i].root_bus == NULL)
continue; continue;
bar_start = pci_controllers[i].mem_resources[0].start; bar_start = pci_controllers[i].io_space.start;
bar_end = pci_controllers[i].mem_resources[0].end; bar_end = pci_controllers[i].io_space.end;
if ((start >= bar_start) && (end <= bar_end)) { if ((start >= bar_start) && (end <= bar_end)) {
controller = &pci_controllers[i]; controller = &pci_controllers[i];
break;
goto got_it;
} }
} }
if (controller == NULL) if (controller == NULL)
return NULL; return NULL;
got_it:
trio_fd = controller->trio->fd; trio_fd = controller->trio->fd;
/* Convert the resource start to the bus address offset. */ /* Convert the resource start to the bus address offset. */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment