From patchwork Thu Dec 1 07:45:59 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "majun \(F\)" X-Patchwork-Id: 85973 Delivered-To: patch@linaro.org Received: by 10.140.20.101 with SMTP id 92csp577725qgi; Wed, 30 Nov 2016 23:47:04 -0800 (PST) X-Received: by 10.98.35.211 with SMTP id q80mr37743768pfj.26.1480578424281; Wed, 30 Nov 2016 23:47:04 -0800 (PST) Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d30si39728577plj.293.2016.11.30.23.47.03; Wed, 30 Nov 2016 23:47:04 -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 S1758867AbcLAHqj (ORCPT + 25 others); Thu, 1 Dec 2016 02:46:39 -0500 Received: from szxga03-in.huawei.com ([119.145.14.66]:55022 "EHLO szxga03-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755599AbcLAHqg (ORCPT ); Thu, 1 Dec 2016 02:46:36 -0500 Received: from 172.24.1.60 (EHLO szxeml431-hub.china.huawei.com) ([172.24.1.60]) by szxrg03-dlp.huawei.com (MOS 4.4.3-GA FastPath queued) with ESMTP id CMD74816; Thu, 01 Dec 2016 15:46:12 +0800 (CST) Received: from localhost (10.177.249.226) by szxeml431-hub.china.huawei.com (10.82.67.208) with Microsoft SMTP Server id 14.3.235.1; Thu, 1 Dec 2016 15:46:04 +0800 From: Majun To: , , , , , , , , , , CC: , , Subject: [RFC PATCH 2/3] irqchip/gicv3-its: add a new flag to control indirect route in DT mode Date: Thu, 1 Dec 2016 15:45:59 +0800 Message-ID: <1480578360-9268-3-git-send-email-majun258@huawei.com> X-Mailer: git-send-email 1.9.5.msysgit.1 In-Reply-To: <1480578360-9268-1-git-send-email-majun258@huawei.com> References: <1480578360-9268-1-git-send-email-majun258@huawei.com> MIME-Version: 1.0 X-Originating-IP: [10.177.249.226] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: MaJun Add a new flag for ITS node in DT mode so we can disable/enable the indirect route function. Signed-off-by: MaJun --- drivers/irqchip/irq-gic-v3-its.c | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) -- 1.7.12.4 diff --git a/drivers/irqchip/irq-gic-v3-its.c b/drivers/irqchip/irq-gic-v3-its.c index d278425..ee54133 100644 --- a/drivers/irqchip/irq-gic-v3-its.c +++ b/drivers/irqchip/irq-gic-v3-its.c @@ -46,6 +46,7 @@ #define ITS_FLAGS_CMDQ_NEEDS_FLUSHING (1ULL << 0) #define ITS_FLAGS_WORKAROUND_CAVIUM_22375 (1ULL << 1) #define ITS_FLAGS_WORKAROUND_CAVIUM_23144 (1ULL << 2) +#define ITS_FLAGS_INDIRECT_ROUTE (1ULL << 3) #define RDIST_FLAGS_PROPBASE_NEEDS_FLUSHING (1 << 0) @@ -967,7 +968,7 @@ static bool its_parse_baser_device(struct its_node *its, struct its_baser *baser bool indirect = false; /* No need to enable Indirection if memory requirement < (psz*2)bytes */ - if ((esz << ids) > (psz * 2)) { + if ((its->flags & ITS_FLAGS_INDIRECT_ROUTE) && ((esz << ids) > (psz * 2))) { /* * Find out whether hw supports a single or two-level table by * table by reading bit at offset '62' after writing '1' to it. @@ -1673,8 +1674,8 @@ static int its_init_domain(struct fwnode_handle *handle, struct its_node *its) return 0; } -static int __init its_probe_one(struct resource *res, - struct fwnode_handle *handle, int numa_node) +static int __init its_probe_one(struct resource *res, struct fwnode_handle *handle, + int numa_node, u8 flags) { struct its_node *its; void __iomem *its_base; @@ -1716,6 +1717,7 @@ static int __init its_probe_one(struct resource *res, its->phys_base = res->start; its->ite_size = ((readl_relaxed(its_base + GITS_TYPER) >> 4) & 0xf) + 1; its->numa_node = numa_node; + its->flags |= flags; its->cmd_base = kzalloc(ITS_CMD_QUEUE_SZ, GFP_KERNEL); if (!its->cmd_base) { @@ -1812,6 +1814,7 @@ static int __init its_of_probe(struct device_node *node) { struct device_node *np; struct resource res; + u8 flags = 0; for (np = of_find_matching_node(node, its_device_id); np; np = of_find_matching_node(np, its_device_id)) { @@ -1826,7 +1829,10 @@ static int __init its_of_probe(struct device_node *node) continue; } - its_probe_one(&res, &np->fwnode, of_node_to_nid(np)); + if (of_property_read_bool(np, "two-level-route")) + flags |= ITS_FLAGS_INDIRECT_ROUTE; + + its_probe_one(&res, &np->fwnode, of_node_to_nid(np), flags); } return 0; } @@ -1863,7 +1869,7 @@ static int __init gic_acpi_parse_madt_its(struct acpi_subtable_header *header, goto dom_err; } - err = its_probe_one(&res, dom_handle, NUMA_NO_NODE); + err = its_probe_one(&res, dom_handle, NUMA_NO_NODE, 0); if (!err) return 0;