cpu: Turn cpu_has_work() into a CPUClass hook
Default to false. Tidy variable naming and inline cast uses while at it. Tested-by: Jia Liu <proljc@gmail.com> (or32) Signed-off-by: Andreas Färber <afaerber@suse.de>
This commit is contained in:
parent
1cf5ccbca8
commit
8c2e1b0093
@ -23,11 +23,6 @@
|
|||||||
#include "qemu/atomic.h"
|
#include "qemu/atomic.h"
|
||||||
#include "sysemu/qtest.h"
|
#include "sysemu/qtest.h"
|
||||||
|
|
||||||
bool qemu_cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
return cpu_has_work(cpu);
|
|
||||||
}
|
|
||||||
|
|
||||||
void cpu_loop_exit(CPUArchState *env)
|
void cpu_loop_exit(CPUArchState *env)
|
||||||
{
|
{
|
||||||
CPUState *cpu = ENV_GET_CPU(env);
|
CPUState *cpu = ENV_GET_CPU(env);
|
||||||
|
2
cpus.c
2
cpus.c
@ -76,7 +76,7 @@ static bool cpu_thread_is_idle(CPUState *cpu)
|
|||||||
if (cpu_is_stopped(cpu)) {
|
if (cpu_is_stopped(cpu)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (!cpu->halted || qemu_cpu_has_work(cpu) ||
|
if (!cpu->halted || cpu_has_work(cpu) ||
|
||||||
kvm_halt_in_kernel()) {
|
kvm_halt_in_kernel()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -70,6 +70,7 @@ struct TranslationBlock;
|
|||||||
* instantiatable CPU type.
|
* instantiatable CPU type.
|
||||||
* @reset: Callback to reset the #CPUState to its initial state.
|
* @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.
|
||||||
* @do_interrupt: Callback for interrupt handling.
|
* @do_interrupt: Callback for interrupt handling.
|
||||||
* @do_unassigned_access: Callback for unassigned access handling.
|
* @do_unassigned_access: Callback for unassigned access handling.
|
||||||
* @memory_rw_debug: Callback for GDB memory access.
|
* @memory_rw_debug: Callback for GDB memory access.
|
||||||
@ -99,6 +100,7 @@ typedef struct CPUClass {
|
|||||||
|
|
||||||
void (*reset)(CPUState *cpu);
|
void (*reset)(CPUState *cpu);
|
||||||
int reset_dump_flags;
|
int reset_dump_flags;
|
||||||
|
bool (*has_work)(CPUState *cpu);
|
||||||
void (*do_interrupt)(CPUState *cpu);
|
void (*do_interrupt)(CPUState *cpu);
|
||||||
CPUUnassignedAccess do_unassigned_access;
|
CPUUnassignedAccess do_unassigned_access;
|
||||||
int (*memory_rw_debug)(CPUState *cpu, vaddr addr,
|
int (*memory_rw_debug)(CPUState *cpu, vaddr addr,
|
||||||
@ -348,14 +350,20 @@ void cpu_reset(CPUState *cpu);
|
|||||||
ObjectClass *cpu_class_by_name(const char *typename, const char *cpu_model);
|
ObjectClass *cpu_class_by_name(const char *typename, const char *cpu_model);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* qemu_cpu_has_work:
|
* cpu_has_work:
|
||||||
* @cpu: The vCPU to check.
|
* @cpu: The vCPU to check.
|
||||||
*
|
*
|
||||||
* Checks whether the CPU has work to do.
|
* Checks whether the CPU has work to do.
|
||||||
*
|
*
|
||||||
* Returns: %true if the CPU has work, %false otherwise.
|
* Returns: %true if the CPU has work, %false otherwise.
|
||||||
*/
|
*/
|
||||||
bool qemu_cpu_has_work(CPUState *cpu);
|
static inline bool cpu_has_work(CPUState *cpu)
|
||||||
|
{
|
||||||
|
CPUClass *cc = CPU_GET_CLASS(cpu);
|
||||||
|
|
||||||
|
g_assert(cc->has_work);
|
||||||
|
return cc->has_work(cpu);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* qemu_cpu_is_self:
|
* qemu_cpu_is_self:
|
||||||
|
@ -200,6 +200,11 @@ static void cpu_common_reset(CPUState *cpu)
|
|||||||
cpu->halted = 0;
|
cpu->halted = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool cpu_common_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
ObjectClass *cpu_class_by_name(const char *typename, const char *cpu_model)
|
ObjectClass *cpu_class_by_name(const char *typename, const char *cpu_model)
|
||||||
{
|
{
|
||||||
CPUClass *cc = CPU_CLASS(object_class_by_name(typename));
|
CPUClass *cc = CPU_CLASS(object_class_by_name(typename));
|
||||||
@ -244,6 +249,7 @@ static void cpu_class_init(ObjectClass *klass, void *data)
|
|||||||
k->class_by_name = cpu_common_class_by_name;
|
k->class_by_name = cpu_common_class_by_name;
|
||||||
k->reset = cpu_common_reset;
|
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->get_paging_enabled = cpu_common_get_paging_enabled;
|
k->get_paging_enabled = cpu_common_get_paging_enabled;
|
||||||
k->get_memory_mapping = cpu_common_get_memory_mapping;
|
k->get_memory_mapping = cpu_common_get_memory_mapping;
|
||||||
k->write_elf32_qemunote = cpu_common_write_elf32_qemunote;
|
k->write_elf32_qemunote = cpu_common_write_elf32_qemunote;
|
||||||
|
@ -31,6 +31,21 @@ static void alpha_cpu_set_pc(CPUState *cs, vaddr value)
|
|||||||
cpu->env.pc = value;
|
cpu->env.pc = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool alpha_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
/* Here we are checking to see if the CPU should wake up from HALT.
|
||||||
|
We will have gotten into this state only for WTINT from PALmode. */
|
||||||
|
/* ??? I'm not sure how the IPL state works with WTINT to keep a CPU
|
||||||
|
asleep even if (some) interrupts have been asserted. For now,
|
||||||
|
assume that if a CPU really wants to stay asleep, it will mask
|
||||||
|
interrupts at the chipset level, which will prevent these bits
|
||||||
|
from being set in the first place. */
|
||||||
|
return cs->interrupt_request & (CPU_INTERRUPT_HARD
|
||||||
|
| CPU_INTERRUPT_TIMER
|
||||||
|
| CPU_INTERRUPT_SMP
|
||||||
|
| CPU_INTERRUPT_MCHK);
|
||||||
|
}
|
||||||
|
|
||||||
static void alpha_cpu_realizefn(DeviceState *dev, Error **errp)
|
static void alpha_cpu_realizefn(DeviceState *dev, Error **errp)
|
||||||
{
|
{
|
||||||
CPUState *cs = CPU(dev);
|
CPUState *cs = CPU(dev);
|
||||||
@ -267,6 +282,7 @@ static void alpha_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
dc->realize = alpha_cpu_realizefn;
|
dc->realize = alpha_cpu_realizefn;
|
||||||
|
|
||||||
cc->class_by_name = alpha_cpu_class_by_name;
|
cc->class_by_name = alpha_cpu_class_by_name;
|
||||||
|
cc->has_work = alpha_cpu_has_work;
|
||||||
cc->do_interrupt = alpha_cpu_do_interrupt;
|
cc->do_interrupt = alpha_cpu_do_interrupt;
|
||||||
cc->dump_state = alpha_cpu_dump_state;
|
cc->dump_state = alpha_cpu_dump_state;
|
||||||
cc->set_pc = alpha_cpu_set_pc;
|
cc->set_pc = alpha_cpu_set_pc;
|
||||||
|
@ -498,21 +498,6 @@ static inline void cpu_get_tb_cpu_state(CPUAlphaState *env, target_ulong *pc,
|
|||||||
*pflags = flags;
|
*pflags = flags;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
/* Here we are checking to see if the CPU should wake up from HALT.
|
|
||||||
We will have gotten into this state only for WTINT from PALmode. */
|
|
||||||
/* ??? I'm not sure how the IPL state works with WTINT to keep a CPU
|
|
||||||
asleep even if (some) interrupts have been asserted. For now,
|
|
||||||
assume that if a CPU really wants to stay asleep, it will mask
|
|
||||||
interrupts at the chipset level, which will prevent these bits
|
|
||||||
from being set in the first place. */
|
|
||||||
return cpu->interrupt_request & (CPU_INTERRUPT_HARD
|
|
||||||
| CPU_INTERRUPT_TIMER
|
|
||||||
| CPU_INTERRUPT_SMP
|
|
||||||
| CPU_INTERRUPT_MCHK);
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
#endif /* !defined (__CPU_ALPHA_H__) */
|
#endif /* !defined (__CPU_ALPHA_H__) */
|
||||||
|
@ -36,6 +36,12 @@ static void arm_cpu_set_pc(CPUState *cs, vaddr value)
|
|||||||
cpu->env.regs[15] = value;
|
cpu->env.regs[15] = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool arm_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
return cs->interrupt_request &
|
||||||
|
(CPU_INTERRUPT_FIQ | CPU_INTERRUPT_HARD | CPU_INTERRUPT_EXITTB);
|
||||||
|
}
|
||||||
|
|
||||||
static void cp_reg_reset(gpointer key, gpointer value, gpointer opaque)
|
static void cp_reg_reset(gpointer key, gpointer value, gpointer opaque)
|
||||||
{
|
{
|
||||||
/* Reset a single ARMCPRegInfo register */
|
/* Reset a single ARMCPRegInfo register */
|
||||||
@ -1001,6 +1007,7 @@ static void arm_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
cc->reset = arm_cpu_reset;
|
cc->reset = arm_cpu_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->do_interrupt = arm_cpu_do_interrupt;
|
cc->do_interrupt = arm_cpu_do_interrupt;
|
||||||
cc->dump_state = arm_cpu_dump_state;
|
cc->dump_state = arm_cpu_dump_state;
|
||||||
cc->set_pc = arm_cpu_set_pc;
|
cc->set_pc = arm_cpu_set_pc;
|
||||||
|
@ -1166,12 +1166,6 @@ static inline void cpu_get_tb_cpu_state(CPUARMState *env, target_ulong *pc,
|
|||||||
*cs_base = 0;
|
*cs_base = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
return cpu->interrupt_request &
|
|
||||||
(CPU_INTERRUPT_FIQ | CPU_INTERRUPT_HARD | CPU_INTERRUPT_EXITTB);
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
static inline void cpu_pc_from_tb(CPUARMState *env, TranslationBlock *tb)
|
static inline void cpu_pc_from_tb(CPUARMState *env, TranslationBlock *tb)
|
||||||
|
@ -33,6 +33,11 @@ static void cris_cpu_set_pc(CPUState *cs, vaddr value)
|
|||||||
cpu->env.pc = value;
|
cpu->env.pc = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool cris_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
return cs->interrupt_request & (CPU_INTERRUPT_HARD | CPU_INTERRUPT_NMI);
|
||||||
|
}
|
||||||
|
|
||||||
/* CPUClass::reset() */
|
/* CPUClass::reset() */
|
||||||
static void cris_cpu_reset(CPUState *s)
|
static void cris_cpu_reset(CPUState *s)
|
||||||
{
|
{
|
||||||
@ -283,6 +288,7 @@ static void cris_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
cc->reset = cris_cpu_reset;
|
cc->reset = cris_cpu_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->do_interrupt = cris_cpu_do_interrupt;
|
cc->do_interrupt = cris_cpu_do_interrupt;
|
||||||
cc->dump_state = cris_cpu_dump_state;
|
cc->dump_state = cris_cpu_dump_state;
|
||||||
cc->set_pc = cris_cpu_set_pc;
|
cc->set_pc = cris_cpu_set_pc;
|
||||||
|
@ -276,11 +276,6 @@ static inline void cpu_get_tb_cpu_state(CPUCRISState *env, target_ulong *pc,
|
|||||||
#define cpu_list cris_cpu_list
|
#define cpu_list cris_cpu_list
|
||||||
void cris_cpu_list(FILE *f, fprintf_function cpu_fprintf);
|
void cris_cpu_list(FILE *f, fprintf_function cpu_fprintf);
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
return cpu->interrupt_request & (CPU_INTERRUPT_HARD | CPU_INTERRUPT_NMI);
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -2695,6 +2695,20 @@ static void x86_cpu_synchronize_from_tb(CPUState *cs, TranslationBlock *tb)
|
|||||||
cpu->env.eip = tb->pc - tb->cs_base;
|
cpu->env.eip = tb->pc - tb->cs_base;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool x86_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
X86CPU *cpu = X86_CPU(cs);
|
||||||
|
CPUX86State *env = &cpu->env;
|
||||||
|
|
||||||
|
return ((cs->interrupt_request & (CPU_INTERRUPT_HARD |
|
||||||
|
CPU_INTERRUPT_POLL)) &&
|
||||||
|
(env->eflags & IF_MASK)) ||
|
||||||
|
(cs->interrupt_request & (CPU_INTERRUPT_NMI |
|
||||||
|
CPU_INTERRUPT_INIT |
|
||||||
|
CPU_INTERRUPT_SIPI |
|
||||||
|
CPU_INTERRUPT_MCE));
|
||||||
|
}
|
||||||
|
|
||||||
static Property x86_cpu_properties[] = {
|
static Property x86_cpu_properties[] = {
|
||||||
DEFINE_PROP_BOOL("pmu", X86CPU, enable_pmu, false),
|
DEFINE_PROP_BOOL("pmu", X86CPU, enable_pmu, false),
|
||||||
{ .name = "hv-spinlocks", .info = &qdev_prop_spinlocks },
|
{ .name = "hv-spinlocks", .info = &qdev_prop_spinlocks },
|
||||||
@ -2721,6 +2735,7 @@ static void x86_cpu_common_class_init(ObjectClass *oc, void *data)
|
|||||||
cc->reset = x86_cpu_reset;
|
cc->reset = x86_cpu_reset;
|
||||||
cc->reset_dump_flags = CPU_DUMP_FPU | CPU_DUMP_CCOP;
|
cc->reset_dump_flags = CPU_DUMP_FPU | CPU_DUMP_CCOP;
|
||||||
|
|
||||||
|
cc->has_work = x86_cpu_has_work;
|
||||||
cc->do_interrupt = x86_cpu_do_interrupt;
|
cc->do_interrupt = x86_cpu_do_interrupt;
|
||||||
cc->dump_state = x86_cpu_dump_state;
|
cc->dump_state = x86_cpu_dump_state;
|
||||||
cc->set_pc = x86_cpu_set_pc;
|
cc->set_pc = x86_cpu_set_pc;
|
||||||
|
@ -1186,20 +1186,6 @@ void optimize_flags_init(void);
|
|||||||
#include "hw/i386/apic.h"
|
#include "hw/i386/apic.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cs)
|
|
||||||
{
|
|
||||||
X86CPU *cpu = X86_CPU(cs);
|
|
||||||
CPUX86State *env = &cpu->env;
|
|
||||||
|
|
||||||
return ((cs->interrupt_request & (CPU_INTERRUPT_HARD |
|
|
||||||
CPU_INTERRUPT_POLL)) &&
|
|
||||||
(env->eflags & IF_MASK)) ||
|
|
||||||
(cs->interrupt_request & (CPU_INTERRUPT_NMI |
|
|
||||||
CPU_INTERRUPT_INIT |
|
|
||||||
CPU_INTERRUPT_SIPI |
|
|
||||||
CPU_INTERRUPT_MCE));
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
static inline void cpu_get_tb_cpu_state(CPUX86State *env, target_ulong *pc,
|
static inline void cpu_get_tb_cpu_state(CPUX86State *env, target_ulong *pc,
|
||||||
|
@ -110,6 +110,11 @@ static void lm32_cpu_init_cfg_reg(LM32CPU *cpu)
|
|||||||
env->cfg = cfg;
|
env->cfg = cfg;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool lm32_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
return cs->interrupt_request & CPU_INTERRUPT_HARD;
|
||||||
|
}
|
||||||
|
|
||||||
/* CPUClass::reset() */
|
/* CPUClass::reset() */
|
||||||
static void lm32_cpu_reset(CPUState *s)
|
static void lm32_cpu_reset(CPUState *s)
|
||||||
{
|
{
|
||||||
@ -255,6 +260,7 @@ static void lm32_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
cc->reset = lm32_cpu_reset;
|
cc->reset = lm32_cpu_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->do_interrupt = lm32_cpu_do_interrupt;
|
cc->do_interrupt = lm32_cpu_do_interrupt;
|
||||||
cc->dump_state = lm32_cpu_dump_state;
|
cc->dump_state = lm32_cpu_dump_state;
|
||||||
cc->set_pc = lm32_cpu_set_pc;
|
cc->set_pc = lm32_cpu_set_pc;
|
||||||
|
@ -245,11 +245,6 @@ static inline void cpu_get_tb_cpu_state(CPULM32State *env, target_ulong *pc,
|
|||||||
*flags = 0;
|
*flags = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
return cpu->interrupt_request & CPU_INTERRUPT_HARD;
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -30,6 +30,11 @@ static void m68k_cpu_set_pc(CPUState *cs, vaddr value)
|
|||||||
cpu->env.pc = value;
|
cpu->env.pc = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool m68k_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
return cs->interrupt_request & CPU_INTERRUPT_HARD;
|
||||||
|
}
|
||||||
|
|
||||||
static void m68k_set_feature(CPUM68KState *env, int feature)
|
static void m68k_set_feature(CPUM68KState *env, int feature)
|
||||||
{
|
{
|
||||||
env->features |= (1u << feature);
|
env->features |= (1u << feature);
|
||||||
@ -189,6 +194,7 @@ static void m68k_cpu_class_init(ObjectClass *c, void *data)
|
|||||||
cc->reset = m68k_cpu_reset;
|
cc->reset = m68k_cpu_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->do_interrupt = m68k_cpu_do_interrupt;
|
cc->do_interrupt = m68k_cpu_do_interrupt;
|
||||||
cc->dump_state = m68k_cpu_dump_state;
|
cc->dump_state = m68k_cpu_dump_state;
|
||||||
cc->set_pc = m68k_cpu_set_pc;
|
cc->set_pc = m68k_cpu_set_pc;
|
||||||
|
@ -253,11 +253,6 @@ static inline void cpu_get_tb_cpu_state(CPUM68KState *env, target_ulong *pc,
|
|||||||
| ((env->macsr >> 4) & 0xf); /* Bits 0-3 */
|
| ((env->macsr >> 4) & 0xf); /* Bits 0-3 */
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
return cpu->interrupt_request & CPU_INTERRUPT_HARD;
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -34,6 +34,11 @@ static void mb_cpu_set_pc(CPUState *cs, vaddr value)
|
|||||||
cpu->env.sregs[SR_PC] = value;
|
cpu->env.sregs[SR_PC] = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool mb_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
return cs->interrupt_request & (CPU_INTERRUPT_HARD | CPU_INTERRUPT_NMI);
|
||||||
|
}
|
||||||
|
|
||||||
#ifndef CONFIG_USER_ONLY
|
#ifndef CONFIG_USER_ONLY
|
||||||
static void microblaze_cpu_set_irq(void *opaque, int irq, int level)
|
static void microblaze_cpu_set_irq(void *opaque, int irq, int level)
|
||||||
{
|
{
|
||||||
@ -160,6 +165,7 @@ static void mb_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
mcc->parent_reset = cc->reset;
|
mcc->parent_reset = cc->reset;
|
||||||
cc->reset = mb_cpu_reset;
|
cc->reset = mb_cpu_reset;
|
||||||
|
|
||||||
|
cc->has_work = mb_cpu_has_work;
|
||||||
cc->do_interrupt = mb_cpu_do_interrupt;
|
cc->do_interrupt = mb_cpu_do_interrupt;
|
||||||
cc->dump_state = mb_cpu_dump_state;
|
cc->dump_state = mb_cpu_dump_state;
|
||||||
cc->set_pc = mb_cpu_set_pc;
|
cc->set_pc = mb_cpu_set_pc;
|
||||||
|
@ -363,11 +363,6 @@ void mb_cpu_unassigned_access(CPUState *cpu, hwaddr addr,
|
|||||||
unsigned size);
|
unsigned size);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
return cpu->interrupt_request & (CPU_INTERRUPT_HARD | CPU_INTERRUPT_NMI);
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -45,6 +45,35 @@ static void mips_cpu_synchronize_from_tb(CPUState *cs, TranslationBlock *tb)
|
|||||||
env->hflags |= tb->flags & MIPS_HFLAG_BMASK;
|
env->hflags |= tb->flags & MIPS_HFLAG_BMASK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool mips_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
MIPSCPU *cpu = MIPS_CPU(cs);
|
||||||
|
CPUMIPSState *env = &cpu->env;
|
||||||
|
bool has_work = false;
|
||||||
|
|
||||||
|
/* It is implementation dependent if non-enabled interrupts
|
||||||
|
wake-up the CPU, however most of the implementations only
|
||||||
|
check for interrupts that can be taken. */
|
||||||
|
if ((cs->interrupt_request & CPU_INTERRUPT_HARD) &&
|
||||||
|
cpu_mips_hw_interrupts_pending(env)) {
|
||||||
|
has_work = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* MIPS-MT has the ability to halt the CPU. */
|
||||||
|
if (env->CP0_Config3 & (1 << CP0C3_MT)) {
|
||||||
|
/* The QEMU model will issue an _WAKE request whenever the CPUs
|
||||||
|
should be woken up. */
|
||||||
|
if (cs->interrupt_request & CPU_INTERRUPT_WAKE) {
|
||||||
|
has_work = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!mips_vpe_active(env)) {
|
||||||
|
has_work = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return has_work;
|
||||||
|
}
|
||||||
|
|
||||||
/* CPUClass::reset() */
|
/* CPUClass::reset() */
|
||||||
static void mips_cpu_reset(CPUState *s)
|
static void mips_cpu_reset(CPUState *s)
|
||||||
{
|
{
|
||||||
@ -97,6 +126,7 @@ static void mips_cpu_class_init(ObjectClass *c, void *data)
|
|||||||
mcc->parent_reset = cc->reset;
|
mcc->parent_reset = cc->reset;
|
||||||
cc->reset = mips_cpu_reset;
|
cc->reset = mips_cpu_reset;
|
||||||
|
|
||||||
|
cc->has_work = mips_cpu_has_work;
|
||||||
cc->do_interrupt = mips_cpu_do_interrupt;
|
cc->do_interrupt = mips_cpu_do_interrupt;
|
||||||
cc->dump_state = mips_cpu_dump_state;
|
cc->dump_state = mips_cpu_dump_state;
|
||||||
cc->set_pc = mips_cpu_set_pc;
|
cc->set_pc = mips_cpu_set_pc;
|
||||||
|
@ -715,34 +715,6 @@ static inline int mips_vpe_active(CPUMIPSState *env)
|
|||||||
return active;
|
return active;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
CPUMIPSState *env = &MIPS_CPU(cpu)->env;
|
|
||||||
bool has_work = false;
|
|
||||||
|
|
||||||
/* It is implementation dependent if non-enabled interrupts
|
|
||||||
wake-up the CPU, however most of the implementations only
|
|
||||||
check for interrupts that can be taken. */
|
|
||||||
if ((cpu->interrupt_request & CPU_INTERRUPT_HARD) &&
|
|
||||||
cpu_mips_hw_interrupts_pending(env)) {
|
|
||||||
has_work = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* MIPS-MT has the ability to halt the CPU. */
|
|
||||||
if (env->CP0_Config3 & (1 << CP0C3_MT)) {
|
|
||||||
/* The QEMU model will issue an _WAKE request whenever the CPUs
|
|
||||||
should be woken up. */
|
|
||||||
if (cpu->interrupt_request & CPU_INTERRUPT_WAKE) {
|
|
||||||
has_work = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!mips_vpe_active(env)) {
|
|
||||||
has_work = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return has_work;
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
static inline void compute_hflags(CPUMIPSState *env)
|
static inline void compute_hflags(CPUMIPSState *env)
|
||||||
|
@ -29,6 +29,11 @@ static void moxie_cpu_set_pc(CPUState *cs, vaddr value)
|
|||||||
cpu->env.pc = value;
|
cpu->env.pc = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool moxie_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
return cs->interrupt_request & CPU_INTERRUPT_HARD;
|
||||||
|
}
|
||||||
|
|
||||||
static void moxie_cpu_reset(CPUState *s)
|
static void moxie_cpu_reset(CPUState *s)
|
||||||
{
|
{
|
||||||
MoxieCPU *cpu = MOXIE_CPU(s);
|
MoxieCPU *cpu = MOXIE_CPU(s);
|
||||||
@ -99,6 +104,7 @@ static void moxie_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
|
|
||||||
cc->class_by_name = moxie_cpu_class_by_name;
|
cc->class_by_name = moxie_cpu_class_by_name;
|
||||||
|
|
||||||
|
cc->has_work = moxie_cpu_has_work;
|
||||||
cc->do_interrupt = moxie_cpu_do_interrupt;
|
cc->do_interrupt = moxie_cpu_do_interrupt;
|
||||||
cc->dump_state = moxie_cpu_dump_state;
|
cc->dump_state = moxie_cpu_dump_state;
|
||||||
cc->set_pc = moxie_cpu_set_pc;
|
cc->set_pc = moxie_cpu_set_pc;
|
||||||
|
@ -152,11 +152,6 @@ static inline void cpu_get_tb_cpu_state(CPUMoxieState *env, target_ulong *pc,
|
|||||||
*flags = 0;
|
*flags = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
return cpu->interrupt_request & CPU_INTERRUPT_HARD;
|
|
||||||
}
|
|
||||||
|
|
||||||
int cpu_moxie_handle_mmu_fault(CPUMoxieState *env, target_ulong address,
|
int cpu_moxie_handle_mmu_fault(CPUMoxieState *env, target_ulong address,
|
||||||
int rw, int mmu_idx);
|
int rw, int mmu_idx);
|
||||||
|
|
||||||
|
@ -27,6 +27,12 @@ static void openrisc_cpu_set_pc(CPUState *cs, vaddr value)
|
|||||||
cpu->env.pc = value;
|
cpu->env.pc = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool openrisc_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
return cs->interrupt_request & (CPU_INTERRUPT_HARD |
|
||||||
|
CPU_INTERRUPT_TIMER);
|
||||||
|
}
|
||||||
|
|
||||||
/* CPUClass::reset() */
|
/* CPUClass::reset() */
|
||||||
static void openrisc_cpu_reset(CPUState *s)
|
static void openrisc_cpu_reset(CPUState *s)
|
||||||
{
|
{
|
||||||
@ -153,6 +159,7 @@ static void openrisc_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
cc->reset = openrisc_cpu_reset;
|
cc->reset = openrisc_cpu_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->do_interrupt = openrisc_cpu_do_interrupt;
|
cc->do_interrupt = openrisc_cpu_do_interrupt;
|
||||||
cc->dump_state = openrisc_cpu_dump_state;
|
cc->dump_state = openrisc_cpu_dump_state;
|
||||||
cc->set_pc = openrisc_cpu_set_pc;
|
cc->set_pc = openrisc_cpu_set_pc;
|
||||||
|
@ -419,11 +419,6 @@ static inline int cpu_mmu_index(CPUOpenRISCState *env)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#define CPU_INTERRUPT_TIMER CPU_INTERRUPT_TGT_INT_0
|
#define CPU_INTERRUPT_TIMER CPU_INTERRUPT_TGT_INT_0
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
return cpu->interrupt_request & (CPU_INTERRUPT_HARD |
|
|
||||||
CPU_INTERRUPT_TIMER);
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
|
@ -2171,14 +2171,6 @@ static inline bool msr_is_64bit(CPUPPCState *env, target_ulong msr)
|
|||||||
|
|
||||||
extern void (*cpu_ppc_hypercall)(PowerPCCPU *);
|
extern void (*cpu_ppc_hypercall)(PowerPCCPU *);
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
PowerPCCPU *ppc_cpu = POWERPC_CPU(cpu);
|
|
||||||
CPUPPCState *env = &ppc_cpu->env;
|
|
||||||
|
|
||||||
return msr_ee && (cpu->interrupt_request & CPU_INTERRUPT_HARD);
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
void dump_mmu(FILE *f, fprintf_function cpu_fprintf, CPUPPCState *env);
|
void dump_mmu(FILE *f, fprintf_function cpu_fprintf, CPUPPCState *env);
|
||||||
|
@ -8384,6 +8384,14 @@ static void ppc_cpu_set_pc(CPUState *cs, vaddr value)
|
|||||||
cpu->env.nip = value;
|
cpu->env.nip = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool ppc_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
PowerPCCPU *cpu = POWERPC_CPU(cs);
|
||||||
|
CPUPPCState *env = &cpu->env;
|
||||||
|
|
||||||
|
return msr_ee && (cs->interrupt_request & CPU_INTERRUPT_HARD);
|
||||||
|
}
|
||||||
|
|
||||||
/* CPUClass::reset() */
|
/* CPUClass::reset() */
|
||||||
static void ppc_cpu_reset(CPUState *s)
|
static void ppc_cpu_reset(CPUState *s)
|
||||||
{
|
{
|
||||||
@ -8511,6 +8519,7 @@ static void ppc_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
cc->reset = ppc_cpu_reset;
|
cc->reset = ppc_cpu_reset;
|
||||||
|
|
||||||
cc->class_by_name = ppc_cpu_class_by_name;
|
cc->class_by_name = ppc_cpu_class_by_name;
|
||||||
|
cc->has_work = ppc_cpu_has_work;
|
||||||
cc->do_interrupt = ppc_cpu_do_interrupt;
|
cc->do_interrupt = ppc_cpu_do_interrupt;
|
||||||
cc->dump_state = ppc_cpu_dump_state;
|
cc->dump_state = ppc_cpu_dump_state;
|
||||||
cc->dump_statistics = ppc_cpu_dump_statistics;
|
cc->dump_statistics = ppc_cpu_dump_statistics;
|
||||||
|
@ -65,6 +65,15 @@ static void s390_cpu_set_pc(CPUState *cs, vaddr value)
|
|||||||
cpu->env.psw.addr = value;
|
cpu->env.psw.addr = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool s390_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
S390CPU *cpu = S390_CPU(cs);
|
||||||
|
CPUS390XState *env = &cpu->env;
|
||||||
|
|
||||||
|
return (cs->interrupt_request & CPU_INTERRUPT_HARD) &&
|
||||||
|
(env->psw.mask & PSW_MASK_EXT);
|
||||||
|
}
|
||||||
|
|
||||||
#if !defined(CONFIG_USER_ONLY)
|
#if !defined(CONFIG_USER_ONLY)
|
||||||
/* S390CPUClass::load_normal() */
|
/* S390CPUClass::load_normal() */
|
||||||
static void s390_cpu_load_normal(CPUState *s)
|
static void s390_cpu_load_normal(CPUState *s)
|
||||||
@ -232,6 +241,7 @@ static void s390_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
scc->cpu_reset = s390_cpu_reset;
|
scc->cpu_reset = s390_cpu_reset;
|
||||||
scc->initial_cpu_reset = s390_cpu_initial_reset;
|
scc->initial_cpu_reset = s390_cpu_initial_reset;
|
||||||
cc->reset = s390_cpu_full_reset;
|
cc->reset = s390_cpu_full_reset;
|
||||||
|
cc->has_work = s390_cpu_has_work;
|
||||||
cc->do_interrupt = s390_cpu_do_interrupt;
|
cc->do_interrupt = s390_cpu_do_interrupt;
|
||||||
cc->dump_state = s390_cpu_dump_state;
|
cc->dump_state = s390_cpu_dump_state;
|
||||||
cc->set_pc = s390_cpu_set_pc;
|
cc->set_pc = s390_cpu_set_pc;
|
||||||
|
@ -1041,15 +1041,6 @@ static inline void cpu_inject_crw_mchk(S390CPU *cpu)
|
|||||||
cpu_interrupt(CPU(cpu), CPU_INTERRUPT_HARD);
|
cpu_interrupt(CPU(cpu), CPU_INTERRUPT_HARD);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
S390CPU *s390_cpu = S390_CPU(cpu);
|
|
||||||
CPUS390XState *env = &s390_cpu->env;
|
|
||||||
|
|
||||||
return (cpu->interrupt_request & CPU_INTERRUPT_HARD) &&
|
|
||||||
(env->psw.mask & PSW_MASK_EXT);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* fpu_helper.c */
|
/* fpu_helper.c */
|
||||||
uint32_t set_cc_nz_f32(float32 v);
|
uint32_t set_cc_nz_f32(float32 v);
|
||||||
uint32_t set_cc_nz_f64(float64 v);
|
uint32_t set_cc_nz_f64(float64 v);
|
||||||
|
@ -39,6 +39,11 @@ static void superh_cpu_synchronize_from_tb(CPUState *cs, TranslationBlock *tb)
|
|||||||
cpu->env.flags = tb->flags;
|
cpu->env.flags = tb->flags;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool superh_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
return cs->interrupt_request & CPU_INTERRUPT_HARD;
|
||||||
|
}
|
||||||
|
|
||||||
/* CPUClass::reset() */
|
/* CPUClass::reset() */
|
||||||
static void superh_cpu_reset(CPUState *s)
|
static void superh_cpu_reset(CPUState *s)
|
||||||
{
|
{
|
||||||
@ -280,6 +285,7 @@ static void superh_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
cc->reset = superh_cpu_reset;
|
cc->reset = superh_cpu_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->do_interrupt = superh_cpu_do_interrupt;
|
cc->do_interrupt = superh_cpu_do_interrupt;
|
||||||
cc->dump_state = superh_cpu_dump_state;
|
cc->dump_state = superh_cpu_dump_state;
|
||||||
cc->set_pc = superh_cpu_set_pc;
|
cc->set_pc = superh_cpu_set_pc;
|
||||||
|
@ -352,11 +352,6 @@ static inline void cpu_get_tb_cpu_state(CPUSH4State *env, target_ulong *pc,
|
|||||||
| (env->movcal_backup ? TB_FLAG_PENDING_MOVCA : 0); /* Bit 4 */
|
| (env->movcal_backup ? TB_FLAG_PENDING_MOVCA : 0); /* Bit 4 */
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
return cpu->interrupt_request & CPU_INTERRUPT_HARD;
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
#endif /* _CPU_SH4_H */
|
#endif /* _CPU_SH4_H */
|
||||||
|
@ -739,6 +739,15 @@ static void sparc_cpu_synchronize_from_tb(CPUState *cs, TranslationBlock *tb)
|
|||||||
cpu->env.npc = tb->cs_base;
|
cpu->env.npc = tb->cs_base;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool sparc_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
SPARCCPU *cpu = SPARC_CPU(cs);
|
||||||
|
CPUSPARCState *env = &cpu->env;
|
||||||
|
|
||||||
|
return (cs->interrupt_request & CPU_INTERRUPT_HARD) &&
|
||||||
|
cpu_interrupts_enabled(env);
|
||||||
|
}
|
||||||
|
|
||||||
static void sparc_cpu_realizefn(DeviceState *dev, Error **errp)
|
static void sparc_cpu_realizefn(DeviceState *dev, Error **errp)
|
||||||
{
|
{
|
||||||
SPARCCPUClass *scc = SPARC_CPU_GET_CLASS(dev);
|
SPARCCPUClass *scc = SPARC_CPU_GET_CLASS(dev);
|
||||||
@ -782,6 +791,7 @@ static void sparc_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
scc->parent_reset = cc->reset;
|
scc->parent_reset = cc->reset;
|
||||||
cc->reset = sparc_cpu_reset;
|
cc->reset = sparc_cpu_reset;
|
||||||
|
|
||||||
|
cc->has_work = sparc_cpu_has_work;
|
||||||
cc->do_interrupt = sparc_cpu_do_interrupt;
|
cc->do_interrupt = sparc_cpu_do_interrupt;
|
||||||
cc->dump_state = sparc_cpu_dump_state;
|
cc->dump_state = sparc_cpu_dump_state;
|
||||||
#if !defined(TARGET_SPARC64) && !defined(CONFIG_USER_ONLY)
|
#if !defined(TARGET_SPARC64) && !defined(CONFIG_USER_ONLY)
|
||||||
|
@ -749,15 +749,6 @@ static inline bool tb_am_enabled(int tb_flags)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
SPARCCPU *sparc_cpu = SPARC_CPU(cpu);
|
|
||||||
CPUSPARCState *env1 = &sparc_cpu->env;
|
|
||||||
|
|
||||||
return (cpu->interrupt_request & CPU_INTERRUPT_HARD) &&
|
|
||||||
cpu_interrupts_enabled(env1);
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -23,6 +23,12 @@ static void uc32_cpu_set_pc(CPUState *cs, vaddr value)
|
|||||||
cpu->env.regs[31] = value;
|
cpu->env.regs[31] = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool uc32_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
return cs->interrupt_request &
|
||||||
|
(CPU_INTERRUPT_HARD | CPU_INTERRUPT_EXITTB);
|
||||||
|
}
|
||||||
|
|
||||||
static inline void set_feature(CPUUniCore32State *env, int feature)
|
static inline void set_feature(CPUUniCore32State *env, int feature)
|
||||||
{
|
{
|
||||||
env->features |= feature;
|
env->features |= feature;
|
||||||
@ -138,6 +144,7 @@ static void uc32_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
dc->realize = uc32_cpu_realizefn;
|
dc->realize = uc32_cpu_realizefn;
|
||||||
|
|
||||||
cc->class_by_name = uc32_cpu_class_by_name;
|
cc->class_by_name = uc32_cpu_class_by_name;
|
||||||
|
cc->has_work = uc32_cpu_has_work;
|
||||||
cc->do_interrupt = uc32_cpu_do_interrupt;
|
cc->do_interrupt = uc32_cpu_do_interrupt;
|
||||||
cc->dump_state = uc32_cpu_dump_state;
|
cc->dump_state = uc32_cpu_dump_state;
|
||||||
cc->set_pc = uc32_cpu_set_pc;
|
cc->set_pc = uc32_cpu_set_pc;
|
||||||
|
@ -160,10 +160,4 @@ static inline void cpu_get_tb_cpu_state(CPUUniCore32State *env, target_ulong *pc
|
|||||||
void uc32_translate_init(void);
|
void uc32_translate_init(void);
|
||||||
void switch_mode(CPUUniCore32State *, int);
|
void switch_mode(CPUUniCore32State *, int);
|
||||||
|
|
||||||
static inline bool cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
return cpu->interrupt_request &
|
|
||||||
(CPU_INTERRUPT_HARD | CPU_INTERRUPT_EXITTB);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* QEMU_UNICORE32_CPU_H */
|
#endif /* QEMU_UNICORE32_CPU_H */
|
||||||
|
@ -40,6 +40,13 @@ static void xtensa_cpu_set_pc(CPUState *cs, vaddr value)
|
|||||||
cpu->env.pc = value;
|
cpu->env.pc = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool xtensa_cpu_has_work(CPUState *cs)
|
||||||
|
{
|
||||||
|
XtensaCPU *cpu = XTENSA_CPU(cs);
|
||||||
|
|
||||||
|
return cpu->env.pending_irq_level;
|
||||||
|
}
|
||||||
|
|
||||||
/* CPUClass::reset() */
|
/* CPUClass::reset() */
|
||||||
static void xtensa_cpu_reset(CPUState *s)
|
static void xtensa_cpu_reset(CPUState *s)
|
||||||
{
|
{
|
||||||
@ -134,6 +141,7 @@ static void xtensa_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
cc->reset = xtensa_cpu_reset;
|
cc->reset = xtensa_cpu_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->do_interrupt = xtensa_cpu_do_interrupt;
|
cc->do_interrupt = xtensa_cpu_do_interrupt;
|
||||||
cc->dump_state = xtensa_cpu_dump_state;
|
cc->dump_state = xtensa_cpu_dump_state;
|
||||||
cc->set_pc = xtensa_cpu_set_pc;
|
cc->set_pc = xtensa_cpu_set_pc;
|
||||||
|
@ -525,11 +525,4 @@ static inline void cpu_get_tb_cpu_state(CPUXtensaState *env, target_ulong *pc,
|
|||||||
#include "exec/cpu-all.h"
|
#include "exec/cpu-all.h"
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
|
|
||||||
static inline int cpu_has_work(CPUState *cpu)
|
|
||||||
{
|
|
||||||
CPUXtensaState *env = &XTENSA_CPU(cpu)->env;
|
|
||||||
|
|
||||||
return env->pending_irq_level;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user