diff options
author | Timur Iskhodzhanov <timurrrr@google.com> | 2013-09-23 11:40:58 +0000 |
---|---|---|
committer | Timur Iskhodzhanov <timurrrr@google.com> | 2013-09-23 11:40:58 +0000 |
commit | a8b8e964d7b94cae465df77642465901b1b3079d (patch) | |
tree | fc58114d2365faf74f2fbbce89d573358f44be25 /lib/asan/asan_dll_thunk.cc | |
parent | def895b9ed81b37a99660a2ddfc2c45d229000a4 (diff) | |
download | compiler-rt-a8b8e964d7b94cae465df77642465901b1b3079d.tar.gz compiler-rt-a8b8e964d7b94cae465df77642465901b1b3079d.tar.bz2 compiler-rt-a8b8e964d7b94cae465df77642465901b1b3079d.tar.xz |
[ASan/Win] Slightly optimize the DLL thunk
git-svn-id: https://llvm.org/svn/llvm-project/compiler-rt/trunk@191190 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/asan/asan_dll_thunk.cc')
-rw-r--r-- | lib/asan/asan_dll_thunk.cc | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/lib/asan/asan_dll_thunk.cc b/lib/asan/asan_dll_thunk.cc index 56f271f5..cedd60d3 100644 --- a/lib/asan/asan_dll_thunk.cc +++ b/lib/asan/asan_dll_thunk.cc @@ -38,63 +38,63 @@ static void *getRealProcAddressOrDie(const char *name) { #define WRAP_V_V(name) \ extern "C" void name() { \ typedef void (*fntype)(); \ - fntype fn = (fntype)getRealProcAddressOrDie(#name); \ + static fntype fn = (fntype)getRealProcAddressOrDie(#name); \ fn(); \ } #define WRAP_V_W(name) \ extern "C" void name(void *arg) { \ typedef void (*fntype)(void *arg); \ - fntype fn = (fntype)getRealProcAddressOrDie(#name); \ + static fntype fn = (fntype)getRealProcAddressOrDie(#name); \ fn(arg); \ } #define WRAP_V_WW(name) \ extern "C" void name(void *arg1, void *arg2) { \ typedef void (*fntype)(void *, void *); \ - fntype fn = (fntype)getRealProcAddressOrDie(#name); \ + static fntype fn = (fntype)getRealProcAddressOrDie(#name); \ fn(arg1, arg2); \ } #define WRAP_V_WWW(name) \ extern "C" void name(void *arg1, void *arg2, void *arg3) { \ typedef void *(*fntype)(void *, void *, void *); \ - fntype fn = (fntype)getRealProcAddressOrDie(#name); \ + static fntype fn = (fntype)getRealProcAddressOrDie(#name); \ fn(arg1, arg2, arg3); \ } #define WRAP_W_V(name) \ extern "C" void *name() { \ typedef void *(*fntype)(); \ - fntype fn = (fntype)getRealProcAddressOrDie(#name); \ + static fntype fn = (fntype)getRealProcAddressOrDie(#name); \ return fn(); \ } #define WRAP_W_W(name) \ extern "C" void *name(void *arg) { \ typedef void *(*fntype)(void *arg); \ - fntype fn = (fntype)getRealProcAddressOrDie(#name); \ + static fntype fn = (fntype)getRealProcAddressOrDie(#name); \ return fn(arg); \ } #define WRAP_W_WW(name) \ extern "C" void *name(void *arg1, void *arg2) { \ typedef void *(*fntype)(void *, void *); \ - fntype fn = (fntype)getRealProcAddressOrDie(#name); \ + static fntype fn = (fntype)getRealProcAddressOrDie(#name); \ return fn(arg1, arg2); \ } #define WRAP_W_WWW(name) \ extern "C" void *name(void *arg1, void *arg2, void *arg3) { \ typedef void *(*fntype)(void *, void *, void *); \ - fntype fn = (fntype)getRealProcAddressOrDie(#name); \ + static fntype fn = (fntype)getRealProcAddressOrDie(#name); \ return fn(arg1, arg2, arg3); \ } #define WRAP_W_WWWW(name) \ extern "C" void *name(void *arg1, void *arg2, void *arg3, void *arg4) { \ typedef void *(*fntype)(void *, void *, void *, void *); \ - fntype fn = (fntype)getRealProcAddressOrDie(#name); \ + static fntype fn = (fntype)getRealProcAddressOrDie(#name); \ return fn(arg1, arg2, arg3, arg4); \ } @@ -102,7 +102,7 @@ static void *getRealProcAddressOrDie(const char *name) { extern "C" void *name(void *arg1, void *arg2, void *arg3, void *arg4, \ void *arg5) { \ typedef void *(*fntype)(void *, void *, void *, void *, void *); \ - fntype fn = (fntype)getRealProcAddressOrDie(#name); \ + static fntype fn = (fntype)getRealProcAddressOrDie(#name); \ return fn(arg1, arg2, arg3, arg4, arg5); \ } @@ -110,7 +110,7 @@ static void *getRealProcAddressOrDie(const char *name) { extern "C" void *name(void *arg1, void *arg2, void *arg3, void *arg4, \ void *arg5, void *arg6) { \ typedef void *(*fntype)(void *, void *, void *, void *, void *, void *); \ - fntype fn = (fntype)getRealProcAddressOrDie(#name); \ + static fntype fn = (fntype)getRealProcAddressOrDie(#name); \ return fn(arg1, arg2, arg3, arg4, arg5, arg6); \ } // }}} |