[llvm] r241983 - Revert "[ExecutionEngine] Use std::function rather than a function pointer for the LazyFunctionCreator."
Renato Golin
renato.golin at linaro.org
Sat Jul 11 06:42:48 PDT 2015
Author: rengolin
Date: Sat Jul 11 08:42:48 2015
New Revision: 241983
URL: http://llvm.org/viewvc/llvm-project?rev=241983&view=rev
Log:
Revert "[ExecutionEngine] Use std::function rather than a function pointer for the LazyFunctionCreator."
This reverts commit r241962, as it was breaking all ARM buildbots.
It also reverts the two subsequent related commits:
r241974: "[ExecutionEngine] Add a static cast to the unittest for r241962 to suppress a warning."
r241973: "[ExecutionEngine] Remove cruft and fix a couple of warnings in the test case for r241962."
Modified:
llvm/trunk/include/llvm/ExecutionEngine/ExecutionEngine.h
llvm/trunk/unittests/ExecutionEngine/MCJIT/MCJITTest.cpp
Modified: llvm/trunk/include/llvm/ExecutionEngine/ExecutionEngine.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/ExecutionEngine/ExecutionEngine.h?rev=241983&r1=241982&r2=241983&view=diff
==============================================================================
--- llvm/trunk/include/llvm/ExecutionEngine/ExecutionEngine.h (original)
+++ llvm/trunk/include/llvm/ExecutionEngine/ExecutionEngine.h Sat Jul 11 08:42:48 2015
@@ -31,7 +31,6 @@
#include <map>
#include <string>
#include <vector>
-#include <functional>
namespace llvm {
@@ -90,8 +89,6 @@ public:
uint64_t RemoveMapping(StringRef Name);
};
-using FunctionCreator = std::function<void *(const std::string &)>;
-
/// \brief Abstract interface for implementation execution of LLVM modules,
/// designed to support both interpreter and just-in-time (JIT) compiler
/// implementations.
@@ -150,7 +147,7 @@ protected:
/// LazyFunctionCreator - If an unknown function is needed, this function
/// pointer is invoked to create it. If this returns null, the JIT will
/// abort.
- FunctionCreator LazyFunctionCreator;
+ void *(*LazyFunctionCreator)(const std::string &);
/// getMangledName - Get mangled name.
std::string getMangledName(const GlobalValue *GV);
@@ -473,8 +470,8 @@ public:
/// InstallLazyFunctionCreator - If an unknown function is needed, the
/// specified function pointer is invoked to create it. If it returns null,
/// the JIT will abort.
- void InstallLazyFunctionCreator(FunctionCreator C) {
- LazyFunctionCreator = C;
+ void InstallLazyFunctionCreator(void* (*P)(const std::string &)) {
+ LazyFunctionCreator = P;
}
protected:
Modified: llvm/trunk/unittests/ExecutionEngine/MCJIT/MCJITTest.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/unittests/ExecutionEngine/MCJIT/MCJITTest.cpp?rev=241983&r1=241982&r2=241983&view=diff
==============================================================================
--- llvm/trunk/unittests/ExecutionEngine/MCJIT/MCJITTest.cpp (original)
+++ llvm/trunk/unittests/ExecutionEngine/MCJIT/MCJITTest.cpp Sat Jul 11 08:42:48 2015
@@ -199,68 +199,4 @@ TEST_F(MCJITTest, multiple_decl_lookups)
EXPECT_EQ(A, B) << "Repeat calls to getPointerToFunction fail.";
}
-typedef void * (*FunctionHandlerPtr)(const std::string &str);
-
-TEST_F(MCJITTest, lazy_function_creator_pointer) {
- SKIP_UNSUPPORTED_PLATFORM;
-
- Function *Foo = insertExternalReferenceToFunction<int32_t(void)>(M.get(),
- "\1Foo");
- startFunction<int32_t(void)>(M.get(), "Parent");
- CallInst *Call = Builder.CreateCall(Foo, {});
- Builder.CreateRet(Call);
-
- createJIT(std::move(M));
-
- // Set up the lazy function creator that records the name of the last
- // unresolved external function found in the module. Using a function pointer
- // prevents us from capturing local variables, which is why this is static.
- static std::string UnresolvedExternal;
- FunctionHandlerPtr UnresolvedHandler = [] (const std::string &str) {
- UnresolvedExternal = str;
- return (void *)(uintptr_t)-1;
- };
- TheJIT->InstallLazyFunctionCreator(UnresolvedHandler);
-
- // JIT the module.
- TheJIT->finalizeObject();
-
- // Verify that our handler was called.
- EXPECT_EQ(UnresolvedExternal, "Foo");
-}
-
-TEST_F(MCJITTest, lazy_function_creator_lambda) {
- SKIP_UNSUPPORTED_PLATFORM;
-
- Function *Foo1 = insertExternalReferenceToFunction<int32_t(void)>(M.get(),
- "\1Foo1");
- Function *Foo2 = insertExternalReferenceToFunction<int32_t(void)>(M.get(),
- "\1Foo2");
- startFunction<int32_t(void)>(M.get(), "Parent");
- CallInst *Call1 = Builder.CreateCall(Foo1, {});
- CallInst *Call2 = Builder.CreateCall(Foo2, {});
- Value *Result = Builder.CreateAdd(Call1, Call2);
- Builder.CreateRet(Result);
-
- createJIT(std::move(M));
-
- // Set up the lazy function creator that records the name of unresolved
- // external functions in the module.
- std::vector<std::string> UnresolvedExternals;
- auto UnresolvedHandler = [&UnresolvedExternals] (const std::string &str) {
- UnresolvedExternals.push_back(str);
- return (void *)(uintptr_t)-1;
- };
- TheJIT->InstallLazyFunctionCreator(UnresolvedHandler);
-
- // JIT the module.
- TheJIT->finalizeObject();
-
- // Verify that our handler was called for each unresolved function.
- auto I = UnresolvedExternals.begin(), E = UnresolvedExternals.end();
- EXPECT_EQ(UnresolvedExternals.size(), static_cast<size_t>(2));
- EXPECT_FALSE(std::find(I, E, "Foo1") == E);
- EXPECT_FALSE(std::find(I, E, "Foo2") == E);
-}
-
}
More information about the llvm-commits
mailing list