diff options
Diffstat (limited to 'drivers/pci/controller/pci-versatile.c')
| -rw-r--r-- | drivers/pci/controller/pci-versatile.c | 33 | 
1 files changed, 4 insertions, 29 deletions
| diff --git a/drivers/pci/controller/pci-versatile.c b/drivers/pci/controller/pci-versatile.c index b911359b6d81..653d5d0ecf81 100644 --- a/drivers/pci/controller/pci-versatile.c +++ b/drivers/pci/controller/pci-versatile.c @@ -67,23 +67,20 @@ static int versatile_pci_probe(struct platform_device *pdev)  	struct device *dev = &pdev->dev;  	struct resource *res;  	struct resource_entry *entry; -	int ret, i, myslot = -1, mem = 1; +	int i, myslot = -1, mem = 1;  	u32 val;  	void __iomem *local_pci_cfg_base; -	struct pci_bus *bus, *child;  	struct pci_host_bridge *bridge;  	bridge = devm_pci_alloc_host_bridge(dev, 0);  	if (!bridge)  		return -ENOMEM; -	res = platform_get_resource(pdev, IORESOURCE_MEM, 0); -	versatile_pci_base = devm_ioremap_resource(dev, res); +	versatile_pci_base = devm_platform_ioremap_resource(pdev, 0);  	if (IS_ERR(versatile_pci_base))  		return PTR_ERR(versatile_pci_base); -	res = platform_get_resource(pdev, IORESOURCE_MEM, 1); -	versatile_cfg_base[0] = devm_ioremap_resource(dev, res); +	versatile_cfg_base[0] = devm_platform_ioremap_resource(pdev, 1);  	if (IS_ERR(versatile_cfg_base[0]))  		return PTR_ERR(versatile_cfg_base[0]); @@ -92,11 +89,6 @@ static int versatile_pci_probe(struct platform_device *pdev)  	if (IS_ERR(versatile_cfg_base[1]))  		return PTR_ERR(versatile_cfg_base[1]); -	ret = pci_parse_request_of_pci_ranges(dev, &bridge->windows, -					      NULL, NULL); -	if (ret) -		return ret; -  	resource_list_for_each_entry(entry, &bridge->windows) {  		if (resource_type(entry->res) == IORESOURCE_MEM) {  			writel(entry->res->start >> 28, PCI_IMAP(mem)); @@ -154,28 +146,11 @@ static int versatile_pci_probe(struct platform_device *pdev)  	 */  	writel(0, versatile_cfg_base[0] + PCI_INTERRUPT_LINE); -	pci_add_flags(PCI_ENABLE_PROC_DOMAINS);  	pci_add_flags(PCI_REASSIGN_ALL_BUS); -	bridge->dev.parent = dev; -	bridge->sysdata = NULL; -	bridge->busnr = 0;  	bridge->ops = &pci_versatile_ops; -	bridge->map_irq = of_irq_parse_and_map_pci; -	bridge->swizzle_irq = pci_common_swizzle; - -	ret = pci_scan_root_bus_bridge(bridge); -	if (ret < 0) -		return ret; - -	bus = bridge->bus; - -	pci_assign_unassigned_bus_resources(bus); -	list_for_each_entry(child, &bus->children, node) -		pcie_bus_configure_settings(child); -	pci_bus_add_devices(bus); -	return 0; +	return pci_host_probe(bridge);  }  static const struct of_device_id versatile_pci_of_match[] = { |