mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-07-29 13:23:54 -06:00
accel/tcg: Declare cpu_loop_exit_requested() in 'exec/cpu-common.h'
Move cpu_loop_exit_requested() declaration to "exec/cpu-common.h", along with the related cpu_loop_exit_noexc(), cpu_loop_exit(), cpu_loop_exit_atomic() and cpu_loop_exit_restore() methods. Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Alex Bennée <alex.bennee@linaro.org> Message-Id: <20241217140648.98538-1-philmd@linaro.org>
This commit is contained in:
parent
5c09d295e0
commit
47f7b6441a
5 changed files with 21 additions and 18 deletions
|
@ -25,7 +25,7 @@
|
||||||
#include "hw/core/tcg-cpu-ops.h"
|
#include "hw/core/tcg-cpu-ops.h"
|
||||||
#include "trace.h"
|
#include "trace.h"
|
||||||
#include "disas/disas.h"
|
#include "disas/disas.h"
|
||||||
#include "exec/exec-all.h"
|
#include "exec/cpu-common.h"
|
||||||
#include "exec/page-protection.h"
|
#include "exec/page-protection.h"
|
||||||
#include "tcg/tcg.h"
|
#include "tcg/tcg.h"
|
||||||
#include "qemu/atomic.h"
|
#include "qemu/atomic.h"
|
||||||
|
|
|
@ -186,6 +186,7 @@ int cpu_memory_rw_debug(CPUState *cpu, vaddr addr,
|
||||||
void list_cpus(void);
|
void list_cpus(void);
|
||||||
|
|
||||||
#ifdef CONFIG_TCG
|
#ifdef CONFIG_TCG
|
||||||
|
#include "qemu/atomic.h"
|
||||||
|
|
||||||
bool tcg_cflags_has(CPUState *cpu, uint32_t flags);
|
bool tcg_cflags_has(CPUState *cpu, uint32_t flags);
|
||||||
void tcg_cflags_set(CPUState *cpu, uint32_t flags);
|
void tcg_cflags_set(CPUState *cpu, uint32_t flags);
|
||||||
|
@ -218,6 +219,23 @@ bool cpu_unwind_state_data(CPUState *cpu, uintptr_t host_pc, uint64_t *data);
|
||||||
*/
|
*/
|
||||||
bool cpu_restore_state(CPUState *cpu, uintptr_t host_pc);
|
bool cpu_restore_state(CPUState *cpu, uintptr_t host_pc);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* cpu_loop_exit_requested:
|
||||||
|
* @cpu: The CPU state to be tested
|
||||||
|
*
|
||||||
|
* Indicate if somebody asked for a return of the CPU to the main loop
|
||||||
|
* (e.g., via cpu_exit() or cpu_interrupt()).
|
||||||
|
*
|
||||||
|
* This is helpful for architectures that support interruptible
|
||||||
|
* instructions. After writing back all state to registers/memory, this
|
||||||
|
* call can be used to check if it makes sense to return to the main loop
|
||||||
|
* or to continue executing the interruptible instruction.
|
||||||
|
*/
|
||||||
|
static inline bool cpu_loop_exit_requested(CPUState *cpu)
|
||||||
|
{
|
||||||
|
return (int32_t)qatomic_read(&cpu->neg.icount_decr.u32) < 0;
|
||||||
|
}
|
||||||
|
|
||||||
G_NORETURN void cpu_loop_exit_noexc(CPUState *cpu);
|
G_NORETURN void cpu_loop_exit_noexc(CPUState *cpu);
|
||||||
G_NORETURN void cpu_loop_exit_atomic(CPUState *cpu, uintptr_t pc);
|
G_NORETURN void cpu_loop_exit_atomic(CPUState *cpu, uintptr_t pc);
|
||||||
#endif /* CONFIG_TCG */
|
#endif /* CONFIG_TCG */
|
||||||
|
|
|
@ -27,23 +27,6 @@
|
||||||
#include "exec/mmu-access-type.h"
|
#include "exec/mmu-access-type.h"
|
||||||
#include "exec/translation-block.h"
|
#include "exec/translation-block.h"
|
||||||
|
|
||||||
/**
|
|
||||||
* cpu_loop_exit_requested:
|
|
||||||
* @cpu: The CPU state to be tested
|
|
||||||
*
|
|
||||||
* Indicate if somebody asked for a return of the CPU to the main loop
|
|
||||||
* (e.g., via cpu_exit() or cpu_interrupt()).
|
|
||||||
*
|
|
||||||
* This is helpful for architectures that support interruptible
|
|
||||||
* instructions. After writing back all state to registers/memory, this
|
|
||||||
* call can be used to check if it makes sense to return to the main loop
|
|
||||||
* or to continue executing the interruptible instruction.
|
|
||||||
*/
|
|
||||||
static inline bool cpu_loop_exit_requested(CPUState *cpu)
|
|
||||||
{
|
|
||||||
return (int32_t)qatomic_read(&cpu->neg.icount_decr.u32) < 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if !defined(CONFIG_USER_ONLY) && defined(CONFIG_TCG)
|
#if !defined(CONFIG_USER_ONLY) && defined(CONFIG_TCG)
|
||||||
/* cputlb.c */
|
/* cputlb.c */
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
#include "qemu/bitops.h"
|
#include "qemu/bitops.h"
|
||||||
#include "internals.h"
|
#include "internals.h"
|
||||||
#include "qemu/crc32c.h"
|
#include "qemu/crc32c.h"
|
||||||
|
#include "exec/cpu-common.h"
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
#include "exec/cpu_ldst.h"
|
#include "exec/cpu_ldst.h"
|
||||||
#include "qemu/int128.h"
|
#include "qemu/int128.h"
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
#include "s390x-internal.h"
|
#include "s390x-internal.h"
|
||||||
#include "tcg_s390x.h"
|
#include "tcg_s390x.h"
|
||||||
#include "exec/helper-proto.h"
|
#include "exec/helper-proto.h"
|
||||||
|
#include "exec/cpu-common.h"
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
#include "exec/page-protection.h"
|
#include "exec/page-protection.h"
|
||||||
#include "exec/cpu_ldst.h"
|
#include "exec/cpu_ldst.h"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue