mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-06 01:03:55 -06:00
tcg: Add TCG_OPF_BB_EXIT
Use this to notice the opcodes that exit the TB, which implies that local temps are really dead and need not be synced. Previously we so marked the true end of the TB, but that was immediately overwritten by the la_bb_end invoked by any TCG_OPF_BB_END opcode, like exit_tb. Reviewed-by: Emilio G. Cota <cota@braap.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
f65a061c39
commit
ae36a246ed
3 changed files with 16 additions and 10 deletions
14
tcg/tcg.h
14
tcg/tcg.h
|
@ -1030,20 +1030,22 @@ typedef struct TCGArgConstraint {
|
|||
|
||||
/* Bits for TCGOpDef->flags, 8 bits available. */
|
||||
enum {
|
||||
/* Instruction exits the translation block. */
|
||||
TCG_OPF_BB_EXIT = 0x01,
|
||||
/* Instruction defines the end of a basic block. */
|
||||
TCG_OPF_BB_END = 0x01,
|
||||
TCG_OPF_BB_END = 0x02,
|
||||
/* Instruction clobbers call registers and potentially update globals. */
|
||||
TCG_OPF_CALL_CLOBBER = 0x02,
|
||||
TCG_OPF_CALL_CLOBBER = 0x04,
|
||||
/* Instruction has side effects: it cannot be removed if its outputs
|
||||
are not used, and might trigger exceptions. */
|
||||
TCG_OPF_SIDE_EFFECTS = 0x04,
|
||||
TCG_OPF_SIDE_EFFECTS = 0x08,
|
||||
/* Instruction operands are 64-bits (otherwise 32-bits). */
|
||||
TCG_OPF_64BIT = 0x08,
|
||||
TCG_OPF_64BIT = 0x10,
|
||||
/* Instruction is optional and not implemented by the host, or insn
|
||||
is generic and should not be implemened by the host. */
|
||||
TCG_OPF_NOT_PRESENT = 0x10,
|
||||
TCG_OPF_NOT_PRESENT = 0x20,
|
||||
/* Instruction operands are vectors. */
|
||||
TCG_OPF_VECTOR = 0x20,
|
||||
TCG_OPF_VECTOR = 0x40,
|
||||
};
|
||||
|
||||
typedef struct TCGOpDef {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue