aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorRichard Henderson <rth@twiddle.net>2013-09-14 15:57:22 -0700
committerRichard Henderson <rth@twiddle.net>2013-10-10 11:44:25 -0700
commit100b5e0170e86661aaf830869be930a1a201ed08 (patch)
treea3db370b1d116a4abdecc838da63663151aaf300 /include
parentf5daeec412b9624ba902bdba26edff88a1694ea6 (diff)
downloadqemu-100b5e0170e86661aaf830869be930a1a201ed08.zip
qemu-100b5e0170e86661aaf830869be930a1a201ed08.tar.gz
qemu-100b5e0170e86661aaf830869be930a1a201ed08.tar.bz2
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')
-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 022a9ce..73d51f9 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)