diff options
author | aliguori <aliguori@c046a42c-6fe2-441c-8c8c-71466251a162> | 2008-11-18 19:46:41 +0000 |
---|---|---|
committer | aliguori <aliguori@c046a42c-6fe2-441c-8c8c-71466251a162> | 2008-11-18 19:46:41 +0000 |
commit | 6b9175478e9ad8ef2a9569fd8e2a83440747aae5 (patch) | |
tree | 2436af3fe2b5a72150f728c5b5940768e45ecd0e /target-m68k/cpu.h | |
parent | 622ed3605bf4caa5d52b407081ceb6ecce752aec (diff) | |
download | qemu-6b9175478e9ad8ef2a9569fd8e2a83440747aae5.zip qemu-6b9175478e9ad8ef2a9569fd8e2a83440747aae5.tar.gz qemu-6b9175478e9ad8ef2a9569fd8e2a83440747aae5.tar.bz2 |
Refactor translation block CPU state handling (Jan Kiszka)
This patch refactors the way the CPU state is handled that is associated
with a TB. The basic motivation is to move more arch specific code out
of generic files. Specifically the long #ifdef clutter in tb_find_fast()
has to be overcome in order to avoid duplicating it for the gdb
watchpoint fixes (patch "Restore pc on watchpoint hits").
Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@5736 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'target-m68k/cpu.h')
-rw-r--r-- | target-m68k/cpu.h | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/target-m68k/cpu.h b/target-m68k/cpu.h index 48c752c..bdef9b8 100644 --- a/target-m68k/cpu.h +++ b/target-m68k/cpu.h @@ -239,4 +239,14 @@ static inline void cpu_pc_from_tb(CPUState *env, TranslationBlock *tb) env->pc = tb->pc; } +static inline void cpu_get_tb_cpu_state(CPUState *env, target_ulong *pc, + target_ulong *cs_base, int *flags) +{ + *pc = env->pc; + *cs_base = 0; + *flags = (env->fpcr & M68K_FPCR_PREC) /* Bit 6 */ + | (env->sr & SR_S) /* Bit 13 */ + | ((env->macsr >> 4) & 0xf); /* Bits 0-3 */ +} + #endif |