mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-03 07:43:54 -06:00
target/arm: Move aarch64 CPU property code to TYPE_ARM_CPU
The only thing we have left in the TYPE_AARCH64_CPU class that makes it different to TYPE_ARM_CPU is that we register the handling of the "aarch64" property there. Move the handling of this property to the base class, where we make it a property of the object rather than of the class, and add it to the CPU if it has the ARM_FEATURE_AARCH64 property present at init. This is in line with how we handle other Arm CPU properties, and should not change which CPUs it's visible for. Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20250429132200.605611-6-peter.maydell@linaro.org
This commit is contained in:
parent
d2c655a5f4
commit
0ab97bc070
2 changed files with 36 additions and 33 deletions
|
@ -1609,6 +1609,35 @@ static void arm_set_pmu(Object *obj, bool value, Error **errp)
|
|||
cpu->has_pmu = value;
|
||||
}
|
||||
|
||||
static bool aarch64_cpu_get_aarch64(Object *obj, Error **errp)
|
||||
{
|
||||
ARMCPU *cpu = ARM_CPU(obj);
|
||||
|
||||
return arm_feature(&cpu->env, ARM_FEATURE_AARCH64);
|
||||
}
|
||||
|
||||
static void aarch64_cpu_set_aarch64(Object *obj, bool value, Error **errp)
|
||||
{
|
||||
ARMCPU *cpu = ARM_CPU(obj);
|
||||
|
||||
/*
|
||||
* At this time, this property is only allowed if KVM is enabled. This
|
||||
* restriction allows us to avoid fixing up functionality that assumes a
|
||||
* uniform execution state like do_interrupt.
|
||||
*/
|
||||
if (value == false) {
|
||||
if (!kvm_enabled() || !kvm_arm_aarch32_supported()) {
|
||||
error_setg(errp, "'aarch64' feature cannot be disabled "
|
||||
"unless KVM is enabled and 32-bit EL1 "
|
||||
"is supported");
|
||||
return;
|
||||
}
|
||||
unset_feature(&cpu->env, ARM_FEATURE_AARCH64);
|
||||
} else {
|
||||
set_feature(&cpu->env, ARM_FEATURE_AARCH64);
|
||||
}
|
||||
}
|
||||
|
||||
unsigned int gt_cntfrq_period_ns(ARMCPU *cpu)
|
||||
{
|
||||
/*
|
||||
|
@ -1736,6 +1765,13 @@ void arm_cpu_post_init(Object *obj)
|
|||
*/
|
||||
arm_cpu_propagate_feature_implications(cpu);
|
||||
|
||||
if (arm_feature(&cpu->env, ARM_FEATURE_AARCH64)) {
|
||||
object_property_add_bool(obj, "aarch64", aarch64_cpu_get_aarch64,
|
||||
aarch64_cpu_set_aarch64);
|
||||
object_property_set_description(obj, "aarch64",
|
||||
"Set on/off to enable/disable aarch64 "
|
||||
"execution state ");
|
||||
}
|
||||
if (arm_feature(&cpu->env, ARM_FEATURE_CBAR) ||
|
||||
arm_feature(&cpu->env, ARM_FEATURE_CBAR_RO)) {
|
||||
qdev_property_add_static(DEVICE(obj), &arm_cpu_reset_cbar_property);
|
||||
|
|
|
@ -781,45 +781,12 @@ static const ARMCPUInfo aarch64_cpus[] = {
|
|||
#endif
|
||||
};
|
||||
|
||||
static bool aarch64_cpu_get_aarch64(Object *obj, Error **errp)
|
||||
{
|
||||
ARMCPU *cpu = ARM_CPU(obj);
|
||||
|
||||
return arm_feature(&cpu->env, ARM_FEATURE_AARCH64);
|
||||
}
|
||||
|
||||
static void aarch64_cpu_set_aarch64(Object *obj, bool value, Error **errp)
|
||||
{
|
||||
ARMCPU *cpu = ARM_CPU(obj);
|
||||
|
||||
/* At this time, this property is only allowed if KVM is enabled. This
|
||||
* restriction allows us to avoid fixing up functionality that assumes a
|
||||
* uniform execution state like do_interrupt.
|
||||
*/
|
||||
if (value == false) {
|
||||
if (!kvm_enabled() || !kvm_arm_aarch32_supported()) {
|
||||
error_setg(errp, "'aarch64' feature cannot be disabled "
|
||||
"unless KVM is enabled and 32-bit EL1 "
|
||||
"is supported");
|
||||
return;
|
||||
}
|
||||
unset_feature(&cpu->env, ARM_FEATURE_AARCH64);
|
||||
} else {
|
||||
set_feature(&cpu->env, ARM_FEATURE_AARCH64);
|
||||
}
|
||||
}
|
||||
|
||||
static void aarch64_cpu_finalizefn(Object *obj)
|
||||
{
|
||||
}
|
||||
|
||||
static void aarch64_cpu_class_init(ObjectClass *oc, const void *data)
|
||||
{
|
||||
object_class_property_add_bool(oc, "aarch64", aarch64_cpu_get_aarch64,
|
||||
aarch64_cpu_set_aarch64);
|
||||
object_class_property_set_description(oc, "aarch64",
|
||||
"Set on/off to enable/disable aarch64 "
|
||||
"execution state ");
|
||||
}
|
||||
|
||||
static void aarch64_cpu_instance_init(Object *obj)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue