提交 51e5ef45 编写于 作者: M Marc-André Lureau

arm: replace instance_post_init()

Replace arm_cpu_post_init() instance callback by calling it from leaf
classes, to avoid potential ordering issue with other post_init callbacks.
Signed-off-by: NMarc-André Lureau <marcandre.lureau@redhat.com>
Suggested-by: NIgor Mammedov <imammedo@redhat.com>
Reviewed-by: NIgor Mammedov <imammedo@redhat.com>
Acked-by: NEduardo Habkost <ehabkost@redhat.com>
上级 50545b2c
...@@ -35,6 +35,8 @@ struct arm_boot_info; ...@@ -35,6 +35,8 @@ struct arm_boot_info;
#define TYPE_ARM_MAX_CPU "max-" TYPE_ARM_CPU #define TYPE_ARM_MAX_CPU "max-" TYPE_ARM_CPU
typedef struct ARMCPUInfo ARMCPUInfo;
/** /**
* ARMCPUClass: * ARMCPUClass:
* @parent_realize: The parent class' realize handler. * @parent_realize: The parent class' realize handler.
...@@ -47,6 +49,7 @@ typedef struct ARMCPUClass { ...@@ -47,6 +49,7 @@ typedef struct ARMCPUClass {
CPUClass parent_class; CPUClass parent_class;
/*< public >*/ /*< public >*/
const ARMCPUInfo *info;
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); void (*parent_reset)(CPUState *cpu);
} ARMCPUClass; } ARMCPUClass;
......
...@@ -740,7 +740,7 @@ static Property arm_cpu_pmsav7_dregion_property = ...@@ -740,7 +740,7 @@ static Property arm_cpu_pmsav7_dregion_property =
static Property arm_cpu_initsvtor_property = static Property arm_cpu_initsvtor_property =
DEFINE_PROP_UINT32("init-svtor", ARMCPU, init_svtor, 0); DEFINE_PROP_UINT32("init-svtor", ARMCPU, init_svtor, 0);
static void arm_cpu_post_init(Object *obj) void arm_cpu_post_init(Object *obj)
{ {
ARMCPU *cpu = ARM_CPU(obj); ARMCPU *cpu = ARM_CPU(obj);
...@@ -1457,8 +1457,10 @@ static void cortex_m33_initfn(Object *obj) ...@@ -1457,8 +1457,10 @@ static void cortex_m33_initfn(Object *obj)
static void arm_v7m_class_init(ObjectClass *oc, void *data) static void arm_v7m_class_init(ObjectClass *oc, void *data)
{ {
ARMCPUClass *acc = ARM_CPU_CLASS(oc);
CPUClass *cc = CPU_CLASS(oc); CPUClass *cc = CPU_CLASS(oc);
acc->info = data;
#ifndef CONFIG_USER_ONLY #ifndef CONFIG_USER_ONLY
cc->do_interrupt = arm_v7m_cpu_do_interrupt; cc->do_interrupt = arm_v7m_cpu_do_interrupt;
#endif #endif
...@@ -1959,11 +1961,11 @@ static void arm_max_initfn(Object *obj) ...@@ -1959,11 +1961,11 @@ static void arm_max_initfn(Object *obj)
#endif /* !defined(CONFIG_USER_ONLY) || !defined(TARGET_AARCH64) */ #endif /* !defined(CONFIG_USER_ONLY) || !defined(TARGET_AARCH64) */
typedef struct ARMCPUInfo { struct ARMCPUInfo {
const char *name; const char *name;
void (*initfn)(Object *obj); void (*initfn)(Object *obj);
void (*class_init)(ObjectClass *oc, void *data); void (*class_init)(ObjectClass *oc, void *data);
} ARMCPUInfo; };
static const ARMCPUInfo arm_cpus[] = { static const ARMCPUInfo arm_cpus[] = {
#if !defined(CONFIG_USER_ONLY) || !defined(TARGET_AARCH64) #if !defined(CONFIG_USER_ONLY) || !defined(TARGET_AARCH64)
...@@ -2113,6 +2115,7 @@ static void arm_host_initfn(Object *obj) ...@@ -2113,6 +2115,7 @@ static void arm_host_initfn(Object *obj)
ARMCPU *cpu = ARM_CPU(obj); ARMCPU *cpu = ARM_CPU(obj);
kvm_arm_set_cpu_features_from_host(cpu); kvm_arm_set_cpu_features_from_host(cpu);
arm_cpu_post_init(obj);
} }
static const TypeInfo host_arm_cpu_type_info = { static const TypeInfo host_arm_cpu_type_info = {
...@@ -2127,14 +2130,30 @@ static const TypeInfo host_arm_cpu_type_info = { ...@@ -2127,14 +2130,30 @@ static const TypeInfo host_arm_cpu_type_info = {
#endif #endif
static void arm_cpu_instance_init(Object *obj)
{
ARMCPUClass *acc = ARM_CPU_GET_CLASS(obj);
acc->info->initfn(obj);
arm_cpu_post_init(obj);
}
static void cpu_register_class_init(ObjectClass *oc, void *data)
{
ARMCPUClass *acc = ARM_CPU_CLASS(oc);
acc->info = data;
}
static void cpu_register(const ARMCPUInfo *info) static void cpu_register(const ARMCPUInfo *info)
{ {
TypeInfo type_info = { TypeInfo type_info = {
.parent = TYPE_ARM_CPU, .parent = TYPE_ARM_CPU,
.instance_size = sizeof(ARMCPU), .instance_size = sizeof(ARMCPU),
.instance_init = info->initfn, .instance_init = arm_cpu_instance_init,
.class_size = sizeof(ARMCPUClass), .class_size = sizeof(ARMCPUClass),
.class_init = info->class_init, .class_init = info->class_init ?: cpu_register_class_init,
.class_data = (void *)info,
}; };
type_info.name = g_strdup_printf("%s-" TYPE_ARM_CPU, info->name); type_info.name = g_strdup_printf("%s-" TYPE_ARM_CPU, info->name);
...@@ -2147,7 +2166,6 @@ static const TypeInfo arm_cpu_type_info = { ...@@ -2147,7 +2166,6 @@ static const TypeInfo arm_cpu_type_info = {
.parent = TYPE_CPU, .parent = TYPE_CPU,
.instance_size = sizeof(ARMCPU), .instance_size = sizeof(ARMCPU),
.instance_init = arm_cpu_initfn, .instance_init = arm_cpu_initfn,
.instance_post_init = arm_cpu_post_init,
.instance_finalize = arm_cpu_finalizefn, .instance_finalize = arm_cpu_finalizefn,
.abstract = true, .abstract = true,
.class_size = sizeof(ARMCPUClass), .class_size = sizeof(ARMCPUClass),
......
...@@ -884,6 +884,8 @@ static inline ARMCPU *arm_env_get_cpu(CPUARMState *env) ...@@ -884,6 +884,8 @@ static inline ARMCPU *arm_env_get_cpu(CPUARMState *env)
return container_of(env, ARMCPU, env); return container_of(env, ARMCPU, env);
} }
void arm_cpu_post_init(Object *obj);
uint64_t arm_cpu_mp_affinity(int idx, uint8_t clustersz); uint64_t arm_cpu_mp_affinity(int idx, uint8_t clustersz);
#define ENV_GET_CPU(e) CPU(arm_env_get_cpu(e)) #define ENV_GET_CPU(e) CPU(arm_env_get_cpu(e))
......
...@@ -364,11 +364,11 @@ static void aarch64_max_initfn(Object *obj) ...@@ -364,11 +364,11 @@ static void aarch64_max_initfn(Object *obj)
} }
} }
typedef struct ARMCPUInfo { struct ARMCPUInfo {
const char *name; const char *name;
void (*initfn)(Object *obj); void (*initfn)(Object *obj);
void (*class_init)(ObjectClass *oc, void *data); void (*class_init)(ObjectClass *oc, void *data);
} ARMCPUInfo; };
static const ARMCPUInfo aarch64_cpus[] = { static const ARMCPUInfo aarch64_cpus[] = {
{ .name = "cortex-a57", .initfn = aarch64_a57_initfn }, { .name = "cortex-a57", .initfn = aarch64_a57_initfn },
...@@ -452,14 +452,30 @@ static void aarch64_cpu_class_init(ObjectClass *oc, void *data) ...@@ -452,14 +452,30 @@ static void aarch64_cpu_class_init(ObjectClass *oc, void *data)
cc->gdb_arch_name = aarch64_gdb_arch_name; cc->gdb_arch_name = aarch64_gdb_arch_name;
} }
static void aarch64_cpu_instance_init(Object *obj)
{
ARMCPUClass *acc = ARM_CPU_GET_CLASS(obj);
acc->info->initfn(obj);
arm_cpu_post_init(obj);
}
static void cpu_register_class_init(ObjectClass *oc, void *data)
{
ARMCPUClass *acc = ARM_CPU_CLASS(oc);
acc->info = data;
}
static void aarch64_cpu_register(const ARMCPUInfo *info) static void aarch64_cpu_register(const ARMCPUInfo *info)
{ {
TypeInfo type_info = { TypeInfo type_info = {
.parent = TYPE_AARCH64_CPU, .parent = TYPE_AARCH64_CPU,
.instance_size = sizeof(ARMCPU), .instance_size = sizeof(ARMCPU),
.instance_init = info->initfn, .instance_init = aarch64_cpu_instance_init,
.class_size = sizeof(ARMCPUClass), .class_size = sizeof(ARMCPUClass),
.class_init = info->class_init, .class_init = info->class_init ?: cpu_register_class_init,
.class_data = (void *)info,
}; };
type_info.name = g_strdup_printf("%s-" TYPE_ARM_CPU, info->name); type_info.name = g_strdup_printf("%s-" TYPE_ARM_CPU, info->name);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册