diff options
author | Richard Henderson | 2013-09-15 00:57:22 +0200 |
---|---|---|
committer | Richard Henderson | 2013-10-10 20:44:25 +0200 |
commit | 100b5e0170e86661aaf830869be930a1a201ed08 (patch) | |
tree | a3db370b1d116a4abdecc838da63663151aaf300 /include/exec/def-helper.h | |
parent | tcg: Remove stray semi-colons from target-*/helper.h (diff) | |
download | qemu-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.h | 3 |
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) |