From: Chris Lattner Date: Sun, 5 Dec 2004 07:19:16 +0000 (+0000) Subject: Properly implement a fix for PR475 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=e518b7170b09b20abf2806b2762019db082471d8;p=oota-llvm.git Properly implement a fix for PR475 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@18537 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/ExecutionEngine/JIT/JIT.cpp b/lib/ExecutionEngine/JIT/JIT.cpp index 537ca56e024..2bab9e735b5 100644 --- a/lib/ExecutionEngine/JIT/JIT.cpp +++ b/lib/ExecutionEngine/JIT/JIT.cpp @@ -265,19 +265,6 @@ void *JIT::getPointerToFunction(Function *F) { return Addr; } -// getPointerToFunctionOrStub - If the specified function has been -// code-gen'd, return a pointer to the function. If not, compile it, or use -// a stub to implement lazy compilation if available. -// -void *JIT::getPointerToFunctionOrStub(Function *F) { - // If we have already code generated the function, just return the address. - if (void *Addr = getPointerToGlobalIfAvailable(F)) - return Addr; - - // Otherwise, if the target doesn't support it, just codegen the function. - return getPointerToFunction(F); -} - /// getOrEmitGlobalVariable - Return the address of the specified global /// variable, possibly emitting it to memory if needed. This is used by the /// Emitter. diff --git a/lib/ExecutionEngine/JIT/JITEmitter.cpp b/lib/ExecutionEngine/JIT/JITEmitter.cpp index e5cdc92b754..eff24de89e3 100644 --- a/lib/ExecutionEngine/JIT/JITEmitter.cpp +++ b/lib/ExecutionEngine/JIT/JITEmitter.cpp @@ -208,6 +208,21 @@ void *JITResolver::JITCompilerFn(void *Stub) { } +// getPointerToFunctionOrStub - If the specified function has been +// code-gen'd, return a pointer to the function. If not, compile it, or use +// a stub to implement lazy compilation if available. +// +void *JIT::getPointerToFunctionOrStub(Function *F) { + // If we have already code generated the function, just return the address. + if (void *Addr = getPointerToGlobalIfAvailable(F)) + return Addr; + + // Get a stub if the target supports it + return getJITResolver(MCE).getFunctionStub(F); +} + + + //===----------------------------------------------------------------------===// // JITEmitter code. //