mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-05 14:35:35 +00:00
tcg: Record code_gen_buffer address for user-only memory helpers
When we handle a signal from a fault within a user-only memory helper, we cannot cpu_restore_state with the PC found within the signal frame. Use a TLS variable, helper_retaddr, to record the unwind start point to find the faulting guest insn. Backports commit ec603b5584fa71213ef8f324fe89e4b27cc9d2bc from qemu
This commit is contained in:
parent
7ec1f12429
commit
f76eb22a46
|
@ -195,6 +195,9 @@ struct uc_struct {
|
||||||
BounceBuffer bounce;
|
BounceBuffer bounce;
|
||||||
CPUState *tcg_current_rr_cpu;
|
CPUState *tcg_current_rr_cpu;
|
||||||
|
|
||||||
|
// qemu/user-exec.c
|
||||||
|
QEMU_THREAD_LOCAL_VAR helper_retaddr;
|
||||||
|
|
||||||
// qemu/memory.c
|
// qemu/memory.c
|
||||||
bool global_dirty_log;
|
bool global_dirty_log;
|
||||||
|
|
||||||
|
|
|
@ -666,6 +666,7 @@ static void *atomic_mmu_lookup(CPUArchState *env, target_ulong addr,
|
||||||
#define ATOMIC_NAME(X) \
|
#define ATOMIC_NAME(X) \
|
||||||
HELPER(glue(glue(glue(atomic_ ## X, SUFFIX), END), _mmu))
|
HELPER(glue(glue(glue(atomic_ ## X, SUFFIX), END), _mmu))
|
||||||
#define ATOMIC_MMU_LOOKUP atomic_mmu_lookup(env, addr, oi, retaddr)
|
#define ATOMIC_MMU_LOOKUP atomic_mmu_lookup(env, addr, oi, retaddr)
|
||||||
|
#define ATOMIC_MMU_CLEANUP do { } while (0)
|
||||||
|
|
||||||
#define DATA_SIZE 1
|
#define DATA_SIZE 1
|
||||||
#include "atomic_template.h"
|
#include "atomic_template.h"
|
||||||
|
|
Loading…
Reference in a new issue