Received: by 2002:a25:824b:0:0:0:0:0 with SMTP id d11csp1255325ybn; Wed, 25 Sep 2019 15:07:53 -0700 (PDT) X-Google-Smtp-Source: APXvYqweP3uEsQKBiOWcdYezbAGCI+cI7jTKc1cKpeX9cGMqYDBfFcexiOcsYZHabjo0E+gJ6akt X-Received: by 2002:a50:ed82:: with SMTP id h2mr253690edr.206.1569449273814; Wed, 25 Sep 2019 15:07:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1569449273; cv=none; d=google.com; s=arc-20160816; b=KxTCsWAYjaAqOjs0pIpW+CERyJk+m7UN9Jy+O5u8TvcCmoaQppiUPUxQ62A7sCamLM kH+Sxc8ZyJUo3cn14Wc+Jo1JfQ0q9M/lnhQ6c2V0I93VBmnNZRhlrFDbB8BZmIuvI1bH hFBZhJrrg9/hrwlYqgxhrrRDcVHGWB/AYTZMJbA/lgCdkR4/OugkVWjXwNvp5VkmQSFq ng8JT6DA4naud4lPZX43nv4ebZNvb5PV4LrdEudiH/oQZkO+8ahJQvX/Z/XaKbqaajeO SL732jEhymbgEhpay36PbYl5KnbnV0o/gNeQn40BpV+rvdd4+eZAKB3ymGwcwuMw9iqy XakA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=kmAEe2X2pOHOd3z9/qTcCEfQ6MxR48p70s/DYV0iUnM=; b=JVTcsD/MSHIyXy/4LHOd7y8DuB2oHHqCnPziK0bR+qq9nKzu92Z1yiHpTbhNmcnQGg bhnb9CHlzKNoTmVeit4NbPIHeRa3RVfdY9RimDneEMORB2eTi5LR1g9rWvm+AMPjOAIx w05Ajijo0K2RTww0/m/wol9OcG7dSIfmiEEdmQaWFsDWSc0ykpXTtieD40+kfJKfbOw8 yteaVrUqXgzTlk6ciUPuwtK7BrTLENG+XgFIvDMvEMuUJLRIwH5R9BYRzQ1ABflZaIj6 7RLGKpgU2sMkfkxu7AdUACg+DhLNSldEuQDdUcLK9zT7mXDazjYGR7PhzL1+75qYHsi9 xPsg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t4si67459ejs.387.2019.09.25.15.07.29; Wed, 25 Sep 2019 15:07:53 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2502184AbfIWS0s (ORCPT + 99 others); Mon, 23 Sep 2019 14:26:48 -0400 Received: from foss.arm.com ([217.140.110.172]:46706 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2440471AbfIWS0r (ORCPT ); Mon, 23 Sep 2019 14:26:47 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 7985B15BF; Mon, 23 Sep 2019 11:26:46 -0700 (PDT) Received: from big-swifty.lan (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id B381E3F694; Mon, 23 Sep 2019 11:26:43 -0700 (PDT) From: Marc Zyngier To: kvmarm@lists.cs.columbia.edu, linux-kernel@vger.kernel.org Cc: Eric Auger , James Morse , Julien Thierry , Suzuki K Poulose , Thomas Gleixner , Jason Cooper , Lorenzo Pieralisi , Andrew Murray Subject: [PATCH 05/35] irqchip/gic-v3: Add GICv4.1 VPEID size discovery Date: Mon, 23 Sep 2019 19:25:36 +0100 Message-Id: <20190923182606.32100-6-maz@kernel.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190923182606.32100-1-maz@kernel.org> References: <20190923182606.32100-1-maz@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org While GICv4.0 mandates 16 bit worth of VPEIDs, GICv4.1 allows smaller implementations to be built. Add the required glue to dynamically compute the limit. Signed-off-by: Marc Zyngier --- drivers/irqchip/irq-gic-v3-its.c | 11 ++++++++++- drivers/irqchip/irq-gic-v3.c | 3 +++ include/linux/irqchip/arm-gic-v3.h | 5 +++++ 3 files changed, 18 insertions(+), 1 deletion(-) diff --git a/drivers/irqchip/irq-gic-v3-its.c b/drivers/irqchip/irq-gic-v3-its.c index c94eb287393b..17b77a0b9d97 100644 --- a/drivers/irqchip/irq-gic-v3-its.c +++ b/drivers/irqchip/irq-gic-v3-its.c @@ -119,7 +119,16 @@ struct its_node { #define ITS_ITT_ALIGN SZ_256 /* The maximum number of VPEID bits supported by VLPI commands */ -#define ITS_MAX_VPEID_BITS (16) +#define ITS_MAX_VPEID_BITS \ + ({ \ + int nvpeid = 16; \ + if (gic_rdists->has_rvpeid && \ + gic_rdists->gicd_typer2 & GICD_TYPER2_VIL) \ + nvpeid = 1 + (gic_rdists->gicd_typer2 & \ + GICD_TYPER2_VID); \ + \ + nvpeid; \ + }) #define ITS_MAX_VPEID (1 << (ITS_MAX_VPEID_BITS)) /* Convert page order to size in bytes */ diff --git a/drivers/irqchip/irq-gic-v3.c b/drivers/irqchip/irq-gic-v3.c index 0b545e2c3498..fb6360161d6c 100644 --- a/drivers/irqchip/irq-gic-v3.c +++ b/drivers/irqchip/irq-gic-v3.c @@ -1556,6 +1556,9 @@ static int __init gic_init_bases(void __iomem *dist_base, pr_info("%d SPIs implemented\n", GIC_LINE_NR - 32); pr_info("%d Extended SPIs implemented\n", GIC_ESPI_NR); + + gic_data.rdists.gicd_typer2 = readl_relaxed(gic_data.dist_base + GICD_TYPER2); + gic_data.domain = irq_domain_create_tree(handle, &gic_irq_domain_ops, &gic_data); irq_domain_update_bus_token(gic_data.domain, DOMAIN_BUS_WIRED); diff --git a/include/linux/irqchip/arm-gic-v3.h b/include/linux/irqchip/arm-gic-v3.h index b34e0c113697..71730b9def0c 100644 --- a/include/linux/irqchip/arm-gic-v3.h +++ b/include/linux/irqchip/arm-gic-v3.h @@ -13,6 +13,7 @@ #define GICD_CTLR 0x0000 #define GICD_TYPER 0x0004 #define GICD_IIDR 0x0008 +#define GICD_TYPER2 0x000C #define GICD_STATUSR 0x0010 #define GICD_SETSPI_NSR 0x0040 #define GICD_CLRSPI_NSR 0x0048 @@ -89,6 +90,9 @@ #define GICD_TYPER_ESPIS(typer) \ (((typer) & GICD_TYPER_ESPI) ? GICD_TYPER_SPIS((typer) >> 27) : 0) +#define GICD_TYPER2_VIL (1U << 7) +#define GICD_TYPER2_VID GENMASK(4, 0) + #define GICD_IROUTER_SPI_MODE_ONE (0U << 31) #define GICD_IROUTER_SPI_MODE_ANY (1U << 31) @@ -613,6 +617,7 @@ struct rdists { void *prop_table_va; u64 flags; u32 gicd_typer; + u32 gicd_typer2; bool has_vlpis; bool has_rvpeid; bool has_direct_lpi; -- 2.20.1