cpu: Use DeviceClass reset instead of a special CPUClass reset

The CPUClass has a 'reset' method.  This is a legacy from when
TYPE_CPU used not to inherit from TYPE_DEVICE.  We don't need it any
more, as we can simply use the TYPE_DEVICE reset.  The 'cpu_reset()'
function is kept as the API which most places use to reset a CPU; it
is now a wrapper which calls device_cold_reset() and then the
tracepoint function.

This change should not cause CPU objects to be reset more often
than they are at the moment, because:
 * nobody is directly calling device_cold_reset() or
   qdev_reset_all() on CPU objects
 * no CPU object is on a qbus, so they will not be reset either
   by somebody calling qbus_reset_all()/bus_cold_reset(), or
   by the main "reset sysbus and everything in the qbus tree"
   reset that most devices are reset by

Note that this does not change the need for each machine or whatever
to use qemu_register_reset() to arrange to call cpu_reset() -- that
is necessary because CPU objects are not on any qbus, so they don't
get reset when the qbus tree rooted at the sysbus bus is reset, and
this isn't being changed here.

All the changes to the files under target/ were made using the
included Coccinelle script, except:

(1) the deletion of the now-inaccurate and not terribly useful
"CPUClass::reset" comments was done with a perl one-liner afterwards:
  perl -n -i -e '/ CPUClass::reset/ or print' target/*/*.c

(2) this bit of the s390 change was done by hand, because the
Coccinelle script is not sophisticated enough to handle the
parent_reset call being inside another function:

| @@ -96,8 +96,9 @@ static void s390_cpu_reset(CPUState *s, cpu_reset_type type)
|     S390CPU *cpu = S390_CPU(s);
|     S390CPUClass *scc = S390_CPU_GET_CLASS(cpu);
|     CPUS390XState *env = &cpu->env;
|+    DeviceState *dev = DEVICE(s);
|
|-    scc->parent_reset(s);
|+    scc->parent_reset(dev);
|     cpu->env.sigp_order = 0;
|     s390_cpu_set_state(S390_CPU_STATE_STOPPED, cpu);

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Message-Id: <20200303100511.5498-1-peter.maydell@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Eduardo Habkost <ehabkost@redhat.com>
This commit is contained in:
Peter Maydell 2020-03-03 10:05:11 +00:00 committed by Eduardo Habkost
parent 4ba59be1d6
commit 781c67ca55
41 changed files with 144 additions and 108 deletions

View File

@ -239,27 +239,16 @@ void cpu_dump_statistics(CPUState *cpu, int flags)
} }
} }
void cpu_class_set_parent_reset(CPUClass *cc,
void (*child_reset)(CPUState *cpu),
void (**parent_reset)(CPUState *cpu))
{
*parent_reset = cc->reset;
cc->reset = child_reset;
}
void cpu_reset(CPUState *cpu) void cpu_reset(CPUState *cpu)
{ {
CPUClass *klass = CPU_GET_CLASS(cpu); device_cold_reset(DEVICE(cpu));
if (klass->reset != NULL) {
(*klass->reset)(cpu);
}
trace_guest_cpu_reset(cpu); trace_guest_cpu_reset(cpu);
} }
static void cpu_common_reset(CPUState *cpu) static void cpu_common_reset(DeviceState *dev)
{ {
CPUState *cpu = CPU(dev);
CPUClass *cc = CPU_GET_CLASS(cpu); CPUClass *cc = CPU_GET_CLASS(cpu);
if (qemu_loglevel_mask(CPU_LOG_RESET)) { if (qemu_loglevel_mask(CPU_LOG_RESET)) {
@ -419,7 +408,6 @@ static void cpu_class_init(ObjectClass *klass, void *data)
CPUClass *k = CPU_CLASS(klass); CPUClass *k = CPU_CLASS(klass);
k->parse_features = cpu_common_parse_features; k->parse_features = cpu_common_parse_features;
k->reset = cpu_common_reset;
k->get_arch_id = cpu_common_get_arch_id; k->get_arch_id = cpu_common_get_arch_id;
k->has_work = cpu_common_has_work; k->has_work = cpu_common_has_work;
k->get_paging_enabled = cpu_common_get_paging_enabled; k->get_paging_enabled = cpu_common_get_paging_enabled;
@ -440,6 +428,7 @@ static void cpu_class_init(ObjectClass *klass, void *data)
set_bit(DEVICE_CATEGORY_CPU, dc->categories); set_bit(DEVICE_CATEGORY_CPU, dc->categories);
dc->realize = cpu_common_realizefn; dc->realize = cpu_common_realizefn;
dc->unrealize = cpu_common_unrealizefn; dc->unrealize = cpu_common_unrealizefn;
dc->reset = cpu_common_reset;
device_class_set_props(dc, cpu_common_props); device_class_set_props(dc, cpu_common_props);
/* /*
* Reason: CPUs still need special care by board code: wiring up * Reason: CPUs still need special care by board code: wiring up

View File

@ -79,7 +79,6 @@ struct TranslationBlock;
* @class_by_name: Callback to map -cpu command line model name to an * @class_by_name: Callback to map -cpu command line model name to an
* instantiatable CPU type. * instantiatable CPU type.
* @parse_features: Callback to parse command line arguments. * @parse_features: Callback to parse command line arguments.
* @reset: Callback to reset the #CPUState to its initial state.
* @reset_dump_flags: #CPUDumpFlags to use for reset logging. * @reset_dump_flags: #CPUDumpFlags to use for reset logging.
* @has_work: Callback for checking if there is work to do. * @has_work: Callback for checking if there is work to do.
* @do_interrupt: Callback for interrupt handling. * @do_interrupt: Callback for interrupt handling.
@ -165,7 +164,6 @@ typedef struct CPUClass {
ObjectClass *(*class_by_name)(const char *cpu_model); ObjectClass *(*class_by_name)(const char *cpu_model);
void (*parse_features)(const char *typename, char *str, Error **errp); void (*parse_features)(const char *typename, char *str, Error **errp);
void (*reset)(CPUState *cpu);
int reset_dump_flags; int reset_dump_flags;
bool (*has_work)(CPUState *cpu); bool (*has_work)(CPUState *cpu);
void (*do_interrupt)(CPUState *cpu); void (*do_interrupt)(CPUState *cpu);
@ -1135,10 +1133,6 @@ void cpu_exec_unrealizefn(CPUState *cpu);
*/ */
bool target_words_bigendian(void); bool target_words_bigendian(void);
void cpu_class_set_parent_reset(CPUClass *cc,
void (*child_reset)(CPUState *cpu),
void (**parent_reset)(CPUState *cpu));
#ifdef NEED_CPU_H #ifdef NEED_CPU_H
#ifdef CONFIG_SOFTMMU #ifdef CONFIG_SOFTMMU

