Received: by 2002:a25:824b:0:0:0:0:0 with SMTP id d11csp1273533ybn; Wed, 25 Sep 2019 15:25:14 -0700 (PDT) X-Google-Smtp-Source: APXvYqwa8jqa/VBiV1Ju7H3GcS1VOkv8MF55MiH1bjJn63We5yN6si6s6jgbjkBhhQcmzQPF64IF X-Received: by 2002:a50:d0d5:: with SMTP id g21mr325432edf.204.1569450314690; Wed, 25 Sep 2019 15:25:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1569450314; cv=none; d=google.com; s=arc-20160816; b=FDDNcqc5Tw3tMWjGGnYTvRhWo0izIjhJw3VWr+8U6VxcM97zPqE7ku2VnBWqwkP00h EigOSRXnd8JiKN8XosHZe5th+Khh9roT8ry2UzBT5I+tdl3AZMQy1krphhsl7v6SJDBw i3/22nI7Vg/sN71hJ6/WB+LAiu+I4CKUrJ66X7FyRy5cLbH/nbehPiw9vkDbVos+BZW+ qrz7tCNtoLGr0Fl0883ZOF1AEmSs8qKKX0UbdmwznaEB9vTuqbhUKWx0KIdOyBz+rYTa /DuAa5qAYPCv8nXJtsOe7WV0e4vpLH9prGzDNT7W01ys2Uz2cSgcLZJlyQC1p5Ty+Hgp +3TA== 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=1oHhR9406/zQp+V4kQIdP6f9enR12mRuwreJ3xcTNbo=; b=fwzkaRh26kF/EAonHgcwChe13RA9dp+/7jXuB5HAIqw7E0ATcLOo8eH0Si5Oc57RcD Y1T6tyYIU+79bfvVCjWtQcEr+iuQLQaTokMwImE6GdeEqBpAYQr7irBaewfX+OkHalIa dXUZsuPyMjZpdMvOAzEUMkYCUB1wH+Ym/kz4Oq3yoN8kNlEVQqcB6SJiqH0aa42vo/Nd KjNAMh94Y6PBHtdXixgZKF6LwNwM3YgOeQE+GvndgLpBLlQeFp4Mfw7b4bzNuI3ecLU3 uFg/U+YmhSlOz3qpxmh8U7Sl957HGg43nCIGM9uSoRsLSm/ydRM4LmJhfMfla0HAVO1k yvYw== 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 f5si230700edx.302.2019.09.25.15.24.50; Wed, 25 Sep 2019 15:25:14 -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 S1733101AbfIWS2g (ORCPT + 99 others); Mon, 23 Sep 2019 14:28:36 -0400 Received: from foss.arm.com ([217.140.110.172]:47296 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726059AbfIWS2f (ORCPT ); Mon, 23 Sep 2019 14:28:35 -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 CC37E2E8E; Mon, 23 Sep 2019 11:28:34 -0700 (PDT) Received: from big-swifty.lan (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 58AFD3F694; Mon, 23 Sep 2019 11:28:32 -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 35/35] KVM: arm64: GICv4.1: Expose HW-based SGIs in debugfs Date: Mon, 23 Sep 2019 19:26:06 +0100 Message-Id: <20190923182606.32100-36-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 The vgic-state debugfs file could do with showing the pending state of the HW-backed SGIs. Plug it into the low-level code. Signed-off-by: Marc Zyngier --- virt/kvm/arm/vgic/vgic-debug.c | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/virt/kvm/arm/vgic/vgic-debug.c b/virt/kvm/arm/vgic/vgic-debug.c index cc12fe9b2df3..98f3242a34a6 100644 --- a/virt/kvm/arm/vgic/vgic-debug.c +++ b/virt/kvm/arm/vgic/vgic-debug.c @@ -178,6 +178,8 @@ static void print_irq_state(struct seq_file *s, struct vgic_irq *irq, struct kvm_vcpu *vcpu) { char *type; + bool pending; + if (irq->intid < VGIC_NR_SGIS) type = "SGI"; else if (irq->intid < VGIC_NR_PRIVATE_IRQS) @@ -190,6 +192,16 @@ static void print_irq_state(struct seq_file *s, struct vgic_irq *irq, if (irq->intid ==0 || irq->intid == VGIC_NR_PRIVATE_IRQS) print_header(s, irq, vcpu); + pending = irq->pending_latch; + if (irq->hw && vgic_irq_is_sgi(irq->intid)) { + int err; + + err = irq_get_irqchip_state(irq->host_irq, + IRQCHIP_STATE_PENDING, + &pending); + WARN_ON_ONCE(err); + } + seq_printf(s, " %s %4d " " %2d " "%d%d%d%d%d%d%d " @@ -201,7 +213,7 @@ static void print_irq_state(struct seq_file *s, struct vgic_irq *irq, "\n", type, irq->intid, (irq->target_vcpu) ? irq->target_vcpu->vcpu_id : -1, - irq->pending_latch, + pending, irq->line_level, irq->active, irq->enabled, -- 2.20.1