Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp1418370imm; Wed, 17 Oct 2018 20:24:38 -0700 (PDT) X-Google-Smtp-Source: ACcGV62vOqy6XuwRT+yDOAjIozvgSxurZQasyqt2xBckCWRl7v4NhBfXSmTOuL7H6Z0URea7IhGW X-Received: by 2002:a17:902:28a2:: with SMTP id f31-v6mr28512856plb.312.1539833078109; Wed, 17 Oct 2018 20:24:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539833078; cv=none; d=google.com; s=arc-20160816; b=KSp4nTh3YlZJCZBIW56vYfctg5gvTSBLct4g+t+cDwfdsaZY3RcQcw9A/axW5+o/w1 Uh2+XizTj/7lSfAmzk9yGZdJoZKXCrfyVGIQ5QXNodWEwffD+KTznsI0NdlzM9PLEF4I D8ujygps6/Rtjgsam2/rocxUR4C1bkdlqFAM4mEMo2WtmnM5M4cxjQ6AcTGwQ4rR+HJs yb+ZETgAj99q9lSwrgkCk5fQjS6by+asFbqCEeQp871S80J8GgCCKonH27SpFTq+oMQp XR52VYgjPOmycMxJRsV8eD7Hl+9JOj0DaJ9VOFMpaI26Vus2KBuMVju1QgX6EWkH8uPD Whfw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from; bh=2IdLqQiANsaR2PcCYUS7esNUY4hxU3kJY1VnndYIs1o=; b=QTsLABHUKAYVvizcnf+bDsbkhHzKLji9ro7tgHX3JA3wHFeRByS29tvLhlvf4KLjwO rJL3/PTXoGWI/2zsb/PywypTht+tu06fhf2MstYjpcZWtL+44mIiCPcQo29CU7UGLhCM cdyNOy0XpZTRQJhRpWaf3fH3K8X3FC9mJje9s+qq37cPfmILia9B+gZVQrw+KfK/IiQB p39EaaQdEbtyGJsUHZFdXRYo38C+DwdIY/JWfqVjwOEPigOCkLQ2FwGHkONC7doaVHKW D4abHfTFXDBwW8UNluwiXw6Gp+Dontzkp555GXW8ZwFCFs5SA8a43RutnX2rGH70c5I8 KVzw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p6-v6si19701532plq.233.2018.10.17.20.24.22; Wed, 17 Oct 2018 20:24:38 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727408AbeJRLWh (ORCPT + 99 others); Thu, 18 Oct 2018 07:22:37 -0400 Received: from mailgw01.mediatek.com ([210.61.82.183]:30039 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1727260AbeJRLWh (ORCPT ); Thu, 18 Oct 2018 07:22:37 -0400 X-UUID: e51f200e0df94dda90367f309991c1a7-20181018 X-UUID: e51f200e0df94dda90367f309991c1a7-20181018 Received: from mtkcas08.mediatek.inc [(172.21.101.126)] by mailgw01.mediatek.com (envelope-from ) (mhqrelay.mediatek.com ESMTP with TLS) with ESMTP id 523055548; Thu, 18 Oct 2018 11:23:40 +0800 Received: from mtkcas08.mediatek.inc (172.21.101.126) by mtkmbs08n2.mediatek.inc (172.21.101.56) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Thu, 18 Oct 2018 11:23:37 +0800 Received: from localhost.localdomain (10.17.3.153) by mtkcas08.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1395.4 via Frontend Transport; Thu, 18 Oct 2018 11:23:37 +0800 From: To: , , , , , CC: , , , , Honghui Zhang Subject: [PATCH] PCI: mediatek: Use devm_of_pci_get_host_bridge_resources() to parse DT Date: Thu, 18 Oct 2018 11:23:34 +0800 Message-ID: <1539833014-1738-1-git-send-email-honghui.zhang@mediatek.com> X-Mailer: git-send-email 2.6.4 MIME-Version: 1.0 Content-Type: text/plain X-TM-SNTS-SMTP: 02CCF5676C0ADB95BC049CEC9A168FAC163EAFCA2F550AC4B8C205C5D51D42F12000:8 X-MTK: N Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Honghui Zhang Use the devm_of_pci_get_host_bridge_resources() API in place of the PCI OF DT parser. Signed-off-by: Honghui Zhang --- drivers/pci/controller/pcie-mediatek.c | 109 +++++++++------------------------ 1 file changed, 29 insertions(+), 80 deletions(-) diff --git a/drivers/pci/controller/pcie-mediatek.c b/drivers/pci/controller/pcie-mediatek.c index 2a1f97c..6632d4e 100644 --- a/drivers/pci/controller/pcie-mediatek.c +++ b/drivers/pci/controller/pcie-mediatek.c @@ -197,29 +197,20 @@ struct mtk_pcie_port { * @dev: pointer to PCIe device * @base: IO mapped register base * @free_ck: free-run reference clock - * @io: IO resource - * @pio: PIO resource * @mem: non-prefetchable memory resource - * @busn: bus range - * @offset: IO / Memory offset * @ports: pointer to PCIe port information * @soc: pointer to SoC-dependent operations + * @busnr: root bus number */ struct mtk_pcie { struct device *dev; void __iomem *base; struct clk *free_ck; - struct resource io; - struct resource pio; struct resource mem; - struct resource busn; - struct { - resource_size_t mem; - resource_size_t io; - } offset; struct list_head ports; const struct mtk_pcie_soc *soc; + int busnr; }; static void mtk_pcie_subsys_powerdown(struct mtk_pcie *pcie) @@ -1045,55 +1036,42 @@ static int mtk_pcie_setup(struct mtk_pcie *pcie) { struct device *dev = pcie->dev; struct device_node *node = dev->of_node, *child; - struct of_pci_range_parser parser; - struct of_pci_range range; - struct resource res; struct mtk_pcie_port *port, *tmp; + struct pci_host_bridge *host = pci_host_bridge_from_priv(pcie); + struct list_head *windows = &host->windows; + struct resource_entry *win, *tmp_win; + resource_size_t io_base; int err; - if (of_pci_range_parser_init(&parser, node)) { - dev_err(dev, "missing \"ranges\" property\n"); - return -EINVAL; - } + err = devm_of_pci_get_host_bridge_resources(dev, 0, 0xff, + windows, &io_base); + if (err) + return err; - for_each_of_pci_range(&parser, &range) { - err = of_pci_range_to_resource(&range, node, &res); - if (err < 0) - return err; + err = devm_request_pci_bus_resources(dev, windows); + if (err < 0) + return err; - switch (res.flags & IORESOURCE_TYPE_BITS) { + /* Get the I/O and memory ranges from DT */ + resource_list_for_each_entry_safe(win, tmp_win, windows) { + switch (resource_type(win->res)) { case IORESOURCE_IO: - pcie->offset.io = res.start - range.pci_addr; - - memcpy(&pcie->pio, &res, sizeof(res)); - pcie->pio.name = node->full_name; - - pcie->io.start = range.cpu_addr; - pcie->io.end = range.cpu_addr + range.size - 1; - pcie->io.flags = IORESOURCE_MEM; - pcie->io.name = "I/O"; - - memcpy(&res, &pcie->io, sizeof(res)); - break; - + err = devm_pci_remap_iospace(dev, win->res, io_base); + if (err) { + dev_warn(dev, "error %d: failed to map resource %pR\n", + err, win->res); + resource_list_destroy_entry(win); + } case IORESOURCE_MEM: - pcie->offset.mem = res.start - range.pci_addr; - - memcpy(&pcie->mem, &res, sizeof(res)); + memcpy(&pcie->mem, win->res, sizeof(*win->res)); pcie->mem.name = "non-prefetchable"; break; + case IORESOURCE_BUS: + pcie->busnr = win->res->start; + break; } } - err = of_pci_parse_bus_range(node, &pcie->busn); - if (err < 0) { - dev_err(dev, "failed to parse bus ranges property: %d\n", err); - pcie->busn.name = node->name; - pcie->busn.start = 0; - pcie->busn.end = 0xff; - pcie->busn.flags = IORESOURCE_BUS; - } - for_each_available_child_of_node(node, child) { int slot; @@ -1125,28 +1103,6 @@ static int mtk_pcie_setup(struct mtk_pcie *pcie) return 0; } -static int mtk_pcie_request_resources(struct mtk_pcie *pcie) -{ - struct pci_host_bridge *host = pci_host_bridge_from_priv(pcie); - struct list_head *windows = &host->windows; - struct device *dev = pcie->dev; - int err; - - pci_add_resource_offset(windows, &pcie->pio, pcie->offset.io); - pci_add_resource_offset(windows, &pcie->mem, pcie->offset.mem); - pci_add_resource(windows, &pcie->busn); - - err = devm_request_pci_bus_resources(dev, windows); - if (err < 0) - return err; - - err = devm_pci_remap_iospace(dev, &pcie->pio, pcie->io.start); - if (err < 0) - return err; - - return 0; -} - static int mtk_pcie_probe(struct platform_device *pdev) { struct device *dev = &pdev->dev; @@ -1169,11 +1125,7 @@ static int mtk_pcie_probe(struct platform_device *pdev) if (err) return err; - err = mtk_pcie_request_resources(pcie); - if (err) - goto put_resources; - - host->busnr = pcie->busn.start; + host->busnr = pcie->busnr; host->dev.parent = pcie->dev; host->ops = pcie->soc->ops; host->map_irq = of_irq_parse_and_map_pci; @@ -1181,12 +1133,9 @@ static int mtk_pcie_probe(struct platform_device *pdev) host->sysdata = pcie; err = pci_host_probe(host); - if (err) - goto put_resources; - - return 0; + if (!err) + return 0; -put_resources: if (!list_empty(&pcie->ports)) mtk_pcie_put_resources(pcie); -- 2.6.4