From: Igor Mammedov <imammedo@redhat.com>
To: "Marc-André Lureau" <marcandre.lureau@redhat.com>
Cc: qemu-devel@nongnu.org, ehabkost@redhat.com
Subject: Re: [Qemu-devel] [PATCH v6 27/28] arm: replace instance_post_init()
Date: Mon, 17 Dec 2018 10:52:46 +0100 [thread overview]
Message-ID: <20181217105246.5fc3bd28@Igors-MacBook-Pro.local> (raw)
In-Reply-To: <20181212214850.29953-28-marcandre.lureau@redhat.com>
On Thu, 13 Dec 2018 01:48:49 +0400
Marc-André Lureau <marcandre.lureau@redhat.com> wrote:
> 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: Marc-André Lureau <marcandre.lureau@redhat.com>
> Suggested-by: Igor Mammedov <imammedo@redhat.com>
Reviewed-by: Igor Mammedov <imammedo@redhat.com>
> ---
> target/arm/cpu-qom.h | 3 +++
> target/arm/cpu.h | 2 ++
> target/arm/cpu.c | 30 ++++++++++++++++++++++++------
> target/arm/cpu64.c | 24 ++++++++++++++++++++----
> 4 files changed, 49 insertions(+), 10 deletions(-)
>
> diff --git a/target/arm/cpu-qom.h b/target/arm/cpu-qom.h
> index d135ff8e06..2049fa9612 100644
> --- a/target/arm/cpu-qom.h
> +++ b/target/arm/cpu-qom.h
> @@ -35,6 +35,8 @@ struct arm_boot_info;
>
> #define TYPE_ARM_MAX_CPU "max-" TYPE_ARM_CPU
>
> +typedef struct ARMCPUInfo ARMCPUInfo;
> +
> /**
> * ARMCPUClass:
> * @parent_realize: The parent class' realize handler.
> @@ -47,6 +49,7 @@ typedef struct ARMCPUClass {
> CPUClass parent_class;
> /*< public >*/
>
> + const ARMCPUInfo *info;
> DeviceRealize parent_realize;
> void (*parent_reset)(CPUState *cpu);
> } ARMCPUClass;
> diff --git a/target/arm/cpu.h b/target/arm/cpu.h
> index 2a73fed9a0..84fba2b24b 100644
> --- a/target/arm/cpu.h
> +++ b/target/arm/cpu.h
> @@ -884,6 +884,8 @@ static inline ARMCPU *arm_env_get_cpu(CPUARMState *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);
>
> #define ENV_GET_CPU(e) CPU(arm_env_get_cpu(e))
> diff --git a/target/arm/cpu.c b/target/arm/cpu.c
> index 60411f6bfe..68f65c15ba 100644
> --- a/target/arm/cpu.c
> +++ b/target/arm/cpu.c
> @@ -734,7 +734,7 @@ static Property arm_cpu_pmsav7_dregion_property =
> static Property arm_cpu_initsvtor_property =
> 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);
>
> @@ -1442,8 +1442,10 @@ static void cortex_m33_initfn(Object *obj)
>
> static void arm_v7m_class_init(ObjectClass *oc, void *data)
> {
> + ARMCPUClass *acc = ARM_CPU_CLASS(oc);
> CPUClass *cc = CPU_CLASS(oc);
>
> + acc->info = data;
> #ifndef CONFIG_USER_ONLY
> cc->do_interrupt = arm_v7m_cpu_do_interrupt;
> #endif
> @@ -1940,11 +1942,11 @@ static void arm_max_initfn(Object *obj)
>
> #endif /* !defined(CONFIG_USER_ONLY) || !defined(TARGET_AARCH64) */
>
> -typedef struct ARMCPUInfo {
> +struct ARMCPUInfo {
> const char *name;
> void (*initfn)(Object *obj);
> void (*class_init)(ObjectClass *oc, void *data);
> -} ARMCPUInfo;
> +};
>
> static const ARMCPUInfo arm_cpus[] = {
> #if !defined(CONFIG_USER_ONLY) || !defined(TARGET_AARCH64)
> @@ -2094,6 +2096,7 @@ static void arm_host_initfn(Object *obj)
> ARMCPU *cpu = ARM_CPU(obj);
>
> kvm_arm_set_cpu_features_from_host(cpu);
> + arm_cpu_post_init(ARM_CPU(obj));
> }
>
> static const TypeInfo host_arm_cpu_type_info = {
> @@ -2108,14 +2111,30 @@ static const TypeInfo host_arm_cpu_type_info = {
>
> #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)
> {
> TypeInfo type_info = {
> .parent = TYPE_ARM_CPU,
> .instance_size = sizeof(ARMCPU),
> - .instance_init = info->initfn,
> + .instance_init = arm_cpu_instance_init,
> .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);
> @@ -2128,7 +2147,6 @@ static const TypeInfo arm_cpu_type_info = {
> .parent = TYPE_CPU,
> .instance_size = sizeof(ARMCPU),
> .instance_init = arm_cpu_initfn,
> - .instance_post_init = arm_cpu_post_init,
> .instance_finalize = arm_cpu_finalizefn,
> .abstract = true,
> .class_size = sizeof(ARMCPUClass),
> diff --git a/target/arm/cpu64.c b/target/arm/cpu64.c
> index 873f059bf2..f09dc6b20d 100644
> --- a/target/arm/cpu64.c
> +++ b/target/arm/cpu64.c
> @@ -359,11 +359,11 @@ static void aarch64_max_initfn(Object *obj)
> }
> }
>
> -typedef struct ARMCPUInfo {
> +struct ARMCPUInfo {
> const char *name;
> void (*initfn)(Object *obj);
> void (*class_init)(ObjectClass *oc, void *data);
> -} ARMCPUInfo;
> +};
>
> static const ARMCPUInfo aarch64_cpus[] = {
> { .name = "cortex-a57", .initfn = aarch64_a57_initfn },
> @@ -447,14 +447,30 @@ static void aarch64_cpu_class_init(ObjectClass *oc, void *data)
> 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)
> {
> TypeInfo type_info = {
> .parent = TYPE_AARCH64_CPU,
> .instance_size = sizeof(ARMCPU),
> - .instance_init = info->initfn,
> + .instance_init = aarch64_cpu_instance_init,
> .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);
next prev parent reply other threads:[~2018-12-17 9:53 UTC|newest]
Thread overview: 37+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-12-12 21:48 [Qemu-devel] [PATCH v6 00/28] Generalize machine compatibility properties Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 01/28] hw: apply accel compat properties without touching globals Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 02/28] machines: replace COMPAT define with a static array Marc-André Lureau
2018-12-17 11:22 ` Igor Mammedov
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 03/28] hw: apply machine compat properties without touching globals Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 04/28] machine: move compat properties out of globals Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 05/28] hw: remove SET_MACHINE_COMPAT Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 06/28] compat: replace PC_COMPAT_3_1 & HW_COMPAT_3_1 macros Marc-André Lureau
2018-12-13 11:55 ` Cornelia Huck
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 07/28] compat: replace PC_COMPAT_3_0 & HW_COMPAT_3_0 macros Marc-André Lureau
2018-12-20 20:08 ` Eduardo Habkost
2018-12-20 21:58 ` Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 08/28] compat: replace PC_COMPAT_2_12 & HW_COMPAT_2_12 macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 09/28] compat: replace PC_COMPAT_2_11 & HW_COMPAT_2_11 macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 10/28] compat: replace PC_COMPAT_2_10 & HW_COMPAT_2_10 macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 11/28] compat: replace PC_COMPAT_2_9 & HW_COMPAT_2_9 macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 12/28] compat: replace PC_COMPAT_2_8 & HW_COMPAT_2_8 macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 13/28] compat: replace PC_COMPAT_2_7 & HW_COMPAT_2_7 macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 14/28] compat: replace PC_COMPAT_2_6 & HW_COMPAT_2_6 macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 15/28] compat: replace PC_COMPAT_2_5 & HW_COMPAT_2_5 macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 16/28] compat: replace PC_COMPAT_2_4 & HW_COMPAT_2_4 macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 17/28] compat: replace PC_COMPAT_2_3 & HW_COMPAT_2_3 macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 18/28] compat: replace PC_COMPAT_2_2 & HW_COMPAT_2_2 macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 19/28] compat: replace PC_COMPAT_2_1 & HW_COMPAT_2_1 macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 20/28] include: remove compat.h Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 21/28] compat: remove remaining PC_COMPAT macros Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 22/28] qdev: make a separate helper function to apply compat properties Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 23/28] qdev: all globals are now user-provided Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 24/28] qdev-props: convert global_props to GPtrArray Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 25/28] qdev-props: remove errp from GlobalProperty Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 26/28] qdev-props: call object_apply_global_props() Marc-André Lureau
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 27/28] arm: replace instance_post_init() Marc-André Lureau
2018-12-17 9:52 ` Igor Mammedov [this message]
2018-12-12 21:48 ` [Qemu-devel] [PATCH v6 28/28] hostmem: use object id for memory region name with >= 4.0 Marc-André Lureau
2018-12-20 15:40 ` Igor Mammedov
2018-12-13 11:58 ` [Qemu-devel] [PATCH v6 00/28] Generalize machine compatibility properties Cornelia Huck
2018-12-20 15:42 ` Igor Mammedov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20181217105246.5fc3bd28@Igors-MacBook-Pro.local \
--to=imammedo@redhat.com \
--cc=ehabkost@redhat.com \
--cc=marcandre.lureau@redhat.com \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).