mirror of
https://github.com/mii443/qemu.git
synced 2025-12-03 11:08:25 +00:00
tcg/tci: Reuse tci_args_l for goto_tb
Convert to indirect jumps, as it's less complicated. Then we just have a pointer to the tb address at which the chain is stored, from which we read. Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
@@ -818,13 +818,11 @@ uintptr_t QEMU_DISABLE_CFI tcg_qemu_tb_exec(CPUArchState *env,
|
||||
return (uintptr_t)ptr;
|
||||
|
||||
case INDEX_op_goto_tb:
|
||||
/* Jump address is aligned */
|
||||
tb_ptr = QEMU_ALIGN_PTR_UP(tb_ptr, 4);
|
||||
t0 = qatomic_read((int32_t *)tb_ptr);
|
||||
tb_ptr += sizeof(int32_t);
|
||||
tci_args_l(&tb_ptr, &ptr);
|
||||
tci_assert(tb_ptr == old_code_ptr + op_size);
|
||||
tb_ptr += (int32_t)t0;
|
||||
tb_ptr = *(void **)ptr;
|
||||
continue;
|
||||
|
||||
case INDEX_op_qemu_ld_i32:
|
||||
t0 = *tb_ptr++;
|
||||
taddr = tci_read_ulong(regs, &tb_ptr);
|
||||
|
||||
Reference in New Issue
Block a user