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