1996fe010SChris Lattner //===-- ExecutionEngine.cpp - Common Implementation shared by EE's --------===//
2996fe010SChris Lattner //
3996fe010SChris Lattner // This file defines the common interface used by the various execution engine
4996fe010SChris Lattner // subclasses.
5996fe010SChris Lattner //
6996fe010SChris Lattner //===----------------------------------------------------------------------===//
7996fe010SChris Lattner 
8996fe010SChris Lattner #include "ExecutionEngine.h"
9996fe010SChris Lattner #include "GenericValue.h"
10996fe010SChris Lattner #include "llvm/DerivedTypes.h"
11996fe010SChris Lattner #include "llvm/Constants.h"
12996fe010SChris Lattner #include "llvm/Module.h"
13996fe010SChris Lattner #include "llvm/Target/TargetData.h"
14996fe010SChris Lattner #include "Support/Statistic.h"
159de0d14dSChris Lattner #include <dlfcn.h>
16996fe010SChris Lattner 
17996fe010SChris Lattner Statistic<> NumInitBytes("lli", "Number of bytes of global vars initialized");
18996fe010SChris Lattner 
19996fe010SChris Lattner // getPointerToGlobal - This returns the address of the specified global
20996fe010SChris Lattner // value.  This may involve code generation if it's a function.
21996fe010SChris Lattner //
22996fe010SChris Lattner void *ExecutionEngine::getPointerToGlobal(const GlobalValue *GV) {
23996fe010SChris Lattner   if (const Function *F = dyn_cast<Function>(GV))
24996fe010SChris Lattner     return getPointerToFunction(F);
25996fe010SChris Lattner 
26996fe010SChris Lattner   assert(GlobalAddress[GV] && "Global hasn't had an address allocated yet?");
27996fe010SChris Lattner   return GlobalAddress[GV];
28996fe010SChris Lattner }
29996fe010SChris Lattner 
30996fe010SChris Lattner 
31996fe010SChris Lattner GenericValue ExecutionEngine::getConstantValue(const Constant *C) {
32996fe010SChris Lattner   GenericValue Result;
339de0d14dSChris Lattner 
34*68cbcc3eSChris Lattner   if (ConstantExpr *CE = const_cast<ConstantExpr*>(dyn_cast<ConstantExpr>(C))) {
359de0d14dSChris Lattner     switch (CE->getOpcode()) {
369de0d14dSChris Lattner     case Instruction::GetElementPtr: {
37*68cbcc3eSChris Lattner       Result = getConstantValue(CE->getOperand(0));
389de0d14dSChris Lattner       std::vector<Value*> Indexes(CE->op_begin()+1, CE->op_end());
399de0d14dSChris Lattner       uint64_t Offset =
409de0d14dSChris Lattner         TD->getIndexedOffset(CE->getOperand(0)->getType(), Indexes);
419de0d14dSChris Lattner 
429de0d14dSChris Lattner       Result.LongVal += Offset;
439de0d14dSChris Lattner       return Result;
449de0d14dSChris Lattner     }
45*68cbcc3eSChris Lattner     case Instruction::Cast: {
46*68cbcc3eSChris Lattner       // We only need to handle a few cases here.  Almost all casts will
47*68cbcc3eSChris Lattner       // automatically fold, just the ones involving pointers won't.
48*68cbcc3eSChris Lattner       //
49*68cbcc3eSChris Lattner       Constant *Op = CE->getOperand(0);
50*68cbcc3eSChris Lattner 
51*68cbcc3eSChris Lattner       // Handle cast of pointer to pointer...
52*68cbcc3eSChris Lattner       if (Op->getType()->getPrimitiveID() == C->getType()->getPrimitiveID())
53*68cbcc3eSChris Lattner         return getConstantValue(Op);
54*68cbcc3eSChris Lattner 
55*68cbcc3eSChris Lattner       // Handle cast of long to pointer or pointer to long...
56*68cbcc3eSChris Lattner       if ((isa<PointerType>(Op->getType()) && (C->getType() == Type::LongTy ||
57*68cbcc3eSChris Lattner                                                C->getType() == Type::ULongTy))||
58*68cbcc3eSChris Lattner           (isa<PointerType>(C->getType()) && (Op->getType() == Type::LongTy ||
59*68cbcc3eSChris Lattner                                               Op->getType() == Type::ULongTy))){
60*68cbcc3eSChris Lattner         return getConstantValue(Op);
61*68cbcc3eSChris Lattner       }
62*68cbcc3eSChris Lattner       break;
63*68cbcc3eSChris Lattner     }
64*68cbcc3eSChris Lattner 
65*68cbcc3eSChris Lattner     case Instruction::Add:
66*68cbcc3eSChris Lattner       if (C->getOperand(0)->getType() == Type::LongTy ||
67*68cbcc3eSChris Lattner           C->getOperand(0)->getType() == Type::ULongTy)
68*68cbcc3eSChris Lattner         Result.LongVal = getConstantValue(C->getOperand(0)).LongVal +
69*68cbcc3eSChris Lattner                          getConstantValue(C->getOperand(1)).LongVal;
70*68cbcc3eSChris Lattner       else
71*68cbcc3eSChris Lattner         break;
72*68cbcc3eSChris Lattner       return Result;
739de0d14dSChris Lattner 
749de0d14dSChris Lattner     default:
75*68cbcc3eSChris Lattner       break;
76*68cbcc3eSChris Lattner     }
77*68cbcc3eSChris Lattner     std::cerr << "ConstantExpr not handled as global var init: " << *CE << "\n";
789de0d14dSChris Lattner     abort();
799de0d14dSChris Lattner   }
80996fe010SChris Lattner 
81996fe010SChris Lattner   switch (C->getType()->getPrimitiveID()) {
829de0d14dSChris Lattner #define GET_CONST_VAL(TY, CLASS) \
839de0d14dSChris Lattner   case Type::TY##TyID: Result.TY##Val = cast<CLASS>(C)->getValue(); break
84996fe010SChris Lattner     GET_CONST_VAL(Bool   , ConstantBool);
85996fe010SChris Lattner     GET_CONST_VAL(UByte  , ConstantUInt);
86996fe010SChris Lattner     GET_CONST_VAL(SByte  , ConstantSInt);
87996fe010SChris Lattner     GET_CONST_VAL(UShort , ConstantUInt);
88996fe010SChris Lattner     GET_CONST_VAL(Short  , ConstantSInt);
89996fe010SChris Lattner     GET_CONST_VAL(UInt   , ConstantUInt);
90996fe010SChris Lattner     GET_CONST_VAL(Int    , ConstantSInt);
91996fe010SChris Lattner     GET_CONST_VAL(ULong  , ConstantUInt);
92996fe010SChris Lattner     GET_CONST_VAL(Long   , ConstantSInt);
93996fe010SChris Lattner     GET_CONST_VAL(Float  , ConstantFP);
94996fe010SChris Lattner     GET_CONST_VAL(Double , ConstantFP);
95996fe010SChris Lattner #undef GET_CONST_VAL
96996fe010SChris Lattner   case Type::PointerTyID:
97996fe010SChris Lattner     if (isa<ConstantPointerNull>(C)) {
98996fe010SChris Lattner       Result.PointerVal = 0;
99996fe010SChris Lattner     } else if (const ConstantPointerRef *CPR = dyn_cast<ConstantPointerRef>(C)){
100996fe010SChris Lattner       Result = PTOGV(getPointerToGlobal(CPR->getValue()));
101996fe010SChris Lattner 
102996fe010SChris Lattner     } else {
103996fe010SChris Lattner       assert(0 && "Unknown constant pointer type!");
104996fe010SChris Lattner     }
105996fe010SChris Lattner     break;
106996fe010SChris Lattner   default:
1075aa56633SChris Lattner     std::cout << "ERROR: Constant unimp for type: " << C->getType() << "\n";
1089de0d14dSChris Lattner     abort();
109996fe010SChris Lattner   }
110996fe010SChris Lattner   return Result;
111996fe010SChris Lattner }
112996fe010SChris Lattner 
113996fe010SChris Lattner void ExecutionEngine::StoreValueToMemory(GenericValue Val, GenericValue *Ptr,
114996fe010SChris Lattner 				     const Type *Ty) {
115996fe010SChris Lattner   if (getTargetData().isLittleEndian()) {
116996fe010SChris Lattner     switch (Ty->getPrimitiveID()) {
117996fe010SChris Lattner     case Type::BoolTyID:
118996fe010SChris Lattner     case Type::UByteTyID:
119996fe010SChris Lattner     case Type::SByteTyID:   Ptr->Untyped[0] = Val.UByteVal; break;
120996fe010SChris Lattner     case Type::UShortTyID:
121996fe010SChris Lattner     case Type::ShortTyID:   Ptr->Untyped[0] = Val.UShortVal & 255;
122996fe010SChris Lattner                             Ptr->Untyped[1] = (Val.UShortVal >> 8) & 255;
123996fe010SChris Lattner                             break;
124b348952dSChris Lattner     Store4BytesLittleEndian:
125996fe010SChris Lattner     case Type::FloatTyID:
126996fe010SChris Lattner     case Type::UIntTyID:
127996fe010SChris Lattner     case Type::IntTyID:     Ptr->Untyped[0] =  Val.UIntVal        & 255;
128996fe010SChris Lattner                             Ptr->Untyped[1] = (Val.UIntVal >>  8) & 255;
129996fe010SChris Lattner                             Ptr->Untyped[2] = (Val.UIntVal >> 16) & 255;
130996fe010SChris Lattner                             Ptr->Untyped[3] = (Val.UIntVal >> 24) & 255;
131996fe010SChris Lattner                             break;
132b348952dSChris Lattner     case Type::PointerTyID: if (CurMod.has32BitPointers())
133b348952dSChris Lattner                               goto Store4BytesLittleEndian;
134996fe010SChris Lattner     case Type::DoubleTyID:
135996fe010SChris Lattner     case Type::ULongTyID:
136b348952dSChris Lattner     case Type::LongTyID:    Ptr->Untyped[0] =  Val.ULongVal        & 255;
137996fe010SChris Lattner                             Ptr->Untyped[1] = (Val.ULongVal >>  8) & 255;
138996fe010SChris Lattner                             Ptr->Untyped[2] = (Val.ULongVal >> 16) & 255;
139996fe010SChris Lattner                             Ptr->Untyped[3] = (Val.ULongVal >> 24) & 255;
140996fe010SChris Lattner                             Ptr->Untyped[4] = (Val.ULongVal >> 32) & 255;
141996fe010SChris Lattner                             Ptr->Untyped[5] = (Val.ULongVal >> 40) & 255;
142996fe010SChris Lattner                             Ptr->Untyped[6] = (Val.ULongVal >> 48) & 255;
143996fe010SChris Lattner                             Ptr->Untyped[7] = (Val.ULongVal >> 56) & 255;
144996fe010SChris Lattner                             break;
145996fe010SChris Lattner     default:
1465aa56633SChris Lattner       std::cout << "Cannot store value of type " << Ty << "!\n";
147996fe010SChris Lattner     }
148996fe010SChris Lattner   } else {
149996fe010SChris Lattner     switch (Ty->getPrimitiveID()) {
150996fe010SChris Lattner     case Type::BoolTyID:
151996fe010SChris Lattner     case Type::UByteTyID:
152996fe010SChris Lattner     case Type::SByteTyID:   Ptr->Untyped[0] = Val.UByteVal; break;
153996fe010SChris Lattner     case Type::UShortTyID:
154996fe010SChris Lattner     case Type::ShortTyID:   Ptr->Untyped[1] = Val.UShortVal & 255;
155996fe010SChris Lattner                             Ptr->Untyped[0] = (Val.UShortVal >> 8) & 255;
156996fe010SChris Lattner                             break;
157b348952dSChris Lattner     Store4BytesBigEndian:
158996fe010SChris Lattner     case Type::FloatTyID:
159996fe010SChris Lattner     case Type::UIntTyID:
160996fe010SChris Lattner     case Type::IntTyID:     Ptr->Untyped[3] =  Val.UIntVal        & 255;
161996fe010SChris Lattner                             Ptr->Untyped[2] = (Val.UIntVal >>  8) & 255;
162996fe010SChris Lattner                             Ptr->Untyped[1] = (Val.UIntVal >> 16) & 255;
163996fe010SChris Lattner                             Ptr->Untyped[0] = (Val.UIntVal >> 24) & 255;
164996fe010SChris Lattner                             break;
165b348952dSChris Lattner     case Type::PointerTyID: if (CurMod.has32BitPointers())
166b348952dSChris Lattner                               goto Store4BytesBigEndian;
167996fe010SChris Lattner     case Type::DoubleTyID:
168996fe010SChris Lattner     case Type::ULongTyID:
169b348952dSChris Lattner     case Type::LongTyID:    Ptr->Untyped[7] =  Val.ULongVal        & 255;
170996fe010SChris Lattner                             Ptr->Untyped[6] = (Val.ULongVal >>  8) & 255;
171996fe010SChris Lattner                             Ptr->Untyped[5] = (Val.ULongVal >> 16) & 255;
172996fe010SChris Lattner                             Ptr->Untyped[4] = (Val.ULongVal >> 24) & 255;
173996fe010SChris Lattner                             Ptr->Untyped[3] = (Val.ULongVal >> 32) & 255;
174996fe010SChris Lattner                             Ptr->Untyped[2] = (Val.ULongVal >> 40) & 255;
175996fe010SChris Lattner                             Ptr->Untyped[1] = (Val.ULongVal >> 48) & 255;
176996fe010SChris Lattner                             Ptr->Untyped[0] = (Val.ULongVal >> 56) & 255;
177996fe010SChris Lattner                             break;
178996fe010SChris Lattner     default:
1795aa56633SChris Lattner       std::cout << "Cannot store value of type " << Ty << "!\n";
180996fe010SChris Lattner     }
181996fe010SChris Lattner   }
182996fe010SChris Lattner }
183996fe010SChris Lattner 
1847f389e8cSChris Lattner GenericValue ExecutionEngine::LoadValueFromMemory(GenericValue *Ptr,
1857f389e8cSChris Lattner                                                   const Type *Ty) {
1867f389e8cSChris Lattner   GenericValue Result;
1877f389e8cSChris Lattner   if (getTargetData().isLittleEndian()) {
1887f389e8cSChris Lattner     switch (Ty->getPrimitiveID()) {
1897f389e8cSChris Lattner     case Type::BoolTyID:
1907f389e8cSChris Lattner     case Type::UByteTyID:
1917f389e8cSChris Lattner     case Type::SByteTyID:   Result.UByteVal = Ptr->Untyped[0]; break;
1927f389e8cSChris Lattner     case Type::UShortTyID:
1937f389e8cSChris Lattner     case Type::ShortTyID:   Result.UShortVal = (unsigned)Ptr->Untyped[0] |
1947f389e8cSChris Lattner                                               ((unsigned)Ptr->Untyped[1] << 8);
1957f389e8cSChris Lattner                             break;
1967f389e8cSChris Lattner     Load4BytesLittleEndian:
1977f389e8cSChris Lattner     case Type::FloatTyID:
1987f389e8cSChris Lattner     case Type::UIntTyID:
1997f389e8cSChris Lattner     case Type::IntTyID:     Result.UIntVal = (unsigned)Ptr->Untyped[0] |
2007f389e8cSChris Lattner                                             ((unsigned)Ptr->Untyped[1] <<  8) |
2017f389e8cSChris Lattner                                             ((unsigned)Ptr->Untyped[2] << 16) |
2027f389e8cSChris Lattner                                             ((unsigned)Ptr->Untyped[3] << 24);
2037f389e8cSChris Lattner                             break;
2047f389e8cSChris Lattner     case Type::PointerTyID: if (getModule().has32BitPointers())
2057f389e8cSChris Lattner                               goto Load4BytesLittleEndian;
2067f389e8cSChris Lattner     case Type::DoubleTyID:
2077f389e8cSChris Lattner     case Type::ULongTyID:
2087f389e8cSChris Lattner     case Type::LongTyID:    Result.ULongVal = (uint64_t)Ptr->Untyped[0] |
2097f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[1] <<  8) |
2107f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[2] << 16) |
2117f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[3] << 24) |
2127f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[4] << 32) |
2137f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[5] << 40) |
2147f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[6] << 48) |
2157f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[7] << 56);
2167f389e8cSChris Lattner                             break;
2177f389e8cSChris Lattner     default:
2187f389e8cSChris Lattner       std::cout << "Cannot load value of type " << *Ty << "!\n";
2197f389e8cSChris Lattner       abort();
2207f389e8cSChris Lattner     }
2217f389e8cSChris Lattner   } else {
2227f389e8cSChris Lattner     switch (Ty->getPrimitiveID()) {
2237f389e8cSChris Lattner     case Type::BoolTyID:
2247f389e8cSChris Lattner     case Type::UByteTyID:
2257f389e8cSChris Lattner     case Type::SByteTyID:   Result.UByteVal = Ptr->Untyped[0]; break;
2267f389e8cSChris Lattner     case Type::UShortTyID:
2277f389e8cSChris Lattner     case Type::ShortTyID:   Result.UShortVal = (unsigned)Ptr->Untyped[1] |
2287f389e8cSChris Lattner                                               ((unsigned)Ptr->Untyped[0] << 8);
2297f389e8cSChris Lattner                             break;
2307f389e8cSChris Lattner     Load4BytesBigEndian:
2317f389e8cSChris Lattner     case Type::FloatTyID:
2327f389e8cSChris Lattner     case Type::UIntTyID:
2337f389e8cSChris Lattner     case Type::IntTyID:     Result.UIntVal = (unsigned)Ptr->Untyped[3] |
2347f389e8cSChris Lattner                                             ((unsigned)Ptr->Untyped[2] <<  8) |
2357f389e8cSChris Lattner                                             ((unsigned)Ptr->Untyped[1] << 16) |
2367f389e8cSChris Lattner                                             ((unsigned)Ptr->Untyped[0] << 24);
2377f389e8cSChris Lattner                             break;
2387f389e8cSChris Lattner     case Type::PointerTyID: if (getModule().has32BitPointers())
2397f389e8cSChris Lattner                               goto Load4BytesBigEndian;
2407f389e8cSChris Lattner     case Type::DoubleTyID:
2417f389e8cSChris Lattner     case Type::ULongTyID:
2427f389e8cSChris Lattner     case Type::LongTyID:    Result.ULongVal = (uint64_t)Ptr->Untyped[7] |
2437f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[6] <<  8) |
2447f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[5] << 16) |
2457f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[4] << 24) |
2467f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[3] << 32) |
2477f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[2] << 40) |
2487f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[1] << 48) |
2497f389e8cSChris Lattner                                              ((uint64_t)Ptr->Untyped[0] << 56);
2507f389e8cSChris Lattner                             break;
2517f389e8cSChris Lattner     default:
2527f389e8cSChris Lattner       std::cout << "Cannot load value of type " << *Ty << "!\n";
2537f389e8cSChris Lattner       abort();
2547f389e8cSChris Lattner     }
2557f389e8cSChris Lattner   }
2567f389e8cSChris Lattner   return Result;
2577f389e8cSChris Lattner }
2587f389e8cSChris Lattner 
2597f389e8cSChris Lattner 
260996fe010SChris Lattner // InitializeMemory - Recursive function to apply a Constant value into the
261996fe010SChris Lattner // specified memory location...
262996fe010SChris Lattner //
263996fe010SChris Lattner void ExecutionEngine::InitializeMemory(const Constant *Init, void *Addr) {
264996fe010SChris Lattner   if (Init->getType()->isFirstClassType()) {
265996fe010SChris Lattner     GenericValue Val = getConstantValue(Init);
266996fe010SChris Lattner     StoreValueToMemory(Val, (GenericValue*)Addr, Init->getType());
267996fe010SChris Lattner     return;
268996fe010SChris Lattner   }
269996fe010SChris Lattner 
270996fe010SChris Lattner   switch (Init->getType()->getPrimitiveID()) {
271996fe010SChris Lattner   case Type::ArrayTyID: {
272996fe010SChris Lattner     const ConstantArray *CPA = cast<ConstantArray>(Init);
2735aa56633SChris Lattner     const std::vector<Use> &Val = CPA->getValues();
274996fe010SChris Lattner     unsigned ElementSize =
275996fe010SChris Lattner       getTargetData().getTypeSize(cast<ArrayType>(CPA->getType())->getElementType());
276996fe010SChris Lattner     for (unsigned i = 0; i < Val.size(); ++i)
277996fe010SChris Lattner       InitializeMemory(cast<Constant>(Val[i].get()), (char*)Addr+i*ElementSize);
278996fe010SChris Lattner     return;
279996fe010SChris Lattner   }
280996fe010SChris Lattner 
281996fe010SChris Lattner   case Type::StructTyID: {
282996fe010SChris Lattner     const ConstantStruct *CPS = cast<ConstantStruct>(Init);
283996fe010SChris Lattner     const StructLayout *SL =
284996fe010SChris Lattner       getTargetData().getStructLayout(cast<StructType>(CPS->getType()));
2855aa56633SChris Lattner     const std::vector<Use> &Val = CPS->getValues();
286996fe010SChris Lattner     for (unsigned i = 0; i < Val.size(); ++i)
287996fe010SChris Lattner       InitializeMemory(cast<Constant>(Val[i].get()),
288996fe010SChris Lattner                        (char*)Addr+SL->MemberOffsets[i]);
289996fe010SChris Lattner     return;
290996fe010SChris Lattner   }
291996fe010SChris Lattner 
292996fe010SChris Lattner   default:
293996fe010SChris Lattner     std::cerr << "Bad Type: " << Init->getType() << "\n";
294996fe010SChris Lattner     assert(0 && "Unknown constant type to initialize memory with!");
295996fe010SChris Lattner   }
296996fe010SChris Lattner }
297996fe010SChris Lattner 
298996fe010SChris Lattner 
299996fe010SChris Lattner 
300996fe010SChris Lattner void *ExecutionEngine::CreateArgv(const std::vector<std::string> &InputArgv) {
3010f38d5dcSChris Lattner   if (getTargetData().getPointerSize() == 8) {   // 64 bit target?
302510e8ba6SChris Lattner     PointerTy *Result = new PointerTy[InputArgv.size()+1];
303996fe010SChris Lattner     DEBUG(std::cerr << "ARGV = " << (void*)Result << "\n");
304996fe010SChris Lattner 
305996fe010SChris Lattner     for (unsigned i = 0; i < InputArgv.size(); ++i) {
306996fe010SChris Lattner       unsigned Size = InputArgv[i].size()+1;
307996fe010SChris Lattner       char *Dest = new char[Size];
308996fe010SChris Lattner       DEBUG(std::cerr << "ARGV[" << i << "] = " << (void*)Dest << "\n");
309996fe010SChris Lattner 
310996fe010SChris Lattner       copy(InputArgv[i].begin(), InputArgv[i].end(), Dest);
311996fe010SChris Lattner       Dest[Size-1] = 0;
312996fe010SChris Lattner 
313996fe010SChris Lattner       // Endian safe: Result[i] = (PointerTy)Dest;
3140f38d5dcSChris Lattner       StoreValueToMemory(PTOGV(Dest), (GenericValue*)(Result+i), Type::LongTy);
315996fe010SChris Lattner     }
316996fe010SChris Lattner     Result[InputArgv.size()] = 0;
317996fe010SChris Lattner     return Result;
3180f38d5dcSChris Lattner 
3190f38d5dcSChris Lattner   } else {                                      // 32 bit target?
3200f38d5dcSChris Lattner     int *Result = new int[InputArgv.size()+1];
3210f38d5dcSChris Lattner     DEBUG(std::cerr << "ARGV = " << (void*)Result << "\n");
3220f38d5dcSChris Lattner 
3230f38d5dcSChris Lattner     for (unsigned i = 0; i < InputArgv.size(); ++i) {
3240f38d5dcSChris Lattner       unsigned Size = InputArgv[i].size()+1;
3250f38d5dcSChris Lattner       char *Dest = new char[Size];
3260f38d5dcSChris Lattner       DEBUG(std::cerr << "ARGV[" << i << "] = " << (void*)Dest << "\n");
3270f38d5dcSChris Lattner 
3280f38d5dcSChris Lattner       copy(InputArgv[i].begin(), InputArgv[i].end(), Dest);
3290f38d5dcSChris Lattner       Dest[Size-1] = 0;
3300f38d5dcSChris Lattner 
3310f38d5dcSChris Lattner       // Endian safe: Result[i] = (PointerTy)Dest;
3320f38d5dcSChris Lattner       StoreValueToMemory(PTOGV(Dest), (GenericValue*)(Result+i), Type::IntTy);
3330f38d5dcSChris Lattner     }
3340f38d5dcSChris Lattner     Result[InputArgv.size()] = 0;  // null terminate it
3350f38d5dcSChris Lattner     return Result;
3360f38d5dcSChris Lattner   }
337996fe010SChris Lattner }
338996fe010SChris Lattner 
339996fe010SChris Lattner /// EmitGlobals - Emit all of the global variables to memory, storing their
340996fe010SChris Lattner /// addresses into GlobalAddress.  This must make sure to copy the contents of
341996fe010SChris Lattner /// their initializers into the memory.
342996fe010SChris Lattner ///
343996fe010SChris Lattner void ExecutionEngine::emitGlobals() {
344996fe010SChris Lattner   const TargetData &TD = getTargetData();
345996fe010SChris Lattner 
346996fe010SChris Lattner   // Loop over all of the global variables in the program, allocating the memory
347996fe010SChris Lattner   // to hold them.
348996fe010SChris Lattner   for (Module::giterator I = getModule().gbegin(), E = getModule().gend();
349996fe010SChris Lattner        I != E; ++I)
350996fe010SChris Lattner     if (!I->isExternal()) {
351996fe010SChris Lattner       // Get the type of the global...
352996fe010SChris Lattner       const Type *Ty = I->getType()->getElementType();
353996fe010SChris Lattner 
354996fe010SChris Lattner       // Allocate some memory for it!
355996fe010SChris Lattner       unsigned Size = TD.getTypeSize(Ty);
356996fe010SChris Lattner       GlobalAddress[I] = new char[Size];
357996fe010SChris Lattner       NumInitBytes += Size;
358996fe010SChris Lattner 
359996fe010SChris Lattner       DEBUG(std::cerr << "Global '" << I->getName() << "' -> "
360996fe010SChris Lattner 	              << (void*)GlobalAddress[I] << "\n");
361996fe010SChris Lattner     } else {
3629de0d14dSChris Lattner       // External variable reference, try to use dlsym to get a pointer to it in
3639de0d14dSChris Lattner       // the LLI image.
3649de0d14dSChris Lattner       if (void *SymAddr = dlsym(0, I->getName().c_str()))
3659de0d14dSChris Lattner         GlobalAddress[I] = SymAddr;
3669de0d14dSChris Lattner       else {
3679de0d14dSChris Lattner         std::cerr << "Could not resolve external global address: "
3689de0d14dSChris Lattner                   << I->getName() << "\n";
3699de0d14dSChris Lattner         abort();
3709de0d14dSChris Lattner       }
371996fe010SChris Lattner     }
372996fe010SChris Lattner 
373996fe010SChris Lattner   // Now that all of the globals are set up in memory, loop through them all and
374996fe010SChris Lattner   // initialize their contents.
375996fe010SChris Lattner   for (Module::giterator I = getModule().gbegin(), E = getModule().gend();
376996fe010SChris Lattner        I != E; ++I)
377996fe010SChris Lattner     if (!I->isExternal())
378996fe010SChris Lattner       InitializeMemory(I->getInitializer(), GlobalAddress[I]);
379996fe010SChris Lattner }
380996fe010SChris Lattner 
381