From patchwork Tue Oct 1 02:43:09 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Anshuman Khandual X-Patchwork-Id: 13817356 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 7773FCEB2DB for ; Tue, 1 Oct 2024 02:46:53 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: MIME-Version:Message-Id:Date:Subject:Cc:To:From:Reply-To:Content-Type: Content-ID:Content-Description:Resent-Date:Resent-From:Resent-Sender: Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References:List-Owner; bh=MEsExnXhCoAgONDsM6CwTkSyr+RpYP8E24+fo+bEjTg=; b=QJMd6wRm0WIPg6X3fOcqIWrgfO SPAnEoa49pDZOPpqUXA9q0elvFAsMx3STE+rhAyFa2HmhqITHU8xFAq/QjOei2czQp6m1cXaiNjeC 3T8ncBe4e4GpmMdB5ZfYq6sAfNSEzsWMVXTwpfQ0GjblISS11X285fi1/iuJGSNAAX+6OmLP1tC+O udS+4bfpZmE7Y6zdix1mncjoIqrzgGzSoQxX59tdFeSEUy8jkI0Oy15tUjo7PBoq11xqeSMhgWVPH OF8WZOrtv5oNbjN4qFS74OwNNury29MdnZ47ON1Zm1WK+jgV2zvsOINImdvcBSJrx/wMqY7kfJE41 QnTYEsgQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1svSuQ-00000001NuJ-1VG9; Tue, 01 Oct 2024 02:46:42 +0000 Received: from foss.arm.com ([217.140.110.172]) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1svSrw-00000001N67-461A for linux-arm-kernel@lists.infradead.org; Tue, 01 Oct 2024 02:44:11 +0000 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 DC869367; Mon, 30 Sep 2024 19:44:34 -0700 (PDT) Received: from a077893.blr.arm.com (a077893.blr.arm.com [10.162.16.61]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id F284D3F58B; Mon, 30 Sep 2024 19:44:01 -0700 (PDT) From: Anshuman Khandual To: linux-kernel@vger.kernel.org, kvmarm@lists.linux.dev, linux-arm-kernel@lists.infradead.org, maz@kernel.org Cc: Anshuman Khandual , Oliver Upton , James Morse , Suzuki K Poulose , Catalin Marinas , Will Deacon , Mark Brown Subject: [PATCH 00/47] KVM: arm64: Enable FGU (Fine Grained Undefined) for FEAT_FGT2 registers Date: Tue, 1 Oct 2024 08:13:09 +0530 Message-Id: <20241001024356.1096072-1-anshuman.khandual@arm.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20240930_194409_123166_48E46936 X-CRM114-Status: UNSURE ( 8.37 ) X-CRM114-Notice: Please train this message. X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org This series enables fine grained undefined for FEAT_FGT2 managed registers via adding their respective FGT and CGT trap configuration. But first this adds many system register definitions in tools/sysreg, which are required there after. patches 1-44: define system registers in tools/sysreg format patch 45: enables FEAT_FGT2 registers access from virtual EL2 patch 46: enables FGT for FEAT_FGT2 patch 47: enables CGT for FEAT_FGT2 Some notes: As kvm_has_feat() does not support non-ID registers following replacements have been made for validating presence of correspnding features - ID_AA64DFR0_EL1.ExtTrcBuff is tested for HDFGRTR2_EL2.nPMSDSFR_EL1 - ID_AA64DFR0_EL1.PMSVer is tested for HDFGRTR2_EL2.nPMSDSFR_EL1 Following FGT enabled registers don't have corresponding CGT requirements - TRCITECR_EL1 - PMSSCR_EL1 - PMCCNTSVR_EL1 - PMICNTSVR_EL1 - RCWSMASK_EL1 - ERXGSR_EL1 - PFAR_EL1 Changes in V2: - Added all system register definitions required for FEAT_FGT2 traps - Added all system register access traps managed with new FEAT_FGT2 i.e HDFGRTR2_EL2, HDFGWTR2_EL2, HFGRTR2_GROUP, HFGWTR2_GROUP and HFGITR2_GROUP for their VNCR access, FGT and CGT - Added all FGT for all register accesses managed with FEAT_FGT2 - Added all CGT for all register accesses managed with FEAT_FGT2 Changes in RFC V1: https://lore.kernel.org/linux-arm-kernel/20240620065807.151540-1-anshuman.khandual@arm.com/ Cc: Marc Zyngier Cc: Oliver Upton Cc: James Morse Cc: Suzuki K Poulose Cc: Catalin Marinas Cc: Will Deacon Cc: Mark Brown Cc: linux-arm-kernel@lists.infradead.org Cc: kvmarm@lists.linux.dev Cc: linux-kernel@vger.kernel.org Anshuman Khandual (47): arm64/sysreg: Update register fields for ID_AA64MMFR0_EL1 arm64/sysreg: Update register fields for ID_AA64DFR0_EL1 arm64/sysreg: Update register fields for ID_AA64PFR0_EL1 arm64/sysreg: Add register fields for ID_AA64DFR2_EL1 arm64/sysreg: Add register fields for HDFGRTR2_EL2 arm64/sysreg: Add register fields for HDFGWTR2_EL2 arm64/sysreg: Add register fields for HFGITR2_EL2 arm64/sysreg: Add register fields for HFGRTR2_EL2 arm64/sysreg: Add register fields for HFGWTR2_EL2 arm64/sysreg: Add register fields for MDSELR_EL1 arm64/sysreg: Add register fields for PMSIDR_EL1 arm64/sysreg: Add register fields for TRBIDR_EL1 arm64/sysreg: Add register fields for TRBMPAM_EL1 arm64/sysreg: Add register fields for PMSDSFR_EL1 arm64/sysreg: Add register fields for SPMDEVAFF_EL1 arm64/sysreg: Add register fields for PFAR_EL1 arm64/sysreg: Add register fields for PMIAR_EL1 arm64/sysreg: Add register fields for PMECR_EL1 arm64/sysreg: Add register fields for PMUACR_EL1 arm64/sysreg: Add register fields for PMCCNTSVR_EL1 arm64/sysreg: Add register fields for SPMSCR_EL1 arm64/sysreg: Add register fields for SPMACCESSR_EL1 arm64/sysreg: Add register fields for PMICNTR_EL0 arm64/sysreg: Add register fields for PMICFILTR_EL0 arm64/sysreg: Add register fields for SPMCR_EL0 arm64/sysreg: Add register fields for SPMOVSCLR_EL0 arm64/sysreg: Add register fields for SPMOVSSET_EL0 arm64/sysreg: Add register fields for SPMINTENCLR_EL1 arm64/sysreg: Add register fields for SPMINTENSET_EL1 arm64/sysreg: Add register fields for SPMCNTENCLR_EL0 arm64/sysreg: Add register fields for SPMCNTENSET_EL0 arm64/sysreg: Add register fields for SPMSELR_EL0 arm64/sysreg: Add register fields for PMICNTSVR_EL1 arm64/sysreg: Add register fields for SPMIIDR_EL1 arm64/sysreg: Add register fields for SPMDEVARCH_EL1 arm64/sysreg: Add register fields for SPMCFGR_EL1 arm64/sysreg: Add register fields for PMSSCR_EL1 arm64/sysreg: Add register fields for PMZR_EL0 arm64/sysreg: Add register fields for SPMCGCR0_EL1 arm64/sysreg: Add register fields for SPMCGCR1_EL1 arm64/sysreg: Add register fields for MDSTEPOP_EL1 arm64/sysreg: Add register fields for ERXGSR_EL1 arm64/sysreg: Add register fields for SPMACCESSR_EL2 arm64/sysreg: Add remaining debug registers affected by HDFGxTR2_EL2 KVM: arm64: nv: Add FEAT_FGT2 registers access from virtual EL2 KVM: arm64: nv: Add FEAT_FGT2 registers based FGU handling KVM: arm64: nv: Add trap forwarding for FEAT_FGT2 described registers arch/arm64/include/asm/kvm_arm.h | 22 + arch/arm64/include/asm/kvm_host.h | 12 + arch/arm64/include/asm/sysreg.h | 6 + arch/arm64/include/asm/vncr_mapping.h | 5 + arch/arm64/kvm/emulate-nested.c | 444 +++++++++++ arch/arm64/kvm/hyp/include/hyp/switch.h | 26 + arch/arm64/kvm/nested.c | 52 ++ arch/arm64/kvm/sys_regs.c | 64 ++ arch/arm64/tools/sysreg | 938 +++++++++++++++++++++++- 9 files changed, 1564 insertions(+), 5 deletions(-)