aboutsummaryrefslogtreecommitdiff
path: root/include/exec
diff options
context:
space:
mode:
authorJani Kokkonen <Jani.Kokkonen@huawei.com>2013-07-10 17:02:00 +0200
committerClaudio Fontana <claudio.fontana@huawei.com>2013-07-15 13:13:46 +0200
commitc6d8ed24b446b1f1e07af87cde54317f54a1d42e (patch)
tree7d7d63b884a996bbac6dc76992345b827a781554 /include/exec
parentb1f6dc0d2a03f0e114cc5ff08b0a133e24fd55ad (diff)
downloadqemu-c6d8ed24b446b1f1e07af87cde54317f54a1d42e.zip
qemu-c6d8ed24b446b1f1e07af87cde54317f54a1d42e.tar.gz
qemu-c6d8ed24b446b1f1e07af87cde54317f54a1d42e.tar.bz2
tcg/aarch64: Implement tlb lookup fast path
Supports CONFIG_QEMU_LDST_OPTIMIZATION Signed-off-by: Jani Kokkonen <jani.kokkonen@huawei.com> Reviewed-by: Richard Henderson <rth@twiddle.net> Reviewed-by: Claudio Fontana <claudio.fontana@huawei.com>
Diffstat (limited to 'include/exec')
-rw-r--r--include/exec/exec-all.h14
1 files changed, 14 insertions, 0 deletions
diff --git a/include/exec/exec-all.h b/include/exec/exec-all.h
index b2162a4..5920f73 100644
--- a/include/exec/exec-all.h
+++ b/include/exec/exec-all.h
@@ -358,6 +358,20 @@ static inline uintptr_t tcg_getpc_ldst(uintptr_t ra)
not the start of the next opcode */
return ra;
}
+#elif defined(__aarch64__)
+# define GETRA() ((uintptr_t)__builtin_return_address(0))
+# define GETPC_LDST() tcg_getpc_ldst(GETRA())
+static inline uintptr_t tcg_getpc_ldst(uintptr_t ra)
+{
+ int32_t b;
+ ra += 4; /* skip one instruction */
+ b = *(int32_t *)ra; /* load the branch insn */
+ b = (b << 6) >> (6 - 2); /* extract the displacement */
+ ra += b; /* apply the displacement */
+ ra -= 4; /* return a pointer into the current opcode,
+ not the start of the next opcode */
+ return ra;
+}
# else
# error "CONFIG_QEMU_LDST_OPTIMIZATION needs GETPC_LDST() implementation!"
# endif