[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v5 27/43] tcg/ppc: Use tcg_tbrel_diff
From: |
Richard Henderson |
Subject: |
[PATCH v5 27/43] tcg/ppc: Use tcg_tbrel_diff |
Date: |
Tue, 5 Jan 2021 07:19:34 -1000 |
Use tcg_tbrel_diff when we need a displacement to a label,
and with a NULL argument when we need the normalizing addend.
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
tcg/ppc/tcg-target.c.inc | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/tcg/ppc/tcg-target.c.inc b/tcg/ppc/tcg-target.c.inc
index 0eb9c4ebe2..ed7a201578 100644
--- a/tcg/ppc/tcg-target.c.inc
+++ b/tcg/ppc/tcg-target.c.inc
@@ -837,7 +837,7 @@ static void tcg_out_movi_int(TCGContext *s, TCGType type,
TCGReg ret,
}
/* Load addresses within the TB with one insn. */
- tb_diff = arg - (intptr_t)s->code_gen_ptr;
+ tb_diff = tcg_tbrel_diff(s, (void *)arg);
if (!in_prologue && USE_REG_TB && tb_diff == (int16_t)tb_diff) {
tcg_out32(s, ADDI | TAI(ret, TCG_REG_TB, tb_diff));
return;
@@ -890,7 +890,7 @@ static void tcg_out_movi_int(TCGContext *s, TCGType type,
TCGReg ret,
/* Use the constant pool, if possible. */
if (!in_prologue && USE_REG_TB) {
new_pool_label(s, arg, R_PPC_ADDR16, s->code_ptr,
- -(intptr_t)s->code_gen_ptr);
+ tcg_tbrel_diff(s, NULL));
tcg_out32(s, LD | TAI(ret, TCG_REG_TB, 0));
return;
}
@@ -940,7 +940,7 @@ static void tcg_out_dupi_vec(TCGContext *s, TCGType type,
TCGReg ret,
*/
if (USE_REG_TB) {
rel = R_PPC_ADDR16;
- add = -(intptr_t)s->code_gen_ptr;
+ add = tcg_tbrel_diff(s, NULL);
} else {
rel = R_PPC_ADDR32;
add = 0;
--
2.25.1
- Re: [PATCH v5 17/43] tcg: Add --accel tcg,split-wx property, (continued)
- [PATCH v5 19/43] accel/tcg: Support split-wx for darwin/iOS with vm_remap, Richard Henderson, 2021/01/05
- [PATCH v5 24/43] disas: Push const down through host disassembly, Richard Henderson, 2021/01/05
- [PATCH v5 23/43] tcg/aarch64: Support split-wx code generation, Richard Henderson, 2021/01/05
- [PATCH v5 25/43] tcg/tci: Push const down through bytecode reading, Richard Henderson, 2021/01/05
- [PATCH v5 28/43] tcg/ppc: Use tcg_out_mem_long to reset TCG_REG_TB, Richard Henderson, 2021/01/05
- [PATCH v5 18/43] accel/tcg: Support split-wx for linux with memfd, Richard Henderson, 2021/01/05
- [PATCH v5 22/43] tcg/aarch64: Use B not BL for tcg_out_goto_long, Richard Henderson, 2021/01/05
- [PATCH v5 26/43] tcg: Introduce tcg_tbrel_diff, Richard Henderson, 2021/01/05
- [PATCH v5 27/43] tcg/ppc: Use tcg_tbrel_diff,
Richard Henderson <=
- [PATCH v5 29/43] tcg/ppc: Support split-wx code generation, Richard Henderson, 2021/01/05
- [PATCH v5 30/43] tcg/sparc: Use tcg_tbrel_diff, Richard Henderson, 2021/01/05
- [PATCH v5 33/43] tcg/s390: Support split-wx code generation, Richard Henderson, 2021/01/05
- [PATCH v5 34/43] tcg/riscv: Fix branch range checks, Richard Henderson, 2021/01/05
- [PATCH v5 37/43] accel/tcg: Add mips support to alloc_code_gen_buffer_splitwx_memfd, Richard Henderson, 2021/01/05
- [PATCH v5 35/43] tcg/riscv: Remove branch-over-branch fallback, Richard Henderson, 2021/01/05
- [PATCH v5 31/43] tcg/sparc: Support split-wx code generation, Richard Henderson, 2021/01/05
- [PATCH v5 32/43] tcg/s390: Use tcg_tbrel_diff, Richard Henderson, 2021/01/05
- [PATCH v5 36/43] tcg/riscv: Support split-wx code generation, Richard Henderson, 2021/01/05
- [PATCH v5 39/43] tcg/mips: Support split-wx code generation, Richard Henderson, 2021/01/05