summaryrefslogtreecommitdiff
path: root/src/arch
diff options
context:
space:
mode:
authorGiacomo Travaglini <giacomo.travaglini@arm.com>2018-09-25 17:37:48 +0100
committerGiacomo Travaglini <giacomo.travaglini@arm.com>2018-10-01 15:47:55 +0000
commitb992ecbc5b11c38f9469fe1a02dd1302f97f77c7 (patch)
tree3077b9cd638cca96322104b700a1700cfb2524a3 /src/arch
parent30746da58f3dbcb37df6214999ad48cb7df1cc4a (diff)
downloadgem5-b992ecbc5b11c38f9469fe1a02dd1302f97f77c7.tar.xz
arch-arm: Implement AArch64 ID regs as bitunions
This patch is implementing the following AArch64 ID registers as bitunions, so that it is easier to query for feature availability: - ID_AA64DFR0_EL1 - ID_AA64ISAR0_EL1 - ID_AA64ISAR1_EL1 - ID_AA64MMFR1_EL1 - ID_AA64MMFR2_EL1 - ID_AA64PFR0_EL1 They are updated to the latest Armv8.5 arch release version. RES0 only ID registers like ID_AA64AFR1_EL1 haven't been added. Change-Id: Ied037abe3757421bcfc2834d397a8cf9a2b9f0a7 Signed-off-by: Giacomo Travaglini <giacomo.travaglini@arm.com> Reviewed-by: Andreas Sandberg <andreas.sandberg@arm.com> Reviewed-on: https://gem5-review.googlesource.com/13067 Maintainer: Andreas Sandberg <andreas.sandberg@arm.com>
Diffstat (limited to 'src/arch')
-rw-r--r--src/arch/arm/miscregs_types.hh105
1 files changed, 105 insertions, 0 deletions
diff --git a/src/arch/arm/miscregs_types.hh b/src/arch/arm/miscregs_types.hh
index b034ff492..198f8c88d 100644
--- a/src/arch/arm/miscregs_types.hh
+++ b/src/arch/arm/miscregs_types.hh
@@ -74,6 +74,111 @@ namespace ArmISA
Bitfield<0> sp; // AArch64
EndBitUnion(CPSR)
+ BitUnion64(AA64DFR0)
+ Bitfield<43, 40> tracefilt;
+ Bitfield<39, 36> doublelock;
+ Bitfield<35, 32> pmsver;
+ Bitfield<31, 28> ctx_cmps;
+ Bitfield<23, 20> wrps;
+ Bitfield<15, 12> brps;
+ Bitfield<11, 8> pmuver;
+ Bitfield<7, 4> tracever;
+ Bitfield<3, 0> debugver;
+ EndBitUnion(AA64DFR0)
+
+ BitUnion64(AA64ISAR0)
+ Bitfield<63, 60> rndr;
+ Bitfield<59, 56> tlb;
+ Bitfield<55, 52> ts;
+ Bitfield<51, 48> fhm;
+ Bitfield<47, 44> dp;
+ Bitfield<43, 40> sm4;
+ Bitfield<39, 36> sm3;
+ Bitfield<35, 32> sha3;
+ Bitfield<31, 28> rdm;
+ Bitfield<23, 20> atomic;
+ Bitfield<19, 16> crc32;
+ Bitfield<15, 12> sha2;
+ Bitfield<11, 8> sha1;
+ Bitfield<3, 0> aes;
+ EndBitUnion(AA64ISAR0)
+
+ BitUnion64(AA64ISAR1)
+ Bitfield<43, 40> specres;
+ Bitfield<39, 36> sb;
+ Bitfield<35, 32> frintts;
+ Bitfield<31, 28> gpi;
+ Bitfield<27, 24> gpa;
+ Bitfield<23, 20> lrcpc;
+ Bitfield<19, 16> fcma;
+ Bitfield<15, 12> jscvt;
+ Bitfield<11, 8> api;
+ Bitfield<7, 4> apa;
+ Bitfield<3, 0> dpb;
+ EndBitUnion(AA64ISAR1)
+
+ BitUnion64(AA64MMFR0)
+ Bitfield<47, 44> exs;
+ Bitfield<43, 40> tgran4_2;
+ Bitfield<39, 36> tgran64_2;
+ Bitfield<35, 32> tgran16_2;
+ Bitfield<31, 28> tgran4;
+ Bitfield<27, 24> tgran64;
+ Bitfield<23, 20> tgran16;
+ Bitfield<19, 16> bigendEL0;
+ Bitfield<15, 12> snsmem;
+ Bitfield<11, 8> bigend;
+ Bitfield<7, 4> asidbits;
+ Bitfield<3, 0> parange;
+ EndBitUnion(AA64MMFR0)
+
+ BitUnion64(AA64MMFR1)
+ Bitfield<31, 28> xnx;
+ Bitfield<27, 24> specsei;
+ Bitfield<23, 20> pan;
+ Bitfield<19, 16> lo;
+ Bitfield<15, 12> hpds;
+ Bitfield<11, 8> vh;
+ Bitfield<7, 4> vmidbits;
+ Bitfield<3, 0> hafdbs;
+ EndBitUnion(AA64MMFR1)
+
+ BitUnion64(AA64MMFR2)
+ Bitfield<63, 60> e0pd;
+ Bitfield<59, 56> evt;
+ Bitfield<55, 52> bbm;
+ Bitfield<51, 48> ttl;
+ Bitfield<43, 40> fwb;
+ Bitfield<39, 36> ids;
+ Bitfield<35, 32> at;
+ Bitfield<31, 28> st;
+ Bitfield<27, 24> nv;
+ Bitfield<23, 20> ccidx;
+ Bitfield<19, 16> varange;
+ Bitfield<15, 12> iesb;
+ Bitfield<11, 8> lsm;
+ Bitfield<7, 4> uao;
+ Bitfield<3, 0> cnp;
+ EndBitUnion(AA64MMFR2)
+
+ BitUnion64(AA64PFR0)
+ Bitfield<63, 60> csv3;
+ Bitfield<59, 56> csv2;
+ Bitfield<51, 48> dit;
+ Bitfield<47, 44> amu;
+ Bitfield<43, 40> mpam;
+ Bitfield<39, 36> sel2;
+ Bitfield<35, 32> sve;
+ Bitfield<31, 28> ras;
+ Bitfield<27, 24> gic;
+ Bitfield<23, 20> advsimd;
+ Bitfield<19, 16> fp;
+ Bitfield<15, 12> el3;
+ Bitfield<11, 8> el2;
+ Bitfield<7, 4> el1;
+ Bitfield<3, 0> el0;
+ EndBitUnion(AA64PFR0)
+
BitUnion32(HDCR)
Bitfield<11> tdra;
Bitfield<10> tdosa;