From 98b2d7acc57b664996de528e6d32ae8abaee2b99 Mon Sep 17 00:00:00 2001 From: Adrian Herrera Date: Thu, 7 Nov 2019 12:30:08 +0000 Subject: arch-arm: AArch64 reg access HCR_EL2.E2H filter Some AArch64 system registers report UNDEFINED behaviours if accessed from EL2 or EL3 in a non-EL2 Host enabled (HCR_EL2.E2H == 0) environment. Examples of these are seen in the Generic Timer system registers, namely CNTP_CTL_EL02 or CNTKCTL_EL12. This patch provides an ISA filter for specifying the above condition. Change-Id: I240f9afdb000faf5d3c9274ba12bd4cc41fe8604 Reviewed-by: Giacomo Travaglini Reviewed-on: https://gem5-review.googlesource.com/c/public/gem5/+/24664 Reviewed-by: Nikos Nikoleris Maintainer: Giacomo Travaglini Tested-by: kokoro --- src/arch/arm/isa.hh | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) (limited to 'src/arch/arm/isa.hh') diff --git a/src/arch/arm/isa.hh b/src/arch/arm/isa.hh index 7ffa682ef..23f05ccaf 100644 --- a/src/arch/arm/isa.hh +++ b/src/arch/arm/isa.hh @@ -250,11 +250,26 @@ namespace ArmISA privNonSecureRead(v); return *this; } + chain hypE2HRead(bool v = true) const { + info[MISCREG_HYP_E2H_RD] = v; + return *this; + } + chain hypE2HWrite(bool v = true) const { + info[MISCREG_HYP_E2H_WR] = v; + return *this; + } + chain hypE2H(bool v = true) const { + hypE2HRead(v); + hypE2HWrite(v); + return *this; + } chain hypRead(bool v = true) const { + hypE2HRead(v); info[MISCREG_HYP_RD] = v; return *this; } chain hypWrite(bool v = true) const { + hypE2HWrite(v); info[MISCREG_HYP_WR] = v; return *this; } @@ -263,19 +278,36 @@ namespace ArmISA hypWrite(v); return *this; } + chain monE2HRead(bool v = true) const { + info[MISCREG_MON_E2H_RD] = v; + return *this; + } + chain monE2HWrite(bool v = true) const { + info[MISCREG_MON_E2H_WR] = v; + return *this; + } + chain monE2H(bool v = true) const { + monE2HRead(v); + monE2HWrite(v); + return *this; + } chain monSecureRead(bool v = true) const { + monE2HRead(v); info[MISCREG_MON_NS0_RD] = v; return *this; } chain monSecureWrite(bool v = true) const { + monE2HWrite(v); info[MISCREG_MON_NS0_WR] = v; return *this; } chain monNonSecureRead(bool v = true) const { + monE2HRead(v); info[MISCREG_MON_NS1_RD] = v; return *this; } chain monNonSecureWrite(bool v = true) const { + monE2HWrite(v); info[MISCREG_MON_NS1_WR] = v; return *this; } -- cgit v1.2.3