1857c21b4SMisha Brukman //===-- ExecutionEngine.cpp - Common Implementation shared by EEs ---------===// 2996fe010SChris Lattner // 3482202a6SJohn Criswell // The LLVM Compiler Infrastructure 4482202a6SJohn Criswell // 5482202a6SJohn Criswell // This file was developed by the LLVM research group and is distributed under 6482202a6SJohn Criswell // the University of Illinois Open Source License. See LICENSE.TXT for details. 7482202a6SJohn Criswell // 8482202a6SJohn Criswell //===----------------------------------------------------------------------===// 9482202a6SJohn Criswell // 10996fe010SChris Lattner // This file defines the common interface used by the various execution engine 11996fe010SChris Lattner // subclasses. 12996fe010SChris Lattner // 13996fe010SChris Lattner //===----------------------------------------------------------------------===// 14996fe010SChris Lattner 15ee937c80SChris Lattner #define DEBUG_TYPE "jit" 16ad481312SChris Lattner #include "Interpreter/Interpreter.h" 1732ccf7e1SChris Lattner #include "JIT/JIT.h" 18996fe010SChris Lattner #include "llvm/Constants.h" 19260b0c88SMisha Brukman #include "llvm/DerivedTypes.h" 20996fe010SChris Lattner #include "llvm/Module.h" 21260b0c88SMisha Brukman #include "llvm/ModuleProvider.h" 224c96b088SChris Lattner #include "llvm/CodeGen/IntrinsicLowering.h" 23260b0c88SMisha Brukman #include "llvm/ExecutionEngine/ExecutionEngine.h" 24ad481312SChris Lattner #include "llvm/ExecutionEngine/GenericValue.h" 25996fe010SChris Lattner #include "llvm/Target/TargetData.h" 267c16caa3SReid Spencer #include "llvm/Support/Debug.h" 277c16caa3SReid Spencer #include "llvm/ADT/Statistic.h" 287c16caa3SReid Spencer #include "llvm/Support/DynamicLinker.h" 2929681deeSChris Lattner using namespace llvm; 30996fe010SChris Lattner 3129681deeSChris Lattner namespace { 32996fe010SChris Lattner Statistic<> NumInitBytes("lli", "Number of bytes of global vars initialized"); 336bbe3eceSChris Lattner Statistic<> NumGlobals ("lli", "Number of global vars initialized"); 3429681deeSChris Lattner } 35996fe010SChris Lattner 36260b0c88SMisha Brukman ExecutionEngine::ExecutionEngine(ModuleProvider *P) : 37260b0c88SMisha Brukman CurMod(*P->getModule()), MP(P) { 38260b0c88SMisha Brukman assert(P && "ModuleProvider is null?"); 39260b0c88SMisha Brukman } 40260b0c88SMisha Brukman 41260b0c88SMisha Brukman ExecutionEngine::ExecutionEngine(Module *M) : CurMod(*M), MP(0) { 42260b0c88SMisha Brukman assert(M && "Module is null?"); 43260b0c88SMisha Brukman } 44260b0c88SMisha Brukman 4592f8b30dSBrian Gaeke ExecutionEngine::~ExecutionEngine() { 462f1e2002SMisha Brukman delete MP; 4792f8b30dSBrian Gaeke } 4892f8b30dSBrian Gaeke 49748e8579SChris Lattner /// getGlobalValueAtAddress - Return the LLVM global value object that starts 50748e8579SChris Lattner /// at the specified address. 51748e8579SChris Lattner /// 52748e8579SChris Lattner const GlobalValue *ExecutionEngine::getGlobalValueAtAddress(void *Addr) { 53748e8579SChris Lattner // If we haven't computed the reverse mapping yet, do so first. 54748e8579SChris Lattner if (GlobalAddressReverseMap.empty()) { 55748e8579SChris Lattner for (std::map<const GlobalValue*, void *>::iterator I = 56748e8579SChris Lattner GlobalAddressMap.begin(), E = GlobalAddressMap.end(); I != E; ++I) 57748e8579SChris Lattner GlobalAddressReverseMap.insert(std::make_pair(I->second, I->first)); 58748e8579SChris Lattner } 59748e8579SChris Lattner 60748e8579SChris Lattner std::map<void *, const GlobalValue*>::iterator I = 61748e8579SChris Lattner GlobalAddressReverseMap.find(Addr); 62748e8579SChris Lattner return I != GlobalAddressReverseMap.end() ? I->second : 0; 63748e8579SChris Lattner } 645a0d4829SChris Lattner 655a0d4829SChris Lattner // CreateArgv - Turn a vector of strings into a nice argv style array of 665a0d4829SChris Lattner // pointers to null terminated strings. 675a0d4829SChris Lattner // 685a0d4829SChris Lattner static void *CreateArgv(ExecutionEngine *EE, 695a0d4829SChris Lattner const std::vector<std::string> &InputArgv) { 705a0d4829SChris Lattner unsigned PtrSize = EE->getTargetData().getPointerSize(); 715a0d4829SChris Lattner char *Result = new char[(InputArgv.size()+1)*PtrSize]; 725a0d4829SChris Lattner 735a0d4829SChris Lattner DEBUG(std::cerr << "ARGV = " << (void*)Result << "\n"); 745a0d4829SChris Lattner const Type *SBytePtr = PointerType::get(Type::SByteTy); 755a0d4829SChris Lattner 765a0d4829SChris Lattner for (unsigned i = 0; i != InputArgv.size(); ++i) { 775a0d4829SChris Lattner unsigned Size = InputArgv[i].size()+1; 785a0d4829SChris Lattner char *Dest = new char[Size]; 795a0d4829SChris Lattner DEBUG(std::cerr << "ARGV[" << i << "] = " << (void*)Dest << "\n"); 805a0d4829SChris Lattner 815a0d4829SChris Lattner std::copy(InputArgv[i].begin(), InputArgv[i].end(), Dest); 825a0d4829SChris Lattner Dest[Size-1] = 0; 835a0d4829SChris Lattner 845a0d4829SChris Lattner // Endian safe: Result[i] = (PointerTy)Dest; 855a0d4829SChris Lattner EE->StoreValueToMemory(PTOGV(Dest), (GenericValue*)(Result+i*PtrSize), 865a0d4829SChris Lattner SBytePtr); 875a0d4829SChris Lattner } 885a0d4829SChris Lattner 895a0d4829SChris Lattner // Null terminate it 905a0d4829SChris Lattner EE->StoreValueToMemory(PTOGV(0), 915a0d4829SChris Lattner (GenericValue*)(Result+InputArgv.size()*PtrSize), 925a0d4829SChris Lattner SBytePtr); 935a0d4829SChris Lattner return Result; 945a0d4829SChris Lattner } 955a0d4829SChris Lattner 965a0d4829SChris Lattner /// runFunctionAsMain - This is a helper function which wraps runFunction to 975a0d4829SChris Lattner /// handle the common task of starting up main with the specified argc, argv, 985a0d4829SChris Lattner /// and envp parameters. 995a0d4829SChris Lattner int ExecutionEngine::runFunctionAsMain(Function *Fn, 1005a0d4829SChris Lattner const std::vector<std::string> &argv, 1015a0d4829SChris Lattner const char * const * envp) { 1025a0d4829SChris Lattner std::vector<GenericValue> GVArgs; 1035a0d4829SChris Lattner GenericValue GVArgc; 1045a0d4829SChris Lattner GVArgc.IntVal = argv.size(); 105b1cad0b3SChris Lattner unsigned NumArgs = Fn->getFunctionType()->getNumParams(); 106b1cad0b3SChris Lattner if (NumArgs) { 1075a0d4829SChris Lattner GVArgs.push_back(GVArgc); // Arg #0 = argc. 108b1cad0b3SChris Lattner if (NumArgs > 1) { 1095a0d4829SChris Lattner GVArgs.push_back(PTOGV(CreateArgv(this, argv))); // Arg #1 = argv. 110b1cad0b3SChris Lattner assert(((char **)GVTOP(GVArgs[1]))[0] && 111b1cad0b3SChris Lattner "argv[0] was null after CreateArgv"); 112b1cad0b3SChris Lattner if (NumArgs > 2) { 1135a0d4829SChris Lattner std::vector<std::string> EnvVars; 1145a0d4829SChris Lattner for (unsigned i = 0; envp[i]; ++i) 1155a0d4829SChris Lattner EnvVars.push_back(envp[i]); 1165a0d4829SChris Lattner GVArgs.push_back(PTOGV(CreateArgv(this, EnvVars))); // Arg #2 = envp. 117b1cad0b3SChris Lattner } 118b1cad0b3SChris Lattner } 119b1cad0b3SChris Lattner } 1205a0d4829SChris Lattner return runFunction(Fn, GVArgs).IntVal; 1215a0d4829SChris Lattner } 1225a0d4829SChris Lattner 1235a0d4829SChris Lattner 1245a0d4829SChris Lattner 125260b0c88SMisha Brukman /// If possible, create a JIT, unless the caller specifically requests an 126260b0c88SMisha Brukman /// Interpreter or there's an error. If even an Interpreter cannot be created, 127260b0c88SMisha Brukman /// NULL is returned. 128857c21b4SMisha Brukman /// 1292f1e2002SMisha Brukman ExecutionEngine *ExecutionEngine::create(ModuleProvider *MP, 130c8c6c03dSChris Lattner bool ForceInterpreter, 131c8c6c03dSChris Lattner IntrinsicLowering *IL) { 1324bd3bd5bSBrian Gaeke ExecutionEngine *EE = 0; 1334bd3bd5bSBrian Gaeke 134c8c6c03dSChris Lattner // Unless the interpreter was explicitly selected, try making a JIT. 13565cd5048SBrian Gaeke if (!ForceInterpreter) 136c8c6c03dSChris Lattner EE = JIT::create(MP, IL); 1374bd3bd5bSBrian Gaeke 1384bd3bd5bSBrian Gaeke // If we can't make a JIT, make an interpreter instead. 13993f7c408SChris Lattner if (EE == 0) { 140260b0c88SMisha Brukman try { 14193f7c408SChris Lattner Module *M = MP->materializeModule(); 14293f7c408SChris Lattner try { 14393f7c408SChris Lattner EE = Interpreter::create(M, IL); 144260b0c88SMisha Brukman } catch (...) { 14593f7c408SChris Lattner std::cerr << "Error creating the interpreter!\n"; 14693f7c408SChris Lattner } 1476967cd54SReid Spencer } catch (std::string& errmsg) { 1486967cd54SReid Spencer std::cerr << "Error reading the bytecode file: " << errmsg << "\n"; 14993f7c408SChris Lattner } catch (...) { 15093f7c408SChris Lattner std::cerr << "Error reading the bytecode file!\n"; 15193f7c408SChris Lattner } 152260b0c88SMisha Brukman } 153c8c6c03dSChris Lattner 154c8c6c03dSChris Lattner if (EE == 0) delete IL; 1554bd3bd5bSBrian Gaeke return EE; 1564bd3bd5bSBrian Gaeke } 1574bd3bd5bSBrian Gaeke 158857c21b4SMisha Brukman /// getPointerToGlobal - This returns the address of the specified global 159857c21b4SMisha Brukman /// value. This may involve code generation if it's a function. 160857c21b4SMisha Brukman /// 161996fe010SChris Lattner void *ExecutionEngine::getPointerToGlobal(const GlobalValue *GV) { 1621678e859SBrian Gaeke if (Function *F = const_cast<Function*>(dyn_cast<Function>(GV))) 163996fe010SChris Lattner return getPointerToFunction(F); 164996fe010SChris Lattner 165748e8579SChris Lattner assert(GlobalAddressMap[GV] && "Global hasn't had an address allocated yet?"); 166748e8579SChris Lattner return GlobalAddressMap[GV]; 167996fe010SChris Lattner } 168996fe010SChris Lattner 169857c21b4SMisha Brukman /// FIXME: document 170857c21b4SMisha Brukman /// 171996fe010SChris Lattner GenericValue ExecutionEngine::getConstantValue(const Constant *C) { 172996fe010SChris Lattner GenericValue Result; 173d7a7a3f4SChris Lattner if (isa<UndefValue>(C)) return Result; 1749de0d14dSChris Lattner 17568cbcc3eSChris Lattner if (ConstantExpr *CE = const_cast<ConstantExpr*>(dyn_cast<ConstantExpr>(C))) { 1769de0d14dSChris Lattner switch (CE->getOpcode()) { 1779de0d14dSChris Lattner case Instruction::GetElementPtr: { 17868cbcc3eSChris Lattner Result = getConstantValue(CE->getOperand(0)); 1799de0d14dSChris Lattner std::vector<Value*> Indexes(CE->op_begin()+1, CE->op_end()); 1809de0d14dSChris Lattner uint64_t Offset = 1819de0d14dSChris Lattner TD->getIndexedOffset(CE->getOperand(0)->getType(), Indexes); 1829de0d14dSChris Lattner 1839de0d14dSChris Lattner Result.LongVal += Offset; 1849de0d14dSChris Lattner return Result; 1859de0d14dSChris Lattner } 18668cbcc3eSChris Lattner case Instruction::Cast: { 18768cbcc3eSChris Lattner // We only need to handle a few cases here. Almost all casts will 18868cbcc3eSChris Lattner // automatically fold, just the ones involving pointers won't. 18968cbcc3eSChris Lattner // 19068cbcc3eSChris Lattner Constant *Op = CE->getOperand(0); 1915def7a57SChris Lattner GenericValue GV = getConstantValue(Op); 19268cbcc3eSChris Lattner 19368cbcc3eSChris Lattner // Handle cast of pointer to pointer... 1946b727599SChris Lattner if (Op->getType()->getTypeID() == C->getType()->getTypeID()) 1955def7a57SChris Lattner return GV; 19668cbcc3eSChris Lattner 1970627a96eSChris Lattner // Handle a cast of pointer to any integral type... 1988e693398SChris Lattner if (isa<PointerType>(Op->getType()) && C->getType()->isIntegral()) 1995def7a57SChris Lattner return GV; 2000627a96eSChris Lattner 2015def7a57SChris Lattner // Handle cast of integer to a pointer... 2025def7a57SChris Lattner if (isa<PointerType>(C->getType()) && Op->getType()->isIntegral()) 2036b727599SChris Lattner switch (Op->getType()->getTypeID()) { 2045def7a57SChris Lattner case Type::BoolTyID: return PTOGV((void*)(uintptr_t)GV.BoolVal); 2055def7a57SChris Lattner case Type::SByteTyID: return PTOGV((void*)( intptr_t)GV.SByteVal); 2065def7a57SChris Lattner case Type::UByteTyID: return PTOGV((void*)(uintptr_t)GV.UByteVal); 2075def7a57SChris Lattner case Type::ShortTyID: return PTOGV((void*)( intptr_t)GV.ShortVal); 2085def7a57SChris Lattner case Type::UShortTyID: return PTOGV((void*)(uintptr_t)GV.UShortVal); 2095def7a57SChris Lattner case Type::IntTyID: return PTOGV((void*)( intptr_t)GV.IntVal); 2105def7a57SChris Lattner case Type::UIntTyID: return PTOGV((void*)(uintptr_t)GV.UIntVal); 2115def7a57SChris Lattner case Type::LongTyID: return PTOGV((void*)( intptr_t)GV.LongVal); 2125def7a57SChris Lattner case Type::ULongTyID: return PTOGV((void*)(uintptr_t)GV.ULongVal); 2135def7a57SChris Lattner default: assert(0 && "Unknown integral type!"); 2145def7a57SChris Lattner } 21568cbcc3eSChris Lattner break; 21668cbcc3eSChris Lattner } 21768cbcc3eSChris Lattner 21868cbcc3eSChris Lattner case Instruction::Add: 219c4e6bb5fSChris Lattner switch (CE->getOperand(0)->getType()->getTypeID()) { 220c4e6bb5fSChris Lattner default: assert(0 && "Bad add type!"); abort(); 221c4e6bb5fSChris Lattner case Type::LongTyID: 222c4e6bb5fSChris Lattner case Type::ULongTyID: 2233b3276beSChris Lattner Result.LongVal = getConstantValue(CE->getOperand(0)).LongVal + 2243b3276beSChris Lattner getConstantValue(CE->getOperand(1)).LongVal; 22568cbcc3eSChris Lattner break; 226c4e6bb5fSChris Lattner case Type::IntTyID: 227c4e6bb5fSChris Lattner case Type::UIntTyID: 228c4e6bb5fSChris Lattner Result.IntVal = getConstantValue(CE->getOperand(0)).IntVal + 229c4e6bb5fSChris Lattner getConstantValue(CE->getOperand(1)).IntVal; 230c4e6bb5fSChris Lattner break; 231c4e6bb5fSChris Lattner case Type::ShortTyID: 232c4e6bb5fSChris Lattner case Type::UShortTyID: 233c4e6bb5fSChris Lattner Result.ShortVal = getConstantValue(CE->getOperand(0)).ShortVal + 234c4e6bb5fSChris Lattner getConstantValue(CE->getOperand(1)).ShortVal; 235c4e6bb5fSChris Lattner break; 236c4e6bb5fSChris Lattner case Type::SByteTyID: 237c4e6bb5fSChris Lattner case Type::UByteTyID: 238c4e6bb5fSChris Lattner Result.SByteVal = getConstantValue(CE->getOperand(0)).SByteVal + 239c4e6bb5fSChris Lattner getConstantValue(CE->getOperand(1)).SByteVal; 240c4e6bb5fSChris Lattner break; 241c4e6bb5fSChris Lattner case Type::FloatTyID: 242c4e6bb5fSChris Lattner Result.FloatVal = getConstantValue(CE->getOperand(0)).FloatVal + 243c4e6bb5fSChris Lattner getConstantValue(CE->getOperand(1)).FloatVal; 244c4e6bb5fSChris Lattner break; 245c4e6bb5fSChris Lattner case Type::DoubleTyID: 246c4e6bb5fSChris Lattner Result.DoubleVal = getConstantValue(CE->getOperand(0)).DoubleVal + 247c4e6bb5fSChris Lattner getConstantValue(CE->getOperand(1)).DoubleVal; 248c4e6bb5fSChris Lattner break; 249c4e6bb5fSChris Lattner } 25068cbcc3eSChris Lattner return Result; 2519de0d14dSChris Lattner default: 25268cbcc3eSChris Lattner break; 25368cbcc3eSChris Lattner } 25468cbcc3eSChris Lattner std::cerr << "ConstantExpr not handled as global var init: " << *CE << "\n"; 2559de0d14dSChris Lattner abort(); 2569de0d14dSChris Lattner } 257996fe010SChris Lattner 2586b727599SChris Lattner switch (C->getType()->getTypeID()) { 2599de0d14dSChris Lattner #define GET_CONST_VAL(TY, CLASS) \ 2609de0d14dSChris Lattner case Type::TY##TyID: Result.TY##Val = cast<CLASS>(C)->getValue(); break 261996fe010SChris Lattner GET_CONST_VAL(Bool , ConstantBool); 262996fe010SChris Lattner GET_CONST_VAL(UByte , ConstantUInt); 263996fe010SChris Lattner GET_CONST_VAL(SByte , ConstantSInt); 264996fe010SChris Lattner GET_CONST_VAL(UShort , ConstantUInt); 265996fe010SChris Lattner GET_CONST_VAL(Short , ConstantSInt); 266996fe010SChris Lattner GET_CONST_VAL(UInt , ConstantUInt); 267996fe010SChris Lattner GET_CONST_VAL(Int , ConstantSInt); 268996fe010SChris Lattner GET_CONST_VAL(ULong , ConstantUInt); 269996fe010SChris Lattner GET_CONST_VAL(Long , ConstantSInt); 270996fe010SChris Lattner GET_CONST_VAL(Float , ConstantFP); 271996fe010SChris Lattner GET_CONST_VAL(Double , ConstantFP); 272996fe010SChris Lattner #undef GET_CONST_VAL 273996fe010SChris Lattner case Type::PointerTyID: 2746a0fd73bSReid Spencer if (isa<ConstantPointerNull>(C)) 275996fe010SChris Lattner Result.PointerVal = 0; 2766a0fd73bSReid Spencer else if (const Function *F = dyn_cast<Function>(C)) 2776a0fd73bSReid Spencer Result = PTOGV(getPointerToFunctionOrStub(const_cast<Function*>(F))); 2786a0fd73bSReid Spencer else if (const GlobalVariable* GV = dyn_cast<GlobalVariable>(C)) 2796a0fd73bSReid Spencer Result = PTOGV(getOrEmitGlobalVariable(const_cast<GlobalVariable*>(GV))); 280e6492f10SChris Lattner else 281996fe010SChris Lattner assert(0 && "Unknown constant pointer type!"); 282996fe010SChris Lattner break; 283996fe010SChris Lattner default: 28460a7dd16SChris Lattner std::cout << "ERROR: Constant unimp for type: " << *C->getType() << "\n"; 2859de0d14dSChris Lattner abort(); 286996fe010SChris Lattner } 287996fe010SChris Lattner return Result; 288996fe010SChris Lattner } 289996fe010SChris Lattner 290857c21b4SMisha Brukman /// FIXME: document 291857c21b4SMisha Brukman /// 292996fe010SChris Lattner void ExecutionEngine::StoreValueToMemory(GenericValue Val, GenericValue *Ptr, 293996fe010SChris Lattner const Type *Ty) { 294996fe010SChris Lattner if (getTargetData().isLittleEndian()) { 2956b727599SChris Lattner switch (Ty->getTypeID()) { 296996fe010SChris Lattner case Type::BoolTyID: 297996fe010SChris Lattner case Type::UByteTyID: 298996fe010SChris Lattner case Type::SByteTyID: Ptr->Untyped[0] = Val.UByteVal; break; 299996fe010SChris Lattner case Type::UShortTyID: 300996fe010SChris Lattner case Type::ShortTyID: Ptr->Untyped[0] = Val.UShortVal & 255; 301996fe010SChris Lattner Ptr->Untyped[1] = (Val.UShortVal >> 8) & 255; 302996fe010SChris Lattner break; 303b348952dSChris Lattner Store4BytesLittleEndian: 304996fe010SChris Lattner case Type::FloatTyID: 305996fe010SChris Lattner case Type::UIntTyID: 306996fe010SChris Lattner case Type::IntTyID: Ptr->Untyped[0] = Val.UIntVal & 255; 307996fe010SChris Lattner Ptr->Untyped[1] = (Val.UIntVal >> 8) & 255; 308996fe010SChris Lattner Ptr->Untyped[2] = (Val.UIntVal >> 16) & 255; 309996fe010SChris Lattner Ptr->Untyped[3] = (Val.UIntVal >> 24) & 255; 310996fe010SChris Lattner break; 31169cab0ddSChris Lattner case Type::PointerTyID: if (getTargetData().getPointerSize() == 4) 312b348952dSChris Lattner goto Store4BytesLittleEndian; 313996fe010SChris Lattner case Type::DoubleTyID: 314996fe010SChris Lattner case Type::ULongTyID: 315b348952dSChris Lattner case Type::LongTyID: Ptr->Untyped[0] = Val.ULongVal & 255; 316996fe010SChris Lattner Ptr->Untyped[1] = (Val.ULongVal >> 8) & 255; 317996fe010SChris Lattner Ptr->Untyped[2] = (Val.ULongVal >> 16) & 255; 318996fe010SChris Lattner Ptr->Untyped[3] = (Val.ULongVal >> 24) & 255; 319996fe010SChris Lattner Ptr->Untyped[4] = (Val.ULongVal >> 32) & 255; 320996fe010SChris Lattner Ptr->Untyped[5] = (Val.ULongVal >> 40) & 255; 321996fe010SChris Lattner Ptr->Untyped[6] = (Val.ULongVal >> 48) & 255; 322996fe010SChris Lattner Ptr->Untyped[7] = (Val.ULongVal >> 56) & 255; 323996fe010SChris Lattner break; 324996fe010SChris Lattner default: 32560a7dd16SChris Lattner std::cout << "Cannot store value of type " << *Ty << "!\n"; 326996fe010SChris Lattner } 327996fe010SChris Lattner } else { 3286b727599SChris Lattner switch (Ty->getTypeID()) { 329996fe010SChris Lattner case Type::BoolTyID: 330996fe010SChris Lattner case Type::UByteTyID: 331996fe010SChris Lattner case Type::SByteTyID: Ptr->Untyped[0] = Val.UByteVal; break; 332996fe010SChris Lattner case Type::UShortTyID: 333996fe010SChris Lattner case Type::ShortTyID: Ptr->Untyped[1] = Val.UShortVal & 255; 334996fe010SChris Lattner Ptr->Untyped[0] = (Val.UShortVal >> 8) & 255; 335996fe010SChris Lattner break; 336b348952dSChris Lattner Store4BytesBigEndian: 337996fe010SChris Lattner case Type::FloatTyID: 338996fe010SChris Lattner case Type::UIntTyID: 339996fe010SChris Lattner case Type::IntTyID: Ptr->Untyped[3] = Val.UIntVal & 255; 340996fe010SChris Lattner Ptr->Untyped[2] = (Val.UIntVal >> 8) & 255; 341996fe010SChris Lattner Ptr->Untyped[1] = (Val.UIntVal >> 16) & 255; 342996fe010SChris Lattner Ptr->Untyped[0] = (Val.UIntVal >> 24) & 255; 343996fe010SChris Lattner break; 34469cab0ddSChris Lattner case Type::PointerTyID: if (getTargetData().getPointerSize() == 4) 345b348952dSChris Lattner goto Store4BytesBigEndian; 346996fe010SChris Lattner case Type::DoubleTyID: 347996fe010SChris Lattner case Type::ULongTyID: 348b348952dSChris Lattner case Type::LongTyID: Ptr->Untyped[7] = Val.ULongVal & 255; 349996fe010SChris Lattner Ptr->Untyped[6] = (Val.ULongVal >> 8) & 255; 350996fe010SChris Lattner Ptr->Untyped[5] = (Val.ULongVal >> 16) & 255; 351996fe010SChris Lattner Ptr->Untyped[4] = (Val.ULongVal >> 24) & 255; 352996fe010SChris Lattner Ptr->Untyped[3] = (Val.ULongVal >> 32) & 255; 353996fe010SChris Lattner Ptr->Untyped[2] = (Val.ULongVal >> 40) & 255; 354996fe010SChris Lattner Ptr->Untyped[1] = (Val.ULongVal >> 48) & 255; 355996fe010SChris Lattner Ptr->Untyped[0] = (Val.ULongVal >> 56) & 255; 356996fe010SChris Lattner break; 357996fe010SChris Lattner default: 35860a7dd16SChris Lattner std::cout << "Cannot store value of type " << *Ty << "!\n"; 359996fe010SChris Lattner } 360996fe010SChris Lattner } 361996fe010SChris Lattner } 362996fe010SChris Lattner 363857c21b4SMisha Brukman /// FIXME: document 364857c21b4SMisha Brukman /// 3657f389e8cSChris Lattner GenericValue ExecutionEngine::LoadValueFromMemory(GenericValue *Ptr, 3667f389e8cSChris Lattner const Type *Ty) { 3677f389e8cSChris Lattner GenericValue Result; 3687f389e8cSChris Lattner if (getTargetData().isLittleEndian()) { 3696b727599SChris Lattner switch (Ty->getTypeID()) { 3707f389e8cSChris Lattner case Type::BoolTyID: 3717f389e8cSChris Lattner case Type::UByteTyID: 3727f389e8cSChris Lattner case Type::SByteTyID: Result.UByteVal = Ptr->Untyped[0]; break; 3737f389e8cSChris Lattner case Type::UShortTyID: 3747f389e8cSChris Lattner case Type::ShortTyID: Result.UShortVal = (unsigned)Ptr->Untyped[0] | 3757f389e8cSChris Lattner ((unsigned)Ptr->Untyped[1] << 8); 3767f389e8cSChris Lattner break; 3777f389e8cSChris Lattner Load4BytesLittleEndian: 3787f389e8cSChris Lattner case Type::FloatTyID: 3797f389e8cSChris Lattner case Type::UIntTyID: 3807f389e8cSChris Lattner case Type::IntTyID: Result.UIntVal = (unsigned)Ptr->Untyped[0] | 3817f389e8cSChris Lattner ((unsigned)Ptr->Untyped[1] << 8) | 3827f389e8cSChris Lattner ((unsigned)Ptr->Untyped[2] << 16) | 3837f389e8cSChris Lattner ((unsigned)Ptr->Untyped[3] << 24); 3847f389e8cSChris Lattner break; 38569cab0ddSChris Lattner case Type::PointerTyID: if (getTargetData().getPointerSize() == 4) 3867f389e8cSChris Lattner goto Load4BytesLittleEndian; 3877f389e8cSChris Lattner case Type::DoubleTyID: 3887f389e8cSChris Lattner case Type::ULongTyID: 3897f389e8cSChris Lattner case Type::LongTyID: Result.ULongVal = (uint64_t)Ptr->Untyped[0] | 3907f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[1] << 8) | 3917f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[2] << 16) | 3927f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[3] << 24) | 3937f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[4] << 32) | 3947f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[5] << 40) | 3957f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[6] << 48) | 3967f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[7] << 56); 3977f389e8cSChris Lattner break; 3987f389e8cSChris Lattner default: 3997f389e8cSChris Lattner std::cout << "Cannot load value of type " << *Ty << "!\n"; 4007f389e8cSChris Lattner abort(); 4017f389e8cSChris Lattner } 4027f389e8cSChris Lattner } else { 4036b727599SChris Lattner switch (Ty->getTypeID()) { 4047f389e8cSChris Lattner case Type::BoolTyID: 4057f389e8cSChris Lattner case Type::UByteTyID: 4067f389e8cSChris Lattner case Type::SByteTyID: Result.UByteVal = Ptr->Untyped[0]; break; 4077f389e8cSChris Lattner case Type::UShortTyID: 4087f389e8cSChris Lattner case Type::ShortTyID: Result.UShortVal = (unsigned)Ptr->Untyped[1] | 4097f389e8cSChris Lattner ((unsigned)Ptr->Untyped[0] << 8); 4107f389e8cSChris Lattner break; 4117f389e8cSChris Lattner Load4BytesBigEndian: 4127f389e8cSChris Lattner case Type::FloatTyID: 4137f389e8cSChris Lattner case Type::UIntTyID: 4147f389e8cSChris Lattner case Type::IntTyID: Result.UIntVal = (unsigned)Ptr->Untyped[3] | 4157f389e8cSChris Lattner ((unsigned)Ptr->Untyped[2] << 8) | 4167f389e8cSChris Lattner ((unsigned)Ptr->Untyped[1] << 16) | 4177f389e8cSChris Lattner ((unsigned)Ptr->Untyped[0] << 24); 4187f389e8cSChris Lattner break; 41969cab0ddSChris Lattner case Type::PointerTyID: if (getTargetData().getPointerSize() == 4) 4207f389e8cSChris Lattner goto Load4BytesBigEndian; 4217f389e8cSChris Lattner case Type::DoubleTyID: 4227f389e8cSChris Lattner case Type::ULongTyID: 4237f389e8cSChris Lattner case Type::LongTyID: Result.ULongVal = (uint64_t)Ptr->Untyped[7] | 4247f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[6] << 8) | 4257f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[5] << 16) | 4267f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[4] << 24) | 4277f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[3] << 32) | 4287f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[2] << 40) | 4297f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[1] << 48) | 4307f389e8cSChris Lattner ((uint64_t)Ptr->Untyped[0] << 56); 4317f389e8cSChris Lattner break; 4327f389e8cSChris Lattner default: 4337f389e8cSChris Lattner std::cout << "Cannot load value of type " << *Ty << "!\n"; 4347f389e8cSChris Lattner abort(); 4357f389e8cSChris Lattner } 4367f389e8cSChris Lattner } 4377f389e8cSChris Lattner return Result; 4387f389e8cSChris Lattner } 4397f389e8cSChris Lattner 440996fe010SChris Lattner // InitializeMemory - Recursive function to apply a Constant value into the 441996fe010SChris Lattner // specified memory location... 442996fe010SChris Lattner // 443996fe010SChris Lattner void ExecutionEngine::InitializeMemory(const Constant *Init, void *Addr) { 44461753bf8SChris Lattner if (isa<UndefValue>(Init)) { 445*d215992bSChris Lattner // FIXME: THIS SHOULD NOT BE NEEDED. 446*d215992bSChris Lattner unsigned Size = getTargetData().getTypeSize(Init->getType()); 447*d215992bSChris Lattner memset(Addr, 0, Size); 44861753bf8SChris Lattner return; 44961753bf8SChris Lattner } else if (Init->getType()->isFirstClassType()) { 450996fe010SChris Lattner GenericValue Val = getConstantValue(Init); 451996fe010SChris Lattner StoreValueToMemory(Val, (GenericValue*)Addr, Init->getType()); 452996fe010SChris Lattner return; 453834b1272SChris Lattner } else if (isa<ConstantAggregateZero>(Init)) { 454834b1272SChris Lattner unsigned Size = getTargetData().getTypeSize(Init->getType()); 455834b1272SChris Lattner memset(Addr, 0, Size); 456834b1272SChris Lattner return; 457996fe010SChris Lattner } 458996fe010SChris Lattner 4596b727599SChris Lattner switch (Init->getType()->getTypeID()) { 460996fe010SChris Lattner case Type::ArrayTyID: { 461996fe010SChris Lattner const ConstantArray *CPA = cast<ConstantArray>(Init); 462996fe010SChris Lattner unsigned ElementSize = 463996fe010SChris Lattner getTargetData().getTypeSize(cast<ArrayType>(CPA->getType())->getElementType()); 46483243725SAlkis Evlogimenos for (unsigned i = 0, e = CPA->getNumOperands(); i != e; ++i) 46583243725SAlkis Evlogimenos InitializeMemory(CPA->getOperand(i), (char*)Addr+i*ElementSize); 466996fe010SChris Lattner return; 467996fe010SChris Lattner } 468996fe010SChris Lattner 469996fe010SChris Lattner case Type::StructTyID: { 470996fe010SChris Lattner const ConstantStruct *CPS = cast<ConstantStruct>(Init); 471996fe010SChris Lattner const StructLayout *SL = 472996fe010SChris Lattner getTargetData().getStructLayout(cast<StructType>(CPS->getType())); 47383243725SAlkis Evlogimenos for (unsigned i = 0, e = CPS->getNumOperands(); i != e; ++i) 47483243725SAlkis Evlogimenos InitializeMemory(CPS->getOperand(i), (char*)Addr+SL->MemberOffsets[i]); 475996fe010SChris Lattner return; 476996fe010SChris Lattner } 477996fe010SChris Lattner 478996fe010SChris Lattner default: 47960a7dd16SChris Lattner std::cerr << "Bad Type: " << *Init->getType() << "\n"; 480996fe010SChris Lattner assert(0 && "Unknown constant type to initialize memory with!"); 481996fe010SChris Lattner } 482996fe010SChris Lattner } 483996fe010SChris Lattner 484996fe010SChris Lattner /// EmitGlobals - Emit all of the global variables to memory, storing their 485996fe010SChris Lattner /// addresses into GlobalAddress. This must make sure to copy the contents of 486996fe010SChris Lattner /// their initializers into the memory. 487996fe010SChris Lattner /// 488996fe010SChris Lattner void ExecutionEngine::emitGlobals() { 489996fe010SChris Lattner const TargetData &TD = getTargetData(); 490996fe010SChris Lattner 491996fe010SChris Lattner // Loop over all of the global variables in the program, allocating the memory 492996fe010SChris Lattner // to hold them. 493996fe010SChris Lattner for (Module::giterator I = getModule().gbegin(), E = getModule().gend(); 494996fe010SChris Lattner I != E; ++I) 495996fe010SChris Lattner if (!I->isExternal()) { 496996fe010SChris Lattner // Get the type of the global... 497996fe010SChris Lattner const Type *Ty = I->getType()->getElementType(); 498996fe010SChris Lattner 499996fe010SChris Lattner // Allocate some memory for it! 500996fe010SChris Lattner unsigned Size = TD.getTypeSize(Ty); 5016bbe3eceSChris Lattner addGlobalMapping(I, new char[Size]); 502996fe010SChris Lattner } else { 503e8bbcfc2SBrian Gaeke // External variable reference. Try to use the dynamic loader to 504e8bbcfc2SBrian Gaeke // get a pointer to it. 505e8bbcfc2SBrian Gaeke if (void *SymAddr = GetAddressOfSymbol(I->getName().c_str())) 506748e8579SChris Lattner addGlobalMapping(I, SymAddr); 5079de0d14dSChris Lattner else { 5089de0d14dSChris Lattner std::cerr << "Could not resolve external global address: " 5099de0d14dSChris Lattner << I->getName() << "\n"; 5109de0d14dSChris Lattner abort(); 5119de0d14dSChris Lattner } 512996fe010SChris Lattner } 513996fe010SChris Lattner 514996fe010SChris Lattner // Now that all of the globals are set up in memory, loop through them all and 515996fe010SChris Lattner // initialize their contents. 516996fe010SChris Lattner for (Module::giterator I = getModule().gbegin(), E = getModule().gend(); 517996fe010SChris Lattner I != E; ++I) 518996fe010SChris Lattner if (!I->isExternal()) 5196bbe3eceSChris Lattner EmitGlobalVariable(I); 5206bbe3eceSChris Lattner } 5216bbe3eceSChris Lattner 5226bbe3eceSChris Lattner // EmitGlobalVariable - This method emits the specified global variable to the 5236bbe3eceSChris Lattner // address specified in GlobalAddresses, or allocates new memory if it's not 5246bbe3eceSChris Lattner // already in the map. 525fbcc0aa1SChris Lattner void ExecutionEngine::EmitGlobalVariable(const GlobalVariable *GV) { 526748e8579SChris Lattner void *GA = getPointerToGlobalIfAvailable(GV); 527dc631735SChris Lattner DEBUG(std::cerr << "Global '" << GV->getName() << "' -> " << GA << "\n"); 528dc631735SChris Lattner 529fbcc0aa1SChris Lattner const Type *ElTy = GV->getType()->getElementType(); 530*d215992bSChris Lattner unsigned GVSize = getTargetData().getTypeSize(ElTy); 5316bbe3eceSChris Lattner if (GA == 0) { 5326bbe3eceSChris Lattner // If it's not already specified, allocate memory for the global. 533*d215992bSChris Lattner GA = new char[GVSize]; 534748e8579SChris Lattner addGlobalMapping(GV, GA); 5356bbe3eceSChris Lattner } 536fbcc0aa1SChris Lattner 5376bbe3eceSChris Lattner InitializeMemory(GV->getInitializer(), GA); 538*d215992bSChris Lattner NumInitBytes += GVSize; 5396bbe3eceSChris Lattner ++NumGlobals; 540996fe010SChris Lattner } 541