Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3275003imu; Thu, 29 Nov 2018 19:35:37 -0800 (PST) X-Google-Smtp-Source: AFSGD/WxEOPeSLWCXtxqEXojxCmmX1gCtEyTKmRUxn90XodAnRf5RB94jiBEJoE1y0uFK2rBzNv8 X-Received: by 2002:a63:64c:: with SMTP id 73mr3445868pgg.373.1543548937651; Thu, 29 Nov 2018 19:35:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543548937; cv=none; d=google.com; s=arc-20160816; b=AnigD3fo+GjlTOekV+gYvdWn8PwNcV2Y2I7XQrwbRzik2FuQev2fgCqVCeqmysklMG Gwd6550qBnWJNCYBwXhyB0XRlSfrAfy1IloJvJGyo7Gwh9wALgePeNDqeUBfyqpG83SZ czP+oCjZEJMWAXFuOmczjbqXLbQXREu8SB7Kp+XYKa2hKnSgdx/z7LDiI2iSUfJOMKQD Y4lRePa4SIYRQ3UIgs2w+Ho6zBQMfFtXo7nTDWCETiqEp24J9xuqKQk0pljbZcj16B+I Qkh+nFpfs2nTnOwLzczPPf0zHlbQvfks5KDoUQhdl2UBeFOrNntmHsAVvXMJ7NfPN2H9 u5xg== 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=aWkABEnooyzTKKl7DVRZiUGNPmBxxPGy4tSuLS3qWic=; b=JwXByICaSrMjV3Soe+Z7xZUTmrue1+bPF3CucP/+33pcXiybBY7rBy89y03uFDBpds VIV1xjy1pXRuCQyV90GiRmfNh5353EVnb4tjdiofSSJQj4CmN4g2dtqAWBD1eNS020mp rBDwS4QDW3202zCYPtpjqlMZfC5wQ1dJmiuI4Ae7L0Xal0D5xZJse1YQYSjmLFiW7vcI 6qCLUS4vzyKqHkAidCYzpRLaNd41ikg2rULzVhIrl9IcG11mjdgyVVKqon8s4PL0rXQh OteyTONTypJoQT5e27vNfKWaH0SgD8Zw4TnGBfOY1J5/pCqAqvOZBACDxRqFdQKCvRqe 6LfQ== 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 q70si3745509pgq.526.2018.11.29.19.35.22; Thu, 29 Nov 2018 19:35:37 -0800 (PST) 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 S1727246AbeK3OlP (ORCPT + 99 others); Fri, 30 Nov 2018 09:41:15 -0500 Received: from mailgw01.mediatek.com ([210.61.82.183]:47499 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1726161AbeK3OlP (ORCPT ); Fri, 30 Nov 2018 09:41:15 -0500 X-UUID: dcebd37cea2d480980931bf9e712db21-20181130 X-UUID: dcebd37cea2d480980931bf9e712db21-20181130 Received: from mtkexhb02.mediatek.inc [(172.21.101.103)] by mailgw01.mediatek.com (envelope-from ) (mhqrelay.mediatek.com ESMTP with TLS) with ESMTP id 1179112301; Fri, 30 Nov 2018 11:33:16 +0800 Received: from mtkcas09.mediatek.inc (172.21.101.178) by mtkmbs08n1.mediatek.inc (172.21.101.55) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Fri, 30 Nov 2018 11:33:02 +0800 Received: from localhost.localdomain (10.17.3.153) by mtkcas09.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1395.4 via Frontend Transport; Fri, 30 Nov 2018 11:33:02 +0800 From: To: , , , , , , CC: , , , Subject: [PATCH v3] PCI: mediatek: Use devm_of_pci_get_host_bridge_resources() to parse DT Date: Fri, 30 Nov 2018 11:33:00 +0800 Message-ID: <1543548780-3912-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-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 Acked-by: Ryder Lee --- drivers/pci/controller/pcie-mediatek.c | 101 +++++++++------------------------ 1 file changed, 27 insertions(+), 74 deletions(-) diff --git a/drivers/pci/controller/pcie-mediatek.c b/drivers/pci/controller/pcie-mediatek.c index 2a1f97c..6917aec 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; + unsigned int busnr; }; static void mtk_pcie_subsys_powerdown(struct mtk_pcie *pcie) @@ -1045,55 +1036,43 @@ 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)); + 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); + } break; - 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 +1104,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 +1126,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; -- 2.6.4