View File

@ -0,0 +1,47 @@
// Convert targets using the old CPUState reset to DeviceState reset
//
// Copyright Linaro Ltd 2020
// This work is licensed under the terms of the GNU GPLv2 or later.
//
// spatch --macro-file scripts/cocci-macro-file.h \
// --sp-file scripts/coccinelle/cpu-reset.cocci \
// --keep-comments --smpl-spacing --in-place --include-headers --dir target
//
// For simplicity we assume some things about the code we're modifying
// that happen to be true for all our targets:
// * all cpu_class_set_parent_reset() callsites have a 'DeviceClass *dc' local
// * the parent reset field in the target CPU class is 'parent_reset'
// * no reset function already has a 'dev' local
@@
identifier cpu, x;
typedef CPUState;
@@
struct x {
...
- void (*parent_reset)(CPUState *cpu);
+ DeviceReset parent_reset;
...
};
@ rule1 @
identifier resetfn;
expression resetfield;
identifier cc;
@@
- cpu_class_set_parent_reset(cc, resetfn, resetfield)
+ device_class_set_parent_reset(dc, resetfn, resetfield)
@@
identifier rule1.resetfn;
identifier cpu, cc;
typedef CPUState, DeviceState;
@@
-resetfn(CPUState *cpu)
-{
+resetfn(DeviceState *dev)
+{
+ CPUState *cpu = CPU(dev);
<...
- cc->parent_reset(cpu);
+ cc->parent_reset(dev);
...>
}

View File

@ -44,7 +44,7 @@ typedef struct AlphaCPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} AlphaCPUClass; } AlphaCPUClass;
typedef struct AlphaCPU AlphaCPU; typedef struct AlphaCPU AlphaCPU;

View File

@ -51,7 +51,7 @@ typedef struct ARMCPUClass {
const ARMCPUInfo *info; const ARMCPUInfo *info;
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} ARMCPUClass; } ARMCPUClass;
typedef struct ARMCPU ARMCPU; typedef struct ARMCPU ARMCPU;

View File

@ -155,14 +155,14 @@ static void cp_reg_check_reset(gpointer key, gpointer value, gpointer opaque)
assert(oldvalue == newvalue); assert(oldvalue == newvalue);
} }
/* CPUClass::reset() */ static void arm_cpu_reset(DeviceState *dev)
static void arm_cpu_reset(CPUState *s)
{ {
CPUState *s = CPU(dev);
ARMCPU *cpu = ARM_CPU(s); ARMCPU *cpu = ARM_CPU(s);
ARMCPUClass *acc = ARM_CPU_GET_CLASS(cpu); ARMCPUClass *acc = ARM_CPU_GET_CLASS(cpu);
CPUARMState *env = &cpu->env; CPUARMState *env = &cpu->env;
acc->parent_reset(s); acc->parent_reset(dev);
memset(env, 0, offsetof(CPUARMState, end_reset_fields)); memset(env, 0, offsetof(CPUARMState, end_reset_fields));
@ -2785,7 +2785,7 @@ static void arm_cpu_class_init(ObjectClass *oc, void *data)
&acc->parent_realize); &acc->parent_realize);
device_class_set_props(dc, arm_cpu_properties); device_class_set_props(dc, arm_cpu_properties);
cpu_class_set_parent_reset(cc, arm_cpu_reset, &acc->parent_reset); device_class_set_parent_reset(dc, arm_cpu_reset, &acc->parent_reset);
cc->class_by_name = arm_cpu_class_by_name; cc->class_by_name = arm_cpu_class_by_name;
cc->has_work = arm_cpu_has_work; cc->has_work = arm_cpu_has_work;

View File

@ -45,7 +45,7 @@ typedef struct CRISCPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
uint32_t vr; uint32_t vr;
} CRISCPUClass; } CRISCPUClass;

View File

