To support CPU feature in AArch64, we need to move some field from ARMCPU to ARMISARegisters, add more definitions of ID fields, and add suport query-cpu-model-expansion qmp command. Let's backport upstream patches to do these. Signed-off-by: Peng Liang <liangpeng10@huawei.com>
167 lines
6.3 KiB
Diff
167 lines
6.3 KiB
Diff
From 515975da851ca9567053bcf0487fde4447dfdc4f Mon Sep 17 00:00:00 2001
|
|
From: Peter Maydell <peter.maydell@linaro.org>
|
|
Date: Fri, 14 Feb 2020 17:51:04 +0000
|
|
Subject: [PATCH 06/13] target/arm: Add _aa64_ and _any_ versions of pmu_8_1
|
|
isar checks
|
|
MIME-Version: 1.0
|
|
Content-Type: text/plain; charset=UTF-8
|
|
Content-Transfer-Encoding: 8bit
|
|
|
|
Add the 64-bit version of the "is this a v8.1 PMUv3?"
|
|
ID register check function, and the _any_ version that
|
|
checks for either AArch32 or AArch64 support. We'll use
|
|
this in a later commit.
|
|
|
|
We don't (yet) do any isar_feature checks on ID_AA64DFR1_EL1,
|
|
but we move id_aa64dfr1 into the ARMISARegisters struct with
|
|
id_aa64dfr0, for consistency.
|
|
|
|
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
|
|
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
|
|
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
|
|
Message-id: 20200214175116.9164-10-peter.maydell@linaro.org
|
|
---
|
|
target/arm/cpu.c | 3 ++-
|
|
target/arm/cpu.h | 15 +++++++++++++--
|
|
target/arm/cpu64.c | 8 ++++----
|
|
target/arm/helper.c | 12 +++++++-----
|
|
4 files changed, 26 insertions(+), 12 deletions(-)
|
|
|
|
diff --git a/target/arm/cpu.c b/target/arm/cpu.c
|
|
index 7e9b85a2..bb2edf4e 100644
|
|
--- a/target/arm/cpu.c
|
|
+++ b/target/arm/cpu.c
|
|
@@ -1522,7 +1522,8 @@ static void arm_cpu_realizefn(DeviceState *dev, Error **errp)
|
|
cpu);
|
|
#endif
|
|
} else {
|
|
- cpu->id_aa64dfr0 = FIELD_DP64(cpu->id_aa64dfr0, ID_AA64DFR0, PMUVER, 0);
|
|
+ cpu->isar.id_aa64dfr0 =
|
|
+ FIELD_DP64(cpu->isar.id_aa64dfr0, ID_AA64DFR0, PMUVER, 0);
|
|
cpu->isar.id_dfr0 = FIELD_DP32(cpu->isar.id_dfr0, ID_DFR0, PERFMON, 0);
|
|
cpu->pmceid0 = 0;
|
|
cpu->pmceid1 = 0;
|
|
diff --git a/target/arm/cpu.h b/target/arm/cpu.h
|
|
index 2d8d27e8..230130be 100644
|
|
--- a/target/arm/cpu.h
|
|
+++ b/target/arm/cpu.h
|
|
@@ -868,6 +868,8 @@ struct ARMCPU {
|
|
uint64_t id_aa64mmfr0;
|
|
uint64_t id_aa64mmfr1;
|
|
uint64_t id_aa64mmfr2;
|
|
+ uint64_t id_aa64dfr0;
|
|
+ uint64_t id_aa64dfr1;
|
|
} isar;
|
|
uint32_t midr;
|
|
uint32_t revidr;
|
|
@@ -884,8 +886,6 @@ struct ARMCPU {
|
|
uint32_t id_mmfr2;
|
|
uint32_t id_mmfr3;
|
|
uint32_t id_mmfr4;
|
|
- uint64_t id_aa64dfr0;
|
|
- uint64_t id_aa64dfr1;
|
|
uint64_t id_aa64afr0;
|
|
uint64_t id_aa64afr1;
|
|
uint32_t dbgdidr;
|
|
@@ -3657,6 +3657,17 @@ static inline bool isar_feature_aa64_bti(const ARMISARegisters *id)
|
|
return FIELD_EX64(id->id_aa64pfr1, ID_AA64PFR1, BT) != 0;
|
|
}
|
|
|
|
+static inline bool isar_feature_aa64_pmu_8_1(const ARMISARegisters *id)
|
|
+{
|
|
+ return FIELD_EX64(id->id_aa64dfr0, ID_AA64DFR0, PMUVER) >= 4 &&
|
|
+ FIELD_EX64(id->id_aa64dfr0, ID_AA64DFR0, PMUVER) != 0xf;
|
|
+}
|
|
+
|
|
+static inline bool isar_feature_any_pmu_8_1(const ARMISARegisters *id)
|
|
+{
|
|
+ return isar_feature_aa64_pmu_8_1(id) || isar_feature_aa32_pmu_8_1(id);
|
|
+}
|
|
+
|
|
/*
|
|
* Forward to the above feature tests given an ARMCPU pointer.
|
|
*/
|
|
diff --git a/target/arm/cpu64.c b/target/arm/cpu64.c
|
|
index afdabbeb..aa96548f 100644
|
|
--- a/target/arm/cpu64.c
|
|
+++ b/target/arm/cpu64.c
|
|
@@ -137,7 +137,7 @@ static void aarch64_a57_initfn(Object *obj)
|
|
cpu->isar.id_isar5 = 0x00011121;
|
|
cpu->isar.id_isar6 = 0;
|
|
cpu->isar.id_aa64pfr0 = 0x00002222;
|
|
- cpu->id_aa64dfr0 = 0x10305106;
|
|
+ cpu->isar.id_aa64dfr0 = 0x10305106;
|
|
cpu->isar.id_aa64isar0 = 0x00011120;
|
|
cpu->isar.id_aa64mmfr0 = 0x00001124;
|
|
cpu->dbgdidr = 0x3516d000;
|
|
@@ -191,7 +191,7 @@ static void aarch64_a53_initfn(Object *obj)
|
|
cpu->isar.id_isar5 = 0x00011121;
|
|
cpu->isar.id_isar6 = 0;
|
|
cpu->isar.id_aa64pfr0 = 0x00002222;
|
|
- cpu->id_aa64dfr0 = 0x10305106;
|
|
+ cpu->isar.id_aa64dfr0 = 0x10305106;
|
|
cpu->isar.id_aa64isar0 = 0x00011120;
|
|
cpu->isar.id_aa64mmfr0 = 0x00001122; /* 40 bit physical addr */
|
|
cpu->dbgdidr = 0x3516d000;
|
|
@@ -244,7 +244,7 @@ static void aarch64_a72_initfn(Object *obj)
|
|
cpu->isar.id_isar4 = 0x00011142;
|
|
cpu->isar.id_isar5 = 0x00011121;
|
|
cpu->isar.id_aa64pfr0 = 0x00002222;
|
|
- cpu->id_aa64dfr0 = 0x10305106;
|
|
+ cpu->isar.id_aa64dfr0 = 0x10305106;
|
|
cpu->isar.id_aa64isar0 = 0x00011120;
|
|
cpu->isar.id_aa64mmfr0 = 0x00001124;
|
|
cpu->dbgdidr = 0x3516d000;
|
|
@@ -276,7 +276,7 @@ static void aarch64_kunpeng_920_initfn(Object *obj)
|
|
cpu->midr = 0x480fd010;
|
|
cpu->ctr = 0x84448004;
|
|
cpu->isar.id_aa64pfr0 = 0x11001111;
|
|
- cpu->id_aa64dfr0 = 0x110305408;
|
|
+ cpu->isar.id_aa64dfr0 = 0x110305408;
|
|
cpu->isar.id_aa64isar0 = 0x10211120;
|
|
cpu->isar.id_aa64mmfr0 = 0x101125;
|
|
}
|
|
diff --git a/target/arm/helper.c b/target/arm/helper.c
|
|
index 3f06ca19..a71f4ef6 100644
|
|
--- a/target/arm/helper.c
|
|
+++ b/target/arm/helper.c
|
|
@@ -23,6 +23,7 @@
|
|
#include "hw/semihosting/semihost.h"
|
|
#include "sysemu/cpus.h"
|
|
#include "sysemu/kvm.h"
|
|
+#include "sysemu/tcg.h"
|
|
#include "qemu/range.h"
|
|
#include "qapi/qapi-commands-machine-target.h"
|
|
#include "qapi/error.h"
|
|
@@ -5611,9 +5612,10 @@ static void define_debug_regs(ARMCPU *cpu)
|
|
* check that if they both exist then they agree.
|
|
*/
|
|
if (arm_feature(&cpu->env, ARM_FEATURE_AARCH64)) {
|
|
- assert(FIELD_EX64(cpu->id_aa64dfr0, ID_AA64DFR0, BRPS) == brps);
|
|
- assert(FIELD_EX64(cpu->id_aa64dfr0, ID_AA64DFR0, WRPS) == wrps);
|
|
- assert(FIELD_EX64(cpu->id_aa64dfr0, ID_AA64DFR0, CTX_CMPS) == ctx_cmps);
|
|
+ assert(FIELD_EX64(cpu->isar.id_aa64dfr0, ID_AA64DFR0, BRPS) == brps);
|
|
+ assert(FIELD_EX64(cpu->isar.id_aa64dfr0, ID_AA64DFR0, WRPS) == wrps);
|
|
+ assert(FIELD_EX64(cpu->isar.id_aa64dfr0, ID_AA64DFR0, CTX_CMPS)
|
|
+ == ctx_cmps);
|
|
}
|
|
|
|
define_one_arm_cp_reg(cpu, &dbgdidr);
|
|
@@ -6112,11 +6114,11 @@ void register_cp_regs_for_features(ARMCPU *cpu)
|
|
{ .name = "ID_AA64DFR0_EL1", .state = ARM_CP_STATE_AA64,
|
|
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 5, .opc2 = 0,
|
|
.access = PL1_R, .type = ARM_CP_CONST,
|
|
- .resetvalue = cpu->id_aa64dfr0 },
|
|
+ .resetvalue = cpu->isar.id_aa64dfr0 },
|
|
{ .name = "ID_AA64DFR1_EL1", .state = ARM_CP_STATE_AA64,
|
|
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 5, .opc2 = 1,
|
|
.access = PL1_R, .type = ARM_CP_CONST,
|
|
- .resetvalue = cpu->id_aa64dfr1 },
|
|
+ .resetvalue = cpu->isar.id_aa64dfr1 },
|
|
{ .name = "ID_AA64DFR2_EL1_RESERVED", .state = ARM_CP_STATE_AA64,
|
|
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 5, .opc2 = 2,
|
|
.access = PL1_R, .type = ARM_CP_CONST,
|
|
--
|
|
2.25.1
|
|
|