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:
parent
4ba59be1d6
commit
781c67ca55
@ -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
|
||||||
|
@ -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
|
||||||
|
47
scripts/coccinelle/cpu-reset.cocci
Normal file
47
scripts/coccinelle/cpu-reset.cocci
Normal 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);
|
||||||
|
...>
|
||||||
|
}
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user