internal-common.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. /*
  2. * Internal execution defines for qemu (target agnostic)
  3. *
  4. * Copyright (c) 2003 Fabrice Bellard
  5. *
  6. * SPDX-License-Identifier: LGPL-2.1-or-later
  7. */
  8. #ifndef ACCEL_TCG_INTERNAL_COMMON_H
  9. #define ACCEL_TCG_INTERNAL_COMMON_H
  10. #include "exec/cpu-common.h"
  11. #include "exec/translation-block.h"
  12. extern int64_t max_delay;
  13. extern int64_t max_advance;
  14. extern bool one_insn_per_tb;
  15. /*
  16. * Return true if CS is not running in parallel with other cpus, either
  17. * because there are no other cpus or we are within an exclusive context.
  18. */
  19. static inline bool cpu_in_serial_context(CPUState *cs)
  20. {
  21. return !tcg_cflags_has(cs, CF_PARALLEL) || cpu_in_exclusive_context(cs);
  22. }
  23. /**
  24. * cpu_plugin_mem_cbs_enabled() - are plugin memory callbacks enabled?
  25. * @cs: CPUState pointer
  26. *
  27. * The memory callbacks are installed if a plugin has instrumented an
  28. * instruction for memory. This can be useful to know if you want to
  29. * force a slow path for a series of memory accesses.
  30. */
  31. static inline bool cpu_plugin_mem_cbs_enabled(const CPUState *cpu)
  32. {
  33. #ifdef CONFIG_PLUGIN
  34. return !!cpu->neg.plugin_mem_cbs;
  35. #else
  36. return false;
  37. #endif
  38. }
  39. TranslationBlock *tb_gen_code(CPUState *cpu, vaddr pc,
  40. uint64_t cs_base, uint32_t flags,
  41. int cflags);
  42. void page_init(void);
  43. void tb_htable_init(void);
  44. void tb_reset_jump(TranslationBlock *tb, int n);
  45. TranslationBlock *tb_link_page(TranslationBlock *tb);
  46. void cpu_restore_state_from_tb(CPUState *cpu, TranslationBlock *tb,
  47. uintptr_t host_pc);
  48. bool tcg_exec_realizefn(CPUState *cpu, Error **errp);
  49. void tcg_exec_unrealizefn(CPUState *cpu);
  50. /* current cflags for hashing/comparison */
  51. uint32_t curr_cflags(CPUState *cpu);
  52. #endif