@ -40,15 +40,15 @@ static bool cris_cpu_has_work(CPUState *cs)
return cs->interrupt_request & (CPU_INTERRUPT_HARD | CPU_INTERRUPT_NMI); return cs->interrupt_request & (CPU_INTERRUPT_HARD | CPU_INTERRUPT_NMI);
} }
/* CPUClass::reset() */ static void cris_cpu_reset(DeviceState *dev)
static void cris_cpu_reset(CPUState *s)
{ {
CPUState *s = CPU(dev);
CRISCPU *cpu = CRIS_CPU(s); CRISCPU *cpu = CRIS_CPU(s);
CRISCPUClass *ccc = CRIS_CPU_GET_CLASS(cpu); CRISCPUClass *ccc = CRIS_CPU_GET_CLASS(cpu);
CPUCRISState *env = &cpu->env; CPUCRISState *env = &cpu->env;
uint32_t vr; uint32_t vr;
ccc->parent_reset(s); ccc->parent_reset(dev);
vr = env->pregs[PR_VR]; vr = env->pregs[PR_VR];
memset(env, 0, offsetof(CPUCRISState, end_reset_fields)); memset(env, 0, offsetof(CPUCRISState, end_reset_fields));
@ -264,7 +264,7 @@ static void cris_cpu_class_init(ObjectClass *oc, void *data)
device_class_set_parent_realize(dc, cris_cpu_realizefn, device_class_set_parent_realize(dc, cris_cpu_realizefn,
&ccc->parent_realize); &ccc->parent_realize);
cpu_class_set_parent_reset(cc, cris_cpu_reset, &ccc->parent_reset); device_class_set_parent_reset(dc, cris_cpu_reset, &ccc->parent_reset);
cc->class_by_name = cris_cpu_class_by_name; cc->class_by_name = cris_cpu_class_by_name;
cc->has_work = cris_cpu_has_work; cc->has_work = cris_cpu_has_work;

View File

@ -44,7 +44,7 @@ typedef struct HPPACPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} HPPACPUClass; } HPPACPUClass;
typedef struct HPPACPU HPPACPU; typedef struct HPPACPU HPPACPU;

View File

@ -71,7 +71,7 @@ typedef struct X86CPUClass {
DeviceRealize parent_realize; DeviceRealize parent_realize;
DeviceUnrealize parent_unrealize; DeviceUnrealize parent_unrealize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} X86CPUClass; } X86CPUClass;
typedef struct X86CPU X86CPU; typedef struct X86CPU X86CPU;

View File

@ -5983,9 +5983,9 @@ void cpu_x86_cpuid(CPUX86State *env, uint32_t index, uint32_t count,
} }
} }
/* CPUClass::reset() */ static void x86_cpu_reset(DeviceState *dev)
static void x86_cpu_reset(CPUState *s)
{ {
CPUState *s = CPU(dev);
X86CPU *cpu = X86_CPU(s); X86CPU *cpu = X86_CPU(s);
X86CPUClass *xcc = X86_CPU_GET_CLASS(cpu); X86CPUClass *xcc = X86_CPU_GET_CLASS(cpu);
CPUX86State *env = &cpu->env; CPUX86State *env = &cpu->env;
@ -5993,7 +5993,7 @@ static void x86_cpu_reset(CPUState *s)
uint64_t xcr0; uint64_t xcr0;
int i; int i;
xcc->parent_reset(s); xcc->parent_reset(dev);
memset(env, 0, offsetof(CPUX86State, end_reset_fields)); memset(env, 0, offsetof(CPUX86State, end_reset_fields));
@ -7297,7 +7297,7 @@ static void x86_cpu_common_class_init(ObjectClass *oc, void *data)
&xcc->parent_unrealize); &xcc->parent_unrealize);
device_class_set_props(dc, x86_cpu_properties); device_class_set_props(dc, x86_cpu_properties);
cpu_class_set_parent_reset(cc, x86_cpu_reset, &xcc->parent_reset); device_class_set_parent_reset(dc, x86_cpu_reset, &xcc->parent_reset);
cc->reset_dump_flags = CPU_DUMP_FPU | CPU_DUMP_CCOP; cc->reset_dump_flags = CPU_DUMP_FPU | CPU_DUMP_CCOP;
cc->class_by_name = x86_cpu_class_by_name; cc->class_by_name = x86_cpu_class_by_name;

View File

@ -44,7 +44,7 @@ typedef struct LM32CPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} LM32CPUClass; } LM32CPUClass;
typedef struct LM32CPU LM32CPU; typedef struct LM32CPU LM32CPU;

View File

@ -99,14 +99,14 @@ static bool lm32_cpu_has_work(CPUState *cs)
return cs->interrupt_request & CPU_INTERRUPT_HARD; return cs->interrupt_request & CPU_INTERRUPT_HARD;
} }
/* CPUClass::reset() */ static void lm32_cpu_reset(DeviceState *dev)
static void lm32_cpu_reset(CPUState *s)
{ {
CPUState *s = CPU(dev);
LM32CPU *cpu = LM32_CPU(s); LM32CPU *cpu = LM32_CPU(s);
LM32CPUClass *lcc = LM32_CPU_GET_CLASS(cpu); LM32CPUClass *lcc = LM32_CPU_GET_CLASS(cpu);
CPULM32State *env = &cpu->env; CPULM32State *env = &cpu->env;
lcc->parent_reset(s); lcc->parent_reset(dev);
/* reset cpu state */ /* reset cpu state */
memset(env, 0, offsetof(CPULM32State, end_reset_fields)); memset(env, 0, offsetof(CPULM32State, end_reset_fields));
@ -218,7 +218,7 @@ static void lm32_cpu_class_init(ObjectClass *oc, void *data)
device_class_set_parent_realize(dc, lm32_cpu_realizefn, device_class_set_parent_realize(dc, lm32_cpu_realizefn,
&lcc->parent_realize); &lcc->parent_realize);
cpu_class_set_parent_reset(cc, lm32_cpu_reset, &lcc->parent_reset); device_class_set_parent_reset(dc, lm32_cpu_reset, &lcc->parent_reset);
cc->class_by_name = lm32_cpu_class_by_name; cc->class_by_name = lm32_cpu_class_by_name;
cc->has_work = lm32_cpu_has_work; cc->has_work = lm32_cpu_has_work;

View File

@ -44,7 +44,7 @@ typedef struct M68kCPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} M68kCPUClass; } M68kCPUClass;
typedef struct M68kCPU M68kCPU; typedef struct M68kCPU M68kCPU;

