diff options
author | Brian Gaeke <gaeke@uiuc.edu> | 2003-09-05 18:42:01 +0000 |
---|---|---|
committer | Brian Gaeke <gaeke@uiuc.edu> | 2003-09-05 18:42:01 +0000 |
commit | 70975eef572b9e132bbaade16ba9edb76f15f287 (patch) | |
tree | edbaec8a92e10f18d1195cdb5d0fc1b59b4520d2 /lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp | |
parent | 5bea411ad288ea6f25ac296ae2d75a4bfab8bf98 (diff) |
Make CreateArgv part of lli rather than part of ExecutionEngine.
Switch Interpreter and JIT's "run" methods to take a Function and a vector of
GenericValues.
Move (almost all of) the stuff that constructs a canonical call to main()
into lli (new methods "callAsMain", "makeStringVector").
Nuke getCurrentExecutablePath(), enableTracing(), getCurrentFunction(),
isStopped(), and many dead decls from interpreter.
Add linux strdup() support to interpreter.
Make interpreter's atexit handler runner and JIT's runAtExitHandlers() look
more alike, in preparation for refactoring.
atexit() is spelled "atexit", not "at_exit".
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@8366 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp')
-rw-r--r-- | lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp | 22 |
1 files changed, 6 insertions, 16 deletions
diff --git a/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp b/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp index d24557abe0..1a28e46d8d 100644 --- a/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp +++ b/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp @@ -29,22 +29,6 @@ static std::map<std::string, ExFunc> FuncNames; static Interpreter *TheInterpreter; -// getCurrentExecutablePath() - Return the directory that the lli executable -// lives in. -// -std::string Interpreter::getCurrentExecutablePath() const { - Dl_info Info; - if (dladdr(&TheInterpreter, &Info) == 0) return ""; - - std::string LinkAddr(Info.dli_fname); - unsigned SlashPos = LinkAddr.rfind('/'); - if (SlashPos != std::string::npos) - LinkAddr.resize(SlashPos); // Trim the executable name off... - - return LinkAddr; -} - - static char getTypeID(const Type *Ty) { switch (Ty->getPrimitiveID()) { case Type::VoidTyID: return 'V'; @@ -498,6 +482,12 @@ GenericValue lle_X_strlen(FunctionType *M, const vector<GenericValue> &Args) { return Ret; } +// char *strdup(const char *src); +GenericValue lle_X_strdup(FunctionType *M, const vector<GenericValue> &Args) { + assert(Args.size() == 1); + return PTOGV(strdup((char*)GVTOP(Args[0]))); +} + // char *__strdup(const char *src); GenericValue lle_X___strdup(FunctionType *M, const vector<GenericValue> &Args) { assert(Args.size() == 1); |