diff options
author | Claudio Fontana <cfontana@suse.de> | 2021-03-22 14:27:59 +0100 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2021-05-10 15:41:52 -0400 |
commit | cc3f2be6b7ca1bb1e5d78aa355c5bdeea25c91c4 (patch) | |
tree | 6cf56508069f7c9d63b6e6e45740b4ec29b572cb /accel/accel-common.c | |
parent | 92242f34ab08ecc68750dd118bdad6ed66e3b00e (diff) | |
download | qemu-cc3f2be6b7ca1bb1e5d78aa355c5bdeea25c91c4.zip qemu-cc3f2be6b7ca1bb1e5d78aa355c5bdeea25c91c4.tar.gz qemu-cc3f2be6b7ca1bb1e5d78aa355c5bdeea25c91c4.tar.bz2 |
accel: add init_accel_cpu for adapting accel behavior to CPU type
while on x86 all CPU classes can use the same set of TCGCPUOps,
on ARM the right accel behavior depends on the type of the CPU.
So we need a way to specialize the accel behavior according to
the CPU. Therefore, add a second initialization, after the
accel_cpu->cpu_class_init, that allows to do this.
Signed-off-by: Claudio Fontana <cfontana@suse.de>
Cc: Paolo Bonzini <pbonzini@redhat.com>
Message-Id: <20210322132800.7470-24-cfontana@suse.de>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'accel/accel-common.c')
-rw-r--r-- | accel/accel-common.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/accel/accel-common.c b/accel/accel-common.c index d77c09d..cf07f78 100644 --- a/accel/accel-common.c +++ b/accel/accel-common.c @@ -54,10 +54,23 @@ static void accel_init_cpu_int_aux(ObjectClass *klass, void *opaque) CPUClass *cc = CPU_CLASS(klass); AccelCPUClass *accel_cpu = opaque; + /* + * The first callback allows accel-cpu to run initializations + * for the CPU, customizing CPU behavior according to the accelerator. + * + * The second one allows the CPU to customize the accel-cpu + * behavior according to the CPU. + * + * The second is currently only used by TCG, to specialize the + * TCGCPUOps depending on the CPU type. + */ cc->accel_cpu = accel_cpu; if (accel_cpu->cpu_class_init) { accel_cpu->cpu_class_init(cc); } + if (cc->init_accel_cpu) { + cc->init_accel_cpu(accel_cpu, cc); + } } /* initialize the arch-specific accel CpuClass interfaces */ |