|
@@ -417,11 +417,8 @@ int dw_pcie_host_init(struct pcie_port *pp)
|
|
|
struct of_pci_range range;
|
|
|
struct of_pci_range_parser parser;
|
|
|
struct resource *cfg_res;
|
|
|
- u32 val, ns;
|
|
|
- const __be32 *addrp;
|
|
|
- int i, index, ret;
|
|
|
-
|
|
|
- ns = of_n_size_cells(np);
|
|
|
+ u32 val;
|
|
|
+ int i, ret;
|
|
|
|
|
|
cfg_res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "config");
|
|
|
if (cfg_res) {
|
|
@@ -429,12 +426,6 @@ int dw_pcie_host_init(struct pcie_port *pp)
|
|
|
pp->cfg1_size = resource_size(cfg_res)/2;
|
|
|
pp->cfg0_base = cfg_res->start;
|
|
|
pp->cfg1_base = cfg_res->start + pp->cfg0_size;
|
|
|
-
|
|
|
- /* Find the untranslated configuration space address */
|
|
|
- index = of_property_match_string(np, "reg-names", "config");
|
|
|
- addrp = of_get_address(np, index, NULL, NULL);
|
|
|
- pp->cfg0_mod_base = of_read_number(addrp, ns);
|
|
|
- pp->cfg1_mod_base = pp->cfg0_mod_base + pp->cfg0_size;
|
|
|
} else if (!pp->va_cfg0_base) {
|
|
|
dev_err(pp->dev, "missing *config* reg space\n");
|
|
|
}
|
|
@@ -461,18 +452,13 @@ int dw_pcie_host_init(struct pcie_port *pp)
|
|
|
pp->io_size = resource_size(&pp->io);
|
|
|
pp->io_bus_addr = range.pci_addr;
|
|
|
pp->io_base = range.cpu_addr;
|
|
|
-
|
|
|
- /* Find the untranslated IO space address */
|
|
|
- pp->io_mod_base = range.cpu_addr;
|
|
|
+ pp->io_base_tmp = range.cpu_addr;
|
|
|
}
|
|
|
if (restype == IORESOURCE_MEM) {
|
|
|
of_pci_range_to_resource(&range, np, &pp->mem);
|
|
|
pp->mem.name = "MEM";
|
|
|
pp->mem_size = resource_size(&pp->mem);
|
|
|
pp->mem_bus_addr = range.pci_addr;
|
|
|
-
|
|
|
- /* Find the untranslated MEM space address */
|
|
|
- pp->mem_mod_base = range.cpu_addr;
|
|
|
}
|
|
|
if (restype == 0) {
|
|
|
of_pci_range_to_resource(&range, np, &pp->cfg);
|
|
@@ -480,11 +466,6 @@ int dw_pcie_host_init(struct pcie_port *pp)
|
|
|
pp->cfg1_size = resource_size(&pp->cfg)/2;
|
|
|
pp->cfg0_base = pp->cfg.start;
|
|
|
pp->cfg1_base = pp->cfg.start + pp->cfg0_size;
|
|
|
-
|
|
|
- /* Find the untranslated configuration space address */
|
|
|
- pp->cfg0_mod_base = range.cpu_addr;
|
|
|
- pp->cfg1_mod_base = pp->cfg0_mod_base +
|
|
|
- pp->cfg0_size;
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -555,7 +536,7 @@ int dw_pcie_host_init(struct pcie_port *pp)
|
|
|
|
|
|
if (!pp->ops->rd_other_conf)
|
|
|
dw_pcie_prog_outbound_atu(pp, PCIE_ATU_REGION_INDEX1,
|
|
|
- PCIE_ATU_TYPE_MEM, pp->mem_mod_base,
|
|
|
+ PCIE_ATU_TYPE_MEM, pp->mem_base,
|
|
|
pp->mem_bus_addr, pp->mem_size);
|
|
|
|
|
|
dw_pcie_wr_own_conf(pp, PCI_BASE_ADDRESS_0, 4, 0);
|
|
@@ -592,12 +573,12 @@ static int dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus,
|
|
|
|
|
|
if (bus->parent->number == pp->root_bus_nr) {
|
|
|
type = PCIE_ATU_TYPE_CFG0;
|
|
|
- cpu_addr = pp->cfg0_mod_base;
|
|
|
+ cpu_addr = pp->cfg0_base;
|
|
|
cfg_size = pp->cfg0_size;
|
|
|
va_cfg_base = pp->va_cfg0_base;
|
|
|
} else {
|
|
|
type = PCIE_ATU_TYPE_CFG1;
|
|
|
- cpu_addr = pp->cfg1_mod_base;
|
|
|
+ cpu_addr = pp->cfg1_base;
|
|
|
cfg_size = pp->cfg1_size;
|
|
|
va_cfg_base = pp->va_cfg1_base;
|
|
|
}
|
|
@@ -607,7 +588,7 @@ static int dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus,
|
|
|
busdev, cfg_size);
|
|
|
ret = dw_pcie_cfg_read(va_cfg_base + where, size, val);
|
|
|
dw_pcie_prog_outbound_atu(pp, PCIE_ATU_REGION_INDEX0,
|
|
|
- PCIE_ATU_TYPE_IO, pp->io_mod_base,
|
|
|
+ PCIE_ATU_TYPE_IO, pp->io_base,
|
|
|
pp->io_bus_addr, pp->io_size);
|
|
|
|
|
|
return ret;
|
|
@@ -626,12 +607,12 @@ static int dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus,
|
|
|
|
|
|
if (bus->parent->number == pp->root_bus_nr) {
|
|
|
type = PCIE_ATU_TYPE_CFG0;
|
|
|
- cpu_addr = pp->cfg0_mod_base;
|
|
|
+ cpu_addr = pp->cfg0_base;
|
|
|
cfg_size = pp->cfg0_size;
|
|
|
va_cfg_base = pp->va_cfg0_base;
|
|
|
} else {
|
|
|
type = PCIE_ATU_TYPE_CFG1;
|
|
|
- cpu_addr = pp->cfg1_mod_base;
|
|
|
+ cpu_addr = pp->cfg1_base;
|
|
|
cfg_size = pp->cfg1_size;
|
|
|
va_cfg_base = pp->va_cfg1_base;
|
|
|
}
|
|
@@ -641,7 +622,7 @@ static int dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus,
|
|
|
busdev, cfg_size);
|
|
|
ret = dw_pcie_cfg_write(va_cfg_base + where, size, val);
|
|
|
dw_pcie_prog_outbound_atu(pp, PCIE_ATU_REGION_INDEX0,
|
|
|
- PCIE_ATU_TYPE_IO, pp->io_mod_base,
|
|
|
+ PCIE_ATU_TYPE_IO, pp->io_base,
|
|
|
pp->io_bus_addr, pp->io_size);
|
|
|
|
|
|
return ret;
|
|
@@ -729,7 +710,7 @@ static int dw_pcie_setup(int nr, struct pci_sys_data *sys)
|
|
|
|
|
|
if (global_io_offset < SZ_1M && pp->io_size > 0) {
|
|
|
sys->io_offset = global_io_offset - pp->io_bus_addr;
|
|
|
- pci_ioremap_io(global_io_offset, pp->io_base);
|
|
|
+ pci_ioremap_io(global_io_offset, pp->io_base_tmp);
|
|
|
global_io_offset += SZ_64K;
|
|
|
pci_add_resource_offset(&sys->resources, &pp->io,
|
|
|
sys->io_offset);
|