aboutsummaryrefslogtreecommitdiff
path: root/target/arm/translate.h
diff options
context:
space:
mode:
authorPeter Maydell <peter.maydell@linaro.org>2019-08-15 09:46:42 +0100
committerPeter Maydell <peter.maydell@linaro.org>2019-08-16 14:02:48 +0100
commitc1d5f50f094ab204accfacc2ee6aafc9601dd5c4 (patch)
treea0e486e6ffc22dc2b2f2b749b26997db416f7cf4 /target/arm/translate.h
parent88e1b59ee30950a66ea28b740914bf603fa9a1ec (diff)
downloadqemu-c1d5f50f094ab204accfacc2ee6aafc9601dd5c4.zip
qemu-c1d5f50f094ab204accfacc2ee6aafc9601dd5c4.tar.gz
qemu-c1d5f50f094ab204accfacc2ee6aafc9601dd5c4.tar.bz2
target/arm: Factor out 'generate singlestep exception' function
Factor out code to 'generate a singlestep exception', which is currently repeated in four places. To do this we need to also pull the identical copies of the gen-exception() function out of translate-a64.c and translate.c into translate.h. (There is a bug in the code: we're taking the exception to the wrong target EL. This will be simpler to fix if there's only one place to do it.) Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Reviewed-by: Alex Bennée <alex.bennee@linaro.org> Message-id: 20190805130952.4415-2-peter.maydell@linaro.org
Diffstat (limited to 'target/arm/translate.h')
-rw-r--r--target/arm/translate.h23
1 files changed, 23 insertions, 0 deletions
diff --git a/target/arm/translate.h b/target/arm/translate.h
index a20f6e2..4505319 100644
--- a/target/arm/translate.h
+++ b/target/arm/translate.h
@@ -2,6 +2,7 @@
#define TARGET_ARM_TRANSLATE_H
#include "exec/translator.h"
+#include "internals.h"
/* internal defines */
@@ -232,6 +233,28 @@ static inline void gen_ss_advance(DisasContext *s)
}
}
+static inline void gen_exception(int excp, uint32_t syndrome,
+ uint32_t target_el)
+{
+ TCGv_i32 tcg_excp = tcg_const_i32(excp);
+ TCGv_i32 tcg_syn = tcg_const_i32(syndrome);
+ TCGv_i32 tcg_el = tcg_const_i32(target_el);
+
+ gen_helper_exception_with_syndrome(cpu_env, tcg_excp,
+ tcg_syn, tcg_el);
+
+ tcg_temp_free_i32(tcg_el);
+ tcg_temp_free_i32(tcg_syn);
+ tcg_temp_free_i32(tcg_excp);
+}
+
+/* Generate an architectural singlestep exception */
+static inline void gen_swstep_exception(DisasContext *s, int isv, int ex)
+{
+ gen_exception(EXCP_UDEF, syn_swstep(s->ss_same_el, isv, ex),
+ default_exception_el(s));
+}
+
/*
* Given a VFP floating point constant encoded into an 8 bit immediate in an
* instruction, expand it to the actual constant value of the specified