[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 32/52] exec-all: Widen TranslationBlock pc and cs_base to 64-b
|
From: |
Richard Henderson |
|
Subject: |
[PATCH v2 32/52] exec-all: Widen TranslationBlock pc and cs_base to 64-bits |
|
Date: |
Tue, 23 May 2023 06:53:02 -0700 |
This makes TranslationBlock agnostic to the address size of the guest.
Use vaddr for pc, since that's always a virtual address.
Use uint64_t for cs_base, since usage varies between guests.
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
include/exec/exec-all.h | 4 ++--
accel/tcg/cpu-exec.c | 2 +-
2 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/include/exec/exec-all.h b/include/exec/exec-all.h
index 8c8526d9f8..58ac1a91c2 100644
--- a/include/exec/exec-all.h
+++ b/include/exec/exec-all.h
@@ -519,7 +519,7 @@ struct TranslationBlock {
* Unwind information is taken as offsets from the page, to be
* deposited into the "current" PC.
*/
- target_ulong pc;
+ vaddr pc;
/*
* Target-specific data associated with the TranslationBlock, e.g.:
@@ -528,7 +528,7 @@ struct TranslationBlock {
* s390x: instruction data for EXECUTE,
* sparc: the next pc of the instruction queue (for delay slots).
*/
- target_ulong cs_base;
+ uint64_t cs_base;
uint32_t flags; /* flags defining in which context the code was generated
*/
uint32_t cflags; /* compile flags */
diff --git a/accel/tcg/cpu-exec.c b/accel/tcg/cpu-exec.c
index bc0e1c3299..9fe07c31fb 100644
--- a/accel/tcg/cpu-exec.c
+++ b/accel/tcg/cpu-exec.c
@@ -302,7 +302,7 @@ static void log_cpu_exec(target_ulong pc, CPUState *cpu,
{
if (qemu_log_in_addr_range(pc)) {
qemu_log_mask(CPU_LOG_EXEC,
- "Trace %d: %p [" TARGET_FMT_lx
+ "Trace %d: %p [%08" PRIx64
"/" TARGET_FMT_lx "/%08x/%08x] %s\n",
cpu->cpu_index, tb->tc.ptr, tb->cs_base, pc,
tb->flags, tb->cflags, lookup_symbol(pc));
--
2.34.1
- [PATCH v2 21/52] tcg: Pass TCGHelperInfo to tcg_gen_callN, (continued)
- [PATCH v2 21/52] tcg: Pass TCGHelperInfo to tcg_gen_callN, Richard Henderson, 2023/05/23
- [PATCH v2 16/52] tcg: Split tcg/tcg-op-common.h from tcg/tcg-op.h, Richard Henderson, 2023/05/23
- [PATCH v2 25/52] tcg: Split helper-proto.h, Richard Henderson, 2023/05/23
- [PATCH v2 07/52] tcg: Add tlb_fast_offset to TCGContext, Richard Henderson, 2023/05/23
- [PATCH v2 26/52] tcg: Add insn_start_words to TCGContext, Richard Henderson, 2023/05/23
- [PATCH v2 30/52] tcg: Remove NO_CPU_IO_DEFS, Richard Henderson, 2023/05/23
- [PATCH v2 28/52] tcg: Move TLB_FLAGS_MASK check out of get_alignment_bits, Richard Henderson, 2023/05/23
- [PATCH v2 29/52] tcg: Split tcg/tcg-op-gvec.h, Richard Henderson, 2023/05/23
- [PATCH v2 33/52] tcg: Remove DEBUG_DISAS, Richard Henderson, 2023/05/23
- [PATCH v2 32/52] exec-all: Widen TranslationBlock pc and cs_base to 64-bits,
Richard Henderson <=
- [PATCH v2 24/52] tcg: Split helper-gen.h, Richard Henderson, 2023/05/23
- [PATCH v2 36/52] include/exec: Remove CODE_GEN_AVG_BLOCK_SIZE, Richard Henderson, 2023/05/23
- [PATCH v2 31/52] exec-all: Widen tb_page_addr_t for user-only, Richard Henderson, 2023/05/23
- [PATCH v2 37/52] accel/tcg: Move most of gen-icount.h into translator.c, Richard Henderson, 2023/05/23
- [PATCH v2 27/52] tcg: Add guest_mo to TCGContext, Richard Henderson, 2023/05/23
- [PATCH v2 39/52] accel/tcg: Move translator_fake_ldb out of line, Richard Henderson, 2023/05/23
- [PATCH v2 38/52] accel/tcg: Introduce translator_io_start, Richard Henderson, 2023/05/23
- [PATCH v2 34/52] tcg: Remove USE_TCG_OPTIMIZATIONS, Richard Henderson, 2023/05/23