View File

@ -41,16 +41,16 @@ static void m68k_set_feature(CPUM68KState *env, int feature)
env->features |= (1u << feature); env->features |= (1u << feature);
} }
/* CPUClass::reset() */ static void m68k_cpu_reset(DeviceState *dev)
static void m68k_cpu_reset(CPUState *s)
{ {
CPUState *s = CPU(dev);
M68kCPU *cpu = M68K_CPU(s); M68kCPU *cpu = M68K_CPU(s);
M68kCPUClass *mcc = M68K_CPU_GET_CLASS(cpu); M68kCPUClass *mcc = M68K_CPU_GET_CLASS(cpu);
CPUM68KState *env = &cpu->env; CPUM68KState *env = &cpu->env;
floatx80 nan = floatx80_default_nan(NULL); floatx80 nan = floatx80_default_nan(NULL);
int i; int i;
mcc->parent_reset(s); mcc->parent_reset(dev);
memset(env, 0, offsetof(CPUM68KState, end_reset_fields)); memset(env, 0, offsetof(CPUM68KState, end_reset_fields));
#ifdef CONFIG_SOFTMMU #ifdef CONFIG_SOFTMMU
@ -273,7 +273,7 @@ static void m68k_cpu_class_init(ObjectClass *c, void *data)
device_class_set_parent_realize(dc, m68k_cpu_realizefn, device_class_set_parent_realize(dc, m68k_cpu_realizefn,
&mcc->parent_realize); &mcc->parent_realize);
cpu_class_set_parent_reset(cc, m68k_cpu_reset, &mcc->parent_reset); device_class_set_parent_reset(dc, m68k_cpu_reset, &mcc->parent_reset);
cc->class_by_name = m68k_cpu_class_by_name; cc->class_by_name = m68k_cpu_class_by_name;
cc->has_work = m68k_cpu_has_work; cc->has_work = m68k_cpu_has_work;

View File

@ -44,7 +44,7 @@ typedef struct MicroBlazeCPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} MicroBlazeCPUClass; } MicroBlazeCPUClass;
typedef struct MicroBlazeCPU MicroBlazeCPU; typedef struct MicroBlazeCPU MicroBlazeCPU;

View File

@ -102,14 +102,14 @@ static void microblaze_cpu_set_irq(void *opaque, int irq, int level)
} }
#endif #endif
/* CPUClass::reset() */ static void mb_cpu_reset(DeviceState *dev)
static void mb_cpu_reset(CPUState *s)
{ {
CPUState *s = CPU(dev);
MicroBlazeCPU *cpu = MICROBLAZE_CPU(s); MicroBlazeCPU *cpu = MICROBLAZE_CPU(s);
MicroBlazeCPUClass *mcc = MICROBLAZE_CPU_GET_CLASS(cpu); MicroBlazeCPUClass *mcc = MICROBLAZE_CPU_GET_CLASS(cpu);
CPUMBState *env = &cpu->env; CPUMBState *env = &cpu->env;
mcc->parent_reset(s); mcc->parent_reset(dev);
memset(env, 0, offsetof(CPUMBState, end_reset_fields)); memset(env, 0, offsetof(CPUMBState, end_reset_fields));
env->res_addr = RES_ADDR_NONE; env->res_addr = RES_ADDR_NONE;
@ -292,7 +292,7 @@ static void mb_cpu_class_init(ObjectClass *oc, void *data)
device_class_set_parent_realize(dc, mb_cpu_realizefn, device_class_set_parent_realize(dc, mb_cpu_realizefn,
&mcc->parent_realize); &mcc->parent_realize);
cpu_class_set_parent_reset(cc, mb_cpu_reset, &mcc->parent_reset); device_class_set_parent_reset(dc, mb_cpu_reset, &mcc->parent_reset);
cc->class_by_name = mb_cpu_class_by_name; cc->class_by_name = mb_cpu_class_by_name;
cc->has_work = mb_cpu_has_work; cc->has_work = mb_cpu_has_work;

View File

@ -48,7 +48,7 @@ typedef struct MIPSCPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
const struct mips_def_t *cpu_def; const struct mips_def_t *cpu_def;
} MIPSCPUClass; } MIPSCPUClass;

View File

