[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH 08/12] target/ppc: Fill in TCGCPUOps.pointer_wrap
From: |
Richard Henderson |
Subject: |
[PATCH 08/12] target/ppc: Fill in TCGCPUOps.pointer_wrap |
Date: |
Sun, 4 May 2025 13:57:09 -0700 |
Check 32 vs 64-bit state.
Cc: qemu-ppc@nongnu.org
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
target/ppc/cpu_init.c | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/target/ppc/cpu_init.c b/target/ppc/cpu_init.c
index cf88a18244..1f18967b62 100644
--- a/target/ppc/cpu_init.c
+++ b/target/ppc/cpu_init.c
@@ -7386,6 +7386,12 @@ static void ppc_cpu_exec_exit(CPUState *cs)
cpu->vhyp_class->cpu_exec_exit(cpu->vhyp, cpu);
}
}
+
+static vaddr ppc_pointer_wrap(CPUState *cs, int mmu_idx,
+ vaddr result, vaddr base)
+{
+ return (cpu_env(cs)->hflags >> HFLAGS_64) & 1 ? result : (uint32_t)result;
+}
#endif /* CONFIG_TCG */
#endif /* !CONFIG_USER_ONLY */
@@ -7490,6 +7496,7 @@ static const TCGCPUOps ppc_tcg_ops = {
.record_sigsegv = ppc_cpu_record_sigsegv,
#else
.tlb_fill = ppc_cpu_tlb_fill,
+ .pointer_wrap = ppc_pointer_wrap,
.cpu_exec_interrupt = ppc_cpu_exec_interrupt,
.cpu_exec_halt = ppc_cpu_has_work,
.cpu_exec_reset = cpu_reset,
--
2.43.0
- [PATCH 00/12] accel/tcg: Fix cross-page pointer wrapping issue, Richard Henderson, 2025/05/04
- [PATCH 02/12] target: Use cpu_pointer_wrap_notreached for strict align targets, Richard Henderson, 2025/05/04
- [PATCH 06/12] target/loongarch: Fill in TCGCPUOps.pointer_wrap, Richard Henderson, 2025/05/04
- [PATCH 04/12] target/arm: Fill in TCGCPUOps.pointer_wrap, Richard Henderson, 2025/05/04
- [PATCH 08/12] target/ppc: Fill in TCGCPUOps.pointer_wrap,
Richard Henderson <=
- [PATCH 01/12] accel/tcg: Add TCGCPUOps.pointer_wrap, Richard Henderson, 2025/05/04
- [PATCH 07/12] target/mips: Fill in TCGCPUOps.pointer_wrap, Richard Henderson, 2025/05/04
- [PATCH 10/12] target/s390x: Fill in TCGCPUOps.pointer_wrap, Richard Henderson, 2025/05/04
- [PATCH 05/12] target/i386: Fill in TCGCPUOps.pointer_wrap, Richard Henderson, 2025/05/04