[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20250424-gicv5-host-v2-15-545edcaf012b@kernel.org>
Date: Thu, 24 Apr 2025 12:25:26 +0200
From: Lorenzo Pieralisi <lpieralisi@...nel.org>
To: Marc Zyngier <maz@...nel.org>, Thomas Gleixner <tglx@...utronix.de>,
Rob Herring <robh@...nel.org>, Krzysztof Kozlowski <krzk+dt@...nel.org>,
Conor Dooley <conor+dt@...nel.org>,
Catalin Marinas <catalin.marinas@....com>, Will Deacon <will@...nel.org>
Cc: Arnd Bergmann <arnd@...db.de>,
Sascha Bischoff <sascha.bischoff@....com>,
Timothy Hayes <timothy.hayes@....com>,
"Liam R. Howlett" <Liam.Howlett@...cle.com>,
Mark Rutland <mark.rutland@....com>, linux-arm-kernel@...ts.infradead.org,
linux-kernel@...r.kernel.org, devicetree@...r.kernel.org,
Lorenzo Pieralisi <lpieralisi@...nel.org>
Subject: [PATCH v2 15/22] arm64: Disable GICv5 read/write/instruction traps
GICv5 trap configuration registers value is UNKNOWN at reset.
Initialize GICv5 EL2 trap configuration registers to prevent
trapping GICv5 instruction/register access upon entering the
kernel.
Signed-off-by: Lorenzo Pieralisi <lpieralisi@...nel.org>
Cc: Will Deacon <will@...nel.org>
Cc: Catalin Marinas <catalin.marinas@....com>
Cc: Marc Zyngier <maz@...nel.org>
---
arch/arm64/include/asm/el2_setup.h | 45 ++++++++++++++++++++++++++++++++++++++
1 file changed, 45 insertions(+)
diff --git a/arch/arm64/include/asm/el2_setup.h b/arch/arm64/include/asm/el2_setup.h
index ebceaae3c749b84395c9c5eccf0caf874697ad11..1e362bb3b042d51fff15a7c2abc73842930b275a 100644
--- a/arch/arm64/include/asm/el2_setup.h
+++ b/arch/arm64/include/asm/el2_setup.h
@@ -165,6 +165,50 @@
.Lskip_gicv3_\@:
.endm
+/* GICv5 system register access */
+.macro __init_el2_gicv5
+ mrs_s x0, SYS_ID_AA64PFR2_EL1
+ ubfx x0, x0, #ID_AA64PFR2_EL1_GCIE_SHIFT, #4
+ cbz x0, .Lskip_gicv5_\@
+
+ mov x0, #(1 << ICH_HFGITR_EL2_GICRCDNMIA_SHIFT | \
+ 1 << ICH_HFGITR_EL2_GICRCDIA_SHIFT | \
+ 1 << ICH_HFGITR_EL2_GICCDDI_SHIFT | \
+ 1 << ICH_HFGITR_EL2_GICCDEOI_SHIFT | \
+ 1 << ICH_HFGITR_EL2_GICCDHM_SHIFT | \
+ 1 << ICH_HFGITR_EL2_GICCRDRCFG_SHIFT | \
+ 1 << ICH_HFGITR_EL2_GICCDPEND_SHIFT | \
+ 1 << ICH_HFGITR_EL2_GICCDAFF_SHIFT | \
+ 1 << ICH_HFGITR_EL2_GICCDPRI_SHIFT | \
+ 1 << ICH_HFGITR_EL2_GICCDDIS_SHIFT | \
+ 1 << ICH_HFGITR_EL2_GICCDEN_SHIFT)
+ msr_s SYS_ICH_HFGITR_EL2, x0 // Disable instruction traps
+ mov_q x0, (1 << ICH_HFGRTR_EL2_ICC_PPI_ACTIVERn_EL1_SHIFT | \
+ 1 << ICH_HFGRTR_EL2_ICC_PPI_PRIORITYRn_EL1_SHIFT | \
+ 1 << ICH_HFGRTR_EL2_ICC_PPI_PENDRn_EL1_SHIFT | \
+ 1 << ICH_HFGRTR_EL2_ICC_PPI_ENABLERn_EL1_SHIFT | \
+ 1 << ICH_HFGRTR_EL2_ICC_PPI_HMRn_EL1_SHIFT | \
+ 1 << ICH_HFGRTR_EL2_ICC_IAFFIDR_EL1_SHIFT | \
+ 1 << ICH_HFGRTR_EL2_ICC_ICSR_EL1_SHIFT | \
+ 1 << ICH_HFGRTR_EL2_ICC_PCR_EL1_SHIFT | \
+ 1 << ICH_HFGRTR_EL2_ICC_HPPIR_EL1_SHIFT | \
+ 1 << ICH_HFGRTR_EL2_ICC_HAPR_EL1_SHIFT | \
+ 1 << ICH_HFGRTR_EL2_ICC_CR0_EL1_SHIFT | \
+ 1 << ICH_HFGRTR_EL2_ICC_IDRn_EL1_SHIFT | \
+ 1 << ICH_HFGRTR_EL2_ICC_APR_EL1_SHIFT)
+ msr_s SYS_ICH_HFGRTR_EL2, x0 // Disable reg read traps
+ mov_q x0, (1 << ICH_HFGWTR_EL2_ICC_PPI_ACTIVERn_EL1_SHIFT | \
+ 1 << ICH_HFGWTR_EL2_ICC_PPI_PRIORITYRn_EL1_SHIFT | \
+ 1 << ICH_HFGWTR_EL2_ICC_PPI_PENDRn_EL1_SHIFT | \
+ 1 << ICH_HFGWTR_EL2_ICC_PPI_ENABLERn_EL1_SHIFT | \
+ 1 << ICH_HFGWTR_EL2_ICC_ICSR_EL1_SHIFT | \
+ 1 << ICH_HFGWTR_EL2_ICC_PCR_EL1_SHIFT | \
+ 1 << ICH_HFGWTR_EL2_ICC_CR0_EL1_SHIFT | \
+ 1 << ICH_HFGWTR_EL2_ICC_APR_EL1_SHIFT)
+ msr_s SYS_ICH_HFGWTR_EL2, x0 // Disable reg write traps
+.Lskip_gicv5_\@:
+.endm
+
.macro __init_el2_hstr
msr hstr_el2, xzr // Disable CP15 traps to EL2
.endm
@@ -323,6 +367,7 @@
__init_el2_lor
__init_el2_stage2
__init_el2_gicv3
+ __init_el2_gicv5
__init_el2_hstr
__init_el2_mpam
__init_el2_nvhe_idregs
--
2.48.0
Powered by blists - more mailing lists