diff options
Diffstat (limited to 'lib/ExecutionEngine/ExecutionEngine.cpp')
-rw-r--r-- | lib/ExecutionEngine/ExecutionEngine.cpp | 50 |
1 files changed, 33 insertions, 17 deletions
diff --git a/lib/ExecutionEngine/ExecutionEngine.cpp b/lib/ExecutionEngine/ExecutionEngine.cpp index a6f71266d7..dcfbde4985 100644 --- a/lib/ExecutionEngine/ExecutionEngine.cpp +++ b/lib/ExecutionEngine/ExecutionEngine.cpp @@ -193,26 +193,42 @@ void ExecutionEngine::InitializeMemory(const Constant *Init, void *Addr) { void *ExecutionEngine::CreateArgv(const std::vector<std::string> &InputArgv) { - // Pointers are 64 bits... - // FIXME: Assumes 64 bit target - PointerTy *Result = new PointerTy[InputArgv.size()+1]; - DEBUG(std::cerr << "ARGV = " << (void*)Result << "\n"); - - for (unsigned i = 0; i < InputArgv.size(); ++i) { - unsigned Size = InputArgv[i].size()+1; - char *Dest = new char[Size]; - DEBUG(std::cerr << "ARGV[" << i << "] = " << (void*)Dest << "\n"); + if (getTargetData().getPointerSize() == 8) { // 64 bit target? + PointerTy *Result = new PointerTy[InputArgv.size()+1]; + DEBUG(std::cerr << "ARGV = " << (void*)Result << "\n"); + + for (unsigned i = 0; i < InputArgv.size(); ++i) { + unsigned Size = InputArgv[i].size()+1; + char *Dest = new char[Size]; + DEBUG(std::cerr << "ARGV[" << i << "] = " << (void*)Dest << "\n"); + + copy(InputArgv[i].begin(), InputArgv[i].end(), Dest); + Dest[Size-1] = 0; + + // Endian safe: Result[i] = (PointerTy)Dest; + StoreValueToMemory(PTOGV(Dest), (GenericValue*)(Result+i), Type::LongTy); + } + Result[InputArgv.size()] = 0; + return Result; - copy(InputArgv[i].begin(), InputArgv[i].end(), Dest); - Dest[Size-1] = 0; + } else { // 32 bit target? + int *Result = new int[InputArgv.size()+1]; + DEBUG(std::cerr << "ARGV = " << (void*)Result << "\n"); - // Endian safe: Result[i] = (PointerTy)Dest; - StoreValueToMemory(PTOGV(Dest), (GenericValue*)(Result+i), - Type::LongTy); // 64 bit assumption + for (unsigned i = 0; i < InputArgv.size(); ++i) { + unsigned Size = InputArgv[i].size()+1; + char *Dest = new char[Size]; + DEBUG(std::cerr << "ARGV[" << i << "] = " << (void*)Dest << "\n"); + + copy(InputArgv[i].begin(), InputArgv[i].end(), Dest); + Dest[Size-1] = 0; + + // Endian safe: Result[i] = (PointerTy)Dest; + StoreValueToMemory(PTOGV(Dest), (GenericValue*)(Result+i), Type::IntTy); + } + Result[InputArgv.size()] = 0; // null terminate it + return Result; } - - Result[InputArgv.size()] = 0; - return Result; } /// EmitGlobals - Emit all of the global variables to memory, storing their |