@ -96,14 +96,14 @@ static bool mips_cpu_has_work(CPUState *cs)
return has_work; return has_work;
} }
/* CPUClass::reset() */ static void mips_cpu_reset(DeviceState *dev)
static void mips_cpu_reset(CPUState *s)
{ {
CPUState *s = CPU(dev);
MIPSCPU *cpu = MIPS_CPU(s); MIPSCPU *cpu = MIPS_CPU(s);
MIPSCPUClass *mcc = MIPS_CPU_GET_CLASS(cpu); MIPSCPUClass *mcc = MIPS_CPU_GET_CLASS(cpu);
CPUMIPSState *env = &cpu->env; CPUMIPSState *env = &cpu->env;
mcc->parent_reset(s); mcc->parent_reset(dev);
memset(env, 0, offsetof(CPUMIPSState, end_reset_fields)); memset(env, 0, offsetof(CPUMIPSState, end_reset_fields));
@ -189,7 +189,7 @@ static void mips_cpu_class_init(ObjectClass *c, void *data)
device_class_set_parent_realize(dc, mips_cpu_realizefn, device_class_set_parent_realize(dc, mips_cpu_realizefn,
&mcc->parent_realize); &mcc->parent_realize);
cpu_class_set_parent_reset(cc, mips_cpu_reset, &mcc->parent_reset); device_class_set_parent_reset(dc, mips_cpu_reset, &mcc->parent_reset);
cc->class_by_name = mips_cpu_class_by_name; cc->class_by_name = mips_cpu_class_by_name;
cc->has_work = mips_cpu_has_work; cc->has_work = mips_cpu_has_work;

View File

@ -35,13 +35,14 @@ static bool moxie_cpu_has_work(CPUState *cs)
return cs->interrupt_request & CPU_INTERRUPT_HARD; return cs->interrupt_request & CPU_INTERRUPT_HARD;
} }
static void moxie_cpu_reset(CPUState *s) static void moxie_cpu_reset(DeviceState *dev)
{ {
CPUState *s = CPU(dev);
MoxieCPU *cpu = MOXIE_CPU(s); MoxieCPU *cpu = MOXIE_CPU(s);
MoxieCPUClass *mcc = MOXIE_CPU_GET_CLASS(cpu); MoxieCPUClass *mcc = MOXIE_CPU_GET_CLASS(cpu);
CPUMoxieState *env = &cpu->env; CPUMoxieState *env = &cpu->env;
mcc->parent_reset(s); mcc->parent_reset(dev);
memset(env, 0, offsetof(CPUMoxieState, end_reset_fields)); memset(env, 0, offsetof(CPUMoxieState, end_reset_fields));
env->pc = 0x1000; env->pc = 0x1000;
@ -101,7 +102,7 @@ static void moxie_cpu_class_init(ObjectClass *oc, void *data)
device_class_set_parent_realize(dc, moxie_cpu_realizefn, device_class_set_parent_realize(dc, moxie_cpu_realizefn,
&mcc->parent_realize); &mcc->parent_realize);
cpu_class_set_parent_reset(cc, moxie_cpu_reset, &mcc->parent_reset); device_class_set_parent_reset(dc, moxie_cpu_reset, &mcc->parent_reset);
cc->class_by_name = moxie_cpu_class_by_name; cc->class_by_name = moxie_cpu_class_by_name;

View File

@ -69,7 +69,7 @@ typedef struct MoxieCPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} MoxieCPUClass; } MoxieCPUClass;
/** /**

View File

@ -39,9 +39,9 @@ static bool nios2_cpu_has_work(CPUState *cs)
return cs->interrupt_request & (CPU_INTERRUPT_HARD | CPU_INTERRUPT_NMI); return cs->interrupt_request & (CPU_INTERRUPT_HARD | CPU_INTERRUPT_NMI);
} }
/* CPUClass::reset() */ static void nios2_cpu_reset(DeviceState *dev)
static void nios2_cpu_reset(CPUState *cs)
{ {
CPUState *cs = CPU(dev);
Nios2CPU *cpu = NIOS2_CPU(cs); Nios2CPU *cpu = NIOS2_CPU(cs);
Nios2CPUClass *ncc = NIOS2_CPU_GET_CLASS(cpu); Nios2CPUClass *ncc = NIOS2_CPU_GET_CLASS(cpu);
CPUNios2State *env = &cpu->env; CPUNios2State *env = &cpu->env;
@ -51,7 +51,7 @@ static void nios2_cpu_reset(CPUState *cs)
log_cpu_state(cs, 0); log_cpu_state(cs, 0);
} }
ncc->parent_reset(cs); ncc->parent_reset(dev);
memset(env->regs, 0, sizeof(uint32_t) * NUM_CORE_REGS); memset(env->regs, 0, sizeof(uint32_t) * NUM_CORE_REGS);
env->regs[R_PC] = cpu->reset_addr; env->regs[R_PC] = cpu->reset_addr;
@ -188,7 +188,7 @@ static void nios2_cpu_class_init(ObjectClass *oc, void *data)
device_class_set_parent_realize(dc, nios2_cpu_realizefn, device_class_set_parent_realize(dc, nios2_cpu_realizefn,
&ncc->parent_realize); &ncc->parent_realize);
device_class_set_props(dc, nios2_properties); device_class_set_props(dc, nios2_properties);
cpu_class_set_parent_reset(cc, nios2_cpu_reset, &ncc->parent_reset); device_class_set_parent_reset(dc, nios2_cpu_reset, &ncc->parent_reset);
cc->class_by_name = nios2_cpu_class_by_name; cc->class_by_name = nios2_cpu_class_by_name;
cc->has_work = nios2_cpu_has_work; cc->has_work = nios2_cpu_has_work;

View File

@ -50,7 +50,7 @@ typedef struct Nios2CPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} Nios2CPUClass; } Nios2CPUClass;
#define TARGET_HAS_ICE 1 #define TARGET_HAS_ICE 1

View File

@ -41,13 +41,13 @@ static void openrisc_disas_set_info(CPUState *cpu, disassemble_info *info)
info->print_insn = print_insn_or1k; info->print_insn = print_insn_or1k;
} }
/* CPUClass::reset() */ static void openrisc_cpu_reset(DeviceState *dev)
static void openrisc_cpu_reset(CPUState *s)
{ {
CPUState *s = CPU(dev);
OpenRISCCPU *cpu = OPENRISC_CPU(s); OpenRISCCPU *cpu = OPENRISC_CPU(s);
OpenRISCCPUClass *occ = OPENRISC_CPU_GET_CLASS(cpu); OpenRISCCPUClass *occ = OPENRISC_CPU_GET_CLASS(cpu);
occ->parent_reset(s); occ->parent_reset(dev);
memset(&cpu->env, 0, offsetof(CPUOpenRISCState, end_reset_fields)); memset(&cpu->env, 0, offsetof(CPUOpenRISCState, end_reset_fields));
@ -150,7 +150,7 @@ static void openrisc_cpu_class_init(ObjectClass *oc, void *data)
device_class_set_parent_realize(dc, openrisc_cpu_realizefn, device_class_set_parent_realize(dc, openrisc_cpu_realizefn,
&occ->parent_realize); &occ->parent_realize);
cpu_class_set_parent_reset(cc, openrisc_cpu_reset, &occ->parent_reset); device_class_set_parent_reset(dc, openrisc_cpu_reset, &occ->parent_reset);
cc->class_by_name = openrisc_cpu_class_by_name; cc->class_by_name = openrisc_cpu_class_by_name;
cc->has_work = openrisc_cpu_has_work; cc->has_work = openrisc_cpu_has_work;

View File

@ -48,7 +48,7 @@ typedef struct OpenRISCCPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} OpenRISCCPUClass; } OpenRISCCPUClass;
#define TARGET_INSN_START_EXTRA_WORDS 1 #define TARGET_INSN_START_EXTRA_WORDS 1

