1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- /*
- * Internal execution defines for qemu (target agnostic)
- *
- * Copyright (c) 2003 Fabrice Bellard
- *
- * SPDX-License-Identifier: LGPL-2.1-or-later
- */
- #ifndef ACCEL_TCG_INTERNAL_COMMON_H
- #define ACCEL_TCG_INTERNAL_COMMON_H
- #include "exec/cpu-common.h"
- #include "exec/translation-block.h"
- extern int64_t max_delay;
- extern int64_t max_advance;
- extern bool one_insn_per_tb;
- /*
- * Return true if CS is not running in parallel with other cpus, either
- * because there are no other cpus or we are within an exclusive context.
- */
- static inline bool cpu_in_serial_context(CPUState *cs)
- {
- return !tcg_cflags_has(cs, CF_PARALLEL) || cpu_in_exclusive_context(cs);
- }
- /**
- * cpu_plugin_mem_cbs_enabled() - are plugin memory callbacks enabled?
- * @cs: CPUState pointer
- *
- * The memory callbacks are installed if a plugin has instrumented an
- * instruction for memory. This can be useful to know if you want to
- * force a slow path for a series of memory accesses.
- */
- static inline bool cpu_plugin_mem_cbs_enabled(const CPUState *cpu)
- {
- #ifdef CONFIG_PLUGIN
- return !!cpu->neg.plugin_mem_cbs;
- #else
- return false;
- #endif
- }
- TranslationBlock *tb_gen_code(CPUState *cpu, vaddr pc,
- uint64_t cs_base, uint32_t flags,
- int cflags);
- void page_init(void);
- void tb_htable_init(void);
- void tb_reset_jump(TranslationBlock *tb, int n);
- TranslationBlock *tb_link_page(TranslationBlock *tb);
- void cpu_restore_state_from_tb(CPUState *cpu, TranslationBlock *tb,
- uintptr_t host_pc);
- bool tcg_exec_realizefn(CPUState *cpu, Error **errp);
- void tcg_exec_unrealizefn(CPUState *cpu);
- /* current cflags for hashing/comparison */
- uint32_t curr_cflags(CPUState *cpu);
- #endif
|