summaryrefslogtreecommitdiffstats
path: root/include/exec/def-helper.h
diff options
context:
space:
mode:
authorRichard Henderson2013-09-15 00:57:22 +0200
committerRichard Henderson2013-10-10 20:44:25 +0200
commit100b5e0170e86661aaf830869be930a1a201ed08 (patch)
treea3db370b1d116a4abdecc838da63663151aaf300 /include/exec/def-helper.h
parenttcg: Remove stray semi-colons from target-*/helper.h (diff)
downloadqemu-100b5e0170e86661aaf830869be930a1a201ed08.tar.gz
qemu-100b5e0170e86661aaf830869be930a1a201ed08.tar.xz
qemu-100b5e0170e86661aaf830869be930a1a201ed08.zip
tcg: Put target helper data into an array.
One call inside of a loop to tcg_register_helper instead of hundreds of sequential calls. Presumably more icache and branch prediction friendly; resulting binary size mostly unchanged on x86_64, as we're trading 32-bit rip-relative references in .text for full 64-bit pointers in .rodata. Signed-off-by: Richard Henderson <rth@twiddle.net>
Diffstat (limited to 'include/exec/def-helper.h')
-rw-r--r--include/exec/def-helper.h3
1 files changed, 1 insertions, 2 deletions
diff --git a/include/exec/def-helper.h b/include/exec/def-helper.h
index 022a9ceb6a..73d51f9cf5 100644
--- a/include/exec/def-helper.h
+++ b/include/exec/def-helper.h
@@ -240,8 +240,7 @@ static inline void glue(gen_helper_, name)(dh_retvar_decl(ret) \
#elif GEN_HELPER == 2
/* Register helpers. */
-#define DEF_HELPER_FLAGS_0(name, flags, ret) \
-tcg_register_helper(HELPER(name), #name);
+#define DEF_HELPER_FLAGS_0(name, flags, ret) { HELPER(name), #name },
#define DEF_HELPER_FLAGS_1(name, flags, ret, t1) \
DEF_HELPER_FLAGS_0(name, flags, ret)