View File

@ -166,7 +166,7 @@ typedef struct PowerPCCPUClass {
DeviceRealize parent_realize; DeviceRealize parent_realize;
DeviceUnrealize parent_unrealize; DeviceUnrealize parent_unrealize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
void (*parent_parse_features)(const char *type, char *str, Error **errp); void (*parent_parse_features)(const char *type, char *str, Error **errp);
uint32_t pvr; uint32_t pvr;

View File

@ -10669,16 +10669,16 @@ static bool ppc_cpu_has_work(CPUState *cs)
return msr_ee && (cs->interrupt_request & CPU_INTERRUPT_HARD); return msr_ee && (cs->interrupt_request & CPU_INTERRUPT_HARD);
} }
/* CPUClass::reset() */ static void ppc_cpu_reset(DeviceState *dev)
static void ppc_cpu_reset(CPUState *s)
{ {
CPUState *s = CPU(dev);
PowerPCCPU *cpu = POWERPC_CPU(s); PowerPCCPU *cpu = POWERPC_CPU(s);
PowerPCCPUClass *pcc = POWERPC_CPU_GET_CLASS(cpu); PowerPCCPUClass *pcc = POWERPC_CPU_GET_CLASS(cpu);
CPUPPCState *env = &cpu->env; CPUPPCState *env = &cpu->env;
target_ulong msr; target_ulong msr;
int i; int i;
pcc->parent_reset(s); pcc->parent_reset(dev);
msr = (target_ulong)0; msr = (target_ulong)0;
msr |= (target_ulong)MSR_HVB; msr |= (target_ulong)MSR_HVB;
@ -10885,7 +10885,7 @@ static void ppc_cpu_class_init(ObjectClass *oc, void *data)
pcc->interrupts_big_endian = ppc_cpu_interrupts_big_endian_always; pcc->interrupts_big_endian = ppc_cpu_interrupts_big_endian_always;
device_class_set_props(dc, ppc_cpu_properties); device_class_set_props(dc, ppc_cpu_properties);
cpu_class_set_parent_reset(cc, ppc_cpu_reset, &pcc->parent_reset); device_class_set_parent_reset(dc, ppc_cpu_reset, &pcc->parent_reset);
cc->class_by_name = ppc_cpu_class_by_name; cc->class_by_name = ppc_cpu_class_by_name;
pcc->parent_parse_features = cc->parse_features; pcc->parent_parse_features = cc->parse_features;

View File

@ -330,13 +330,14 @@ void restore_state_to_opc(CPURISCVState *env, TranslationBlock *tb,
env->pc = data[0]; env->pc = data[0];
} }
static void riscv_cpu_reset(CPUState *cs) static void riscv_cpu_reset(DeviceState *dev)
{ {
CPUState *cs = CPU(dev);
RISCVCPU *cpu = RISCV_CPU(cs); RISCVCPU *cpu = RISCV_CPU(cs);
RISCVCPUClass *mcc = RISCV_CPU_GET_CLASS(cpu); RISCVCPUClass *mcc = RISCV_CPU_GET_CLASS(cpu);
CPURISCVState *env = &cpu->env; CPURISCVState *env = &cpu->env;
mcc->parent_reset(cs); mcc->parent_reset(dev);
#ifndef CONFIG_USER_ONLY #ifndef CONFIG_USER_ONLY
env->priv = PRV_M; env->priv = PRV_M;
env->mstatus &= ~(MSTATUS_MIE | MSTATUS_MPRV); env->mstatus &= ~(MSTATUS_MIE | MSTATUS_MPRV);
@ -511,7 +512,7 @@ static void riscv_cpu_class_init(ObjectClass *c, void *data)
device_class_set_parent_realize(dc, riscv_cpu_realize, device_class_set_parent_realize(dc, riscv_cpu_realize,
&mcc->parent_realize); &mcc->parent_realize);
cpu_class_set_parent_reset(cc, riscv_cpu_reset, &mcc->parent_reset); device_class_set_parent_reset(dc, riscv_cpu_reset, &mcc->parent_reset);
cc->class_by_name = riscv_cpu_class_by_name; cc->class_by_name = riscv_cpu_class_by_name;
cc->has_work = riscv_cpu_has_work; cc->has_work = riscv_cpu_has_work;

View File

@ -234,7 +234,7 @@ typedef struct RISCVCPUClass {
CPUClass parent_class; CPUClass parent_class;
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} RISCVCPUClass; } RISCVCPUClass;
/** /**

View File

@ -61,7 +61,7 @@ typedef struct S390CPUClass {
const char *desc; const char *desc;
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
void (*load_normal)(CPUState *cpu); void (*load_normal)(CPUState *cpu);
void (*reset)(CPUState *cpu, cpu_reset_type type); void (*reset)(CPUState *cpu, cpu_reset_type type);
} S390CPUClass; } S390CPUClass;

View File

@ -96,8 +96,9 @@ static void s390_cpu_reset(CPUState *s, cpu_reset_type type)
S390CPU *cpu = S390_CPU(s); S390CPU *cpu = S390_CPU(s);
S390CPUClass *scc = S390_CPU_GET_CLASS(cpu); S390CPUClass *scc = S390_CPU_GET_CLASS(cpu);
CPUS390XState *env = &cpu->env; CPUS390XState *env = &cpu->env;
DeviceState *dev = DEVICE(s);
scc->parent_reset(s); scc->parent_reset(dev);
cpu->env.sigp_order = 0; cpu->env.sigp_order = 0;
s390_cpu_set_state(S390_CPU_STATE_STOPPED, cpu); s390_cpu_set_state(S390_CPU_STATE_STOPPED, cpu);
@ -450,8 +451,9 @@ static Property s390x_cpu_properties[] = {
DEFINE_PROP_END_OF_LIST() DEFINE_PROP_END_OF_LIST()
}; };
static void s390_cpu_reset_full(CPUState *s) static void s390_cpu_reset_full(DeviceState *dev)
{ {
CPUState *s = CPU(dev);
return s390_cpu_reset(s, S390_CPU_RESET_CLEAR); return s390_cpu_reset(s, S390_CPU_RESET_CLEAR);
} }
@ -466,7 +468,7 @@ static void s390_cpu_class_init(ObjectClass *oc, void *data)
device_class_set_props(dc, s390x_cpu_properties); device_class_set_props(dc, s390x_cpu_properties);
dc->user_creatable = true; dc->user_creatable = true;
cpu_class_set_parent_reset(cc, s390_cpu_reset_full, &scc->parent_reset); device_class_set_parent_reset(dc, s390_cpu_reset_full, &scc->parent_reset);
#if !defined(CONFIG_USER_ONLY) #if !defined(CONFIG_USER_ONLY)
scc->load_normal = s390_cpu_load_normal; scc->load_normal = s390_cpu_load_normal;
#endif #endif

View File

@ -51,7 +51,7 @@ typedef struct SuperHCPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
uint32_t pvr; uint32_t pvr;
uint32_t prr; uint32_t prr;

View File

@ -47,14 +47,14 @@ static bool superh_cpu_has_work(CPUState *cs)
return cs->interrupt_request & CPU_INTERRUPT_HARD; return cs->interrupt_request & CPU_INTERRUPT_HARD;
} }
/* CPUClass::reset() */ static void superh_cpu_reset(DeviceState *dev)
static void superh_cpu_reset(CPUState *s)
{ {
CPUState *s = CPU(dev);
SuperHCPU *cpu = SUPERH_CPU(s); SuperHCPU *cpu = SUPERH_CPU(s);
SuperHCPUClass *scc = SUPERH_CPU_GET_CLASS(cpu); SuperHCPUClass *scc = SUPERH_CPU_GET_CLASS(cpu);
CPUSH4State *env = &cpu->env; CPUSH4State *env = &cpu->env;
scc->parent_reset(s); scc->parent_reset(dev);
memset(env, 0, offsetof(CPUSH4State, end_reset_fields)); memset(env, 0, offsetof(CPUSH4State, end_reset_fields));
@ -214,7 +214,7 @@ static void superh_cpu_class_init(ObjectClass *oc, void *data)
device_class_set_parent_realize(dc, superh_cpu_realizefn, device_class_set_parent_realize(dc, superh_cpu_realizefn,
&scc->parent_realize); &scc->parent_realize);
cpu_class_set_parent_reset(cc, superh_cpu_reset, &scc->parent_reset); device_class_set_parent_reset(dc, superh_cpu_reset, &scc->parent_reset);
cc->class_by_name = superh_cpu_class_by_name; cc->class_by_name = superh_cpu_class_by_name;
cc->has_work = superh_cpu_has_work; cc->has_work = superh_cpu_has_work;

View File

@ -49,7 +49,7 @@ typedef struct SPARCCPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
sparc_def_t *cpu_def; sparc_def_t *cpu_def;
} SPARCCPUClass; } SPARCCPUClass;

View File

@ -28,14 +28,14 @@
//#define DEBUG_FEATURES //#define DEBUG_FEATURES
/* CPUClass::reset() */ static void sparc_cpu_reset(DeviceState *dev)
static void sparc_cpu_reset(CPUState *s)
{ {
CPUState *s = CPU(dev);
SPARCCPU *cpu = SPARC_CPU(s); SPARCCPU *cpu = SPARC_CPU(s);
SPARCCPUClass *scc = SPARC_CPU_GET_CLASS(cpu); SPARCCPUClass *scc = SPARC_CPU_GET_CLASS(cpu);
CPUSPARCState *env = &cpu->env; CPUSPARCState *env = &cpu->env;
scc->parent_reset(s); scc->parent_reset(dev);
memset(env, 0, offsetof(CPUSPARCState, end_reset_fields)); memset(env, 0, offsetof(CPUSPARCState, end_reset_fields));
env->cwp = 0; env->cwp = 0;
@ -859,7 +859,7 @@ static void sparc_cpu_class_init(ObjectClass *oc, void *data)
&scc->parent_realize); &scc->parent_realize);
device_class_set_props(dc, sparc_cpu_properties); device_class_set_props(dc, sparc_cpu_properties);
cpu_class_set_parent_reset(cc, sparc_cpu_reset, &scc->parent_reset); device_class_set_parent_reset(dc, sparc_cpu_reset, &scc->parent_reset);
cc->class_by_name = sparc_cpu_class_by_name; cc->class_by_name = sparc_cpu_class_by_name;
cc->parse_features = sparc_cpu_parse_features; cc->parse_features = sparc_cpu_parse_features;

View File

@ -68,13 +68,14 @@ static bool tilegx_cpu_has_work(CPUState *cs)
return true; return true;
} }
static void tilegx_cpu_reset(CPUState *s) static void tilegx_cpu_reset(DeviceState *dev)
{ {
CPUState *s = CPU(dev);
TileGXCPU *cpu = TILEGX_CPU(s); TileGXCPU *cpu = TILEGX_CPU(s);
TileGXCPUClass *tcc = TILEGX_CPU_GET_CLASS(cpu); TileGXCPUClass *tcc = TILEGX_CPU_GET_CLASS(cpu);
CPUTLGState *env = &cpu->env; CPUTLGState *env = &cpu->env;
tcc->parent_reset(s); tcc->parent_reset(dev);
memset(env, 0, offsetof(CPUTLGState, end_reset_fields)); memset(env, 0, offsetof(CPUTLGState, end_reset_fields));
} }
@ -142,7 +143,7 @@ static void tilegx_cpu_class_init(ObjectClass *oc, void *data)
device_class_set_parent_realize(dc, tilegx_cpu_realizefn, device_class_set_parent_realize(dc, tilegx_cpu_realizefn,
&tcc->parent_realize); &tcc->parent_realize);
cpu_class_set_parent_reset(cc, tilegx_cpu_reset, &tcc->parent_reset); device_class_set_parent_reset(dc, tilegx_cpu_reset, &tcc->parent_reset);
cc->class_by_name = tilegx_cpu_class_by_name; cc->class_by_name = tilegx_cpu_class_by_name;
cc->has_work = tilegx_cpu_has_work; cc->has_work = tilegx_cpu_has_work;

View File

@ -118,7 +118,7 @@ typedef struct TileGXCPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} TileGXCPUClass; } TileGXCPUClass;
/** /**

View File

@ -36,7 +36,7 @@ typedef struct TriCoreCPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
} TriCoreCPUClass; } TriCoreCPUClass;
typedef struct TriCoreCPU TriCoreCPU; typedef struct TriCoreCPU TriCoreCPU;

View File

@ -53,13 +53,14 @@ static void tricore_cpu_synchronize_from_tb(CPUState *cs,
env->PC = tb->pc; env->PC = tb->pc;
} }
static void tricore_cpu_reset(CPUState *s) static void tricore_cpu_reset(DeviceState *dev)
{ {
CPUState *s = CPU(dev);
TriCoreCPU *cpu = TRICORE_CPU(s); TriCoreCPU *cpu = TRICORE_CPU(s);
TriCoreCPUClass *tcc = TRICORE_CPU_GET_CLASS(cpu); TriCoreCPUClass *tcc = TRICORE_CPU_GET_CLASS(cpu);
CPUTriCoreState *env = &cpu->env; CPUTriCoreState *env = &cpu->env;
tcc->parent_reset(s); tcc->parent_reset(dev);
cpu_state_reset(env); cpu_state_reset(env);
} }
@ -153,7 +154,7 @@ static void tricore_cpu_class_init(ObjectClass *c, void *data)
device_class_set_parent_realize(dc, tricore_cpu_realizefn, device_class_set_parent_realize(dc, tricore_cpu_realizefn,
&mcc->parent_realize); &mcc->parent_realize);
cpu_class_set_parent_reset(cc, tricore_cpu_reset, &mcc->parent_reset); device_class_set_parent_reset(dc, tricore_cpu_reset, &mcc->parent_reset);
cc->class_by_name = tricore_cpu_class_by_name; cc->class_by_name = tricore_cpu_class_by_name;
cc->has_work = tricore_cpu_has_work; cc->has_work = tricore_cpu_has_work;

View File

@ -56,7 +56,7 @@ typedef struct XtensaCPUClass {
/*< public >*/ /*< public >*/
DeviceRealize parent_realize; DeviceRealize parent_realize;
void (*parent_reset)(CPUState *cpu); DeviceReset parent_reset;
const XtensaConfig *config; const XtensaConfig *config;
} XtensaCPUClass; } XtensaCPUClass;

View File

@ -67,14 +67,14 @@ bool xtensa_abi_call0(void)
} }
#endif #endif
/* CPUClass::reset() */ static void xtensa_cpu_reset(DeviceState *dev)
static void xtensa_cpu_reset(CPUState *s)
{ {
CPUState *s = CPU(dev);
XtensaCPU *cpu = XTENSA_CPU(s); XtensaCPU *cpu = XTENSA_CPU(s);
XtensaCPUClass *xcc = XTENSA_CPU_GET_CLASS(cpu); XtensaCPUClass *xcc = XTENSA_CPU_GET_CLASS(cpu);
CPUXtensaState *env = &cpu->env; CPUXtensaState *env = &cpu->env;
xcc->parent_reset(s); xcc->parent_reset(dev);
env->exception_taken = 0; env->exception_taken = 0;
env->pc = env->config->exception_vector[EXC_RESET0 + env->static_vectors]; env->pc = env->config->exception_vector[EXC_RESET0 + env->static_vectors];
@ -184,7 +184,7 @@ static void xtensa_cpu_class_init(ObjectClass *oc, void *data)
device_class_set_parent_realize(dc, xtensa_cpu_realizefn, device_class_set_parent_realize(dc, xtensa_cpu_realizefn,
&xcc->parent_realize); &xcc->parent_realize);
cpu_class_set_parent_reset(cc, xtensa_cpu_reset, &xcc->parent_reset); device_class_set_parent_reset(dc, xtensa_cpu_reset, &xcc->parent_reset);
cc->class_by_name = xtensa_cpu_class_by_name; cc->class_by_name = xtensa_cpu_class_by_name;
cc->has_work = xtensa_cpu_has_work; cc->has_work = xtensa_cpu_has_work;