| OLD | NEW |
| 1 //===- subzero/src/IceTranslator.cpp - ICE to machine code ------*- C++ -*-===// | 1 //===- subzero/src/IceTranslator.cpp - ICE to machine code ------*- C++ -*-===// |
| 2 // | 2 // |
| 3 // The Subzero Code Generator | 3 // The Subzero Code Generator |
| 4 // | 4 // |
| 5 // This file is distributed under the University of Illinois Open Source | 5 // This file is distributed under the University of Illinois Open Source |
| 6 // License. See LICENSE.TXT for details. | 6 // License. See LICENSE.TXT for details. |
| 7 // | 7 // |
| 8 //===----------------------------------------------------------------------===// | 8 //===----------------------------------------------------------------------===// |
| 9 // | 9 // |
| 10 // This file defines the general driver class for translating ICE to | 10 // This file defines the general driver class for translating ICE to |
| (...skipping 11 matching lines...) Expand all Loading... |
| 22 #include "IceCfg.h" | 22 #include "IceCfg.h" |
| 23 #include "IceClFlags.h" | 23 #include "IceClFlags.h" |
| 24 #include "IceDefs.h" | 24 #include "IceDefs.h" |
| 25 #include "IceTargetLowering.h" | 25 #include "IceTargetLowering.h" |
| 26 #include "IceTranslator.h" | 26 #include "IceTranslator.h" |
| 27 | 27 |
| 28 using namespace Ice; | 28 using namespace Ice; |
| 29 | 29 |
| 30 Translator::~Translator() {} | 30 Translator::~Translator() {} |
| 31 | 31 |
| 32 namespace { | 32 IceString Translator::createUnnamedName(const IceString &Prefix, SizeT Index) { |
| 33 void setValueName(llvm::Value *V, const char *Kind, const IceString &Prefix, | 33 if (Index == 0) |
| 34 uint32_t &NameIndex, Ostream &errs) { | 34 return Prefix; |
| 35 if (V->hasName()) { | |
| 36 const std::string &Name(V->getName()); | |
| 37 if (Name.find(Prefix) == 0) { | |
| 38 errs << "Warning: Default " << Kind << " prefix '" << Prefix | |
| 39 << "' conflicts with name '" << Name << "'.\n"; | |
| 40 } | |
| 41 return; | |
| 42 } | |
| 43 if (NameIndex == 0) { | |
| 44 V->setName(Prefix); | |
| 45 ++NameIndex; | |
| 46 return; | |
| 47 } | |
| 48 std::string Buffer; | 35 std::string Buffer; |
| 49 llvm::raw_string_ostream StrBuf(Buffer); | 36 llvm::raw_string_ostream StrBuf(Buffer); |
| 50 StrBuf << Prefix << NameIndex; | 37 StrBuf << Prefix << Index; |
| 51 V->setName(StrBuf.str()); | 38 return StrBuf.str(); |
| 52 ++NameIndex; | |
| 53 } | 39 } |
| 54 } // end of anonymous namespace | 40 |
| 41 bool Translator::checkIfUnnamedNameSafe(const IceString &Name, const char *Kind, |
| 42 const IceString &Prefix, |
| 43 Ostream &Stream) { |
| 44 if (Name.find(Prefix) == 0) { |
| 45 for (size_t i = Prefix.size(); i < Name.size(); ++i) { |
| 46 if (!isdigit(Name[i])) { |
| 47 return false; |
| 48 } |
| 49 } |
| 50 Stream << "Warning : Default " << Kind << " prefix '" << Prefix |
| 51 << "' potentially conflicts with name '" << Name << "'.\n"; |
| 52 return true; |
| 53 } |
| 54 return false; |
| 55 } |
| 55 | 56 |
| 56 void Translator::nameUnnamedGlobalAddresses(llvm::Module *Mod) { | 57 void Translator::nameUnnamedGlobalAddresses(llvm::Module *Mod) { |
| 57 const IceString &GlobalPrefix = Flags.DefaultGlobalPrefix; | 58 const IceString &GlobalPrefix = Flags.DefaultGlobalPrefix; |
| 58 Ostream &errs = Ctx->getStrDump(); | 59 if (GlobalPrefix.empty()) |
| 59 if (!GlobalPrefix.empty()) { | 60 return; |
| 60 uint32_t NameIndex = 0; | 61 uint32_t NameIndex = 0; |
| 61 for (llvm::Module::global_iterator I = Mod->global_begin(), | 62 for (auto V = Mod->global_begin(), E = Mod->global_end(); V != E; ++V) { |
| 62 E = Mod->global_end(); | 63 if (!V->hasName()) { |
| 63 I != E; ++I) { | 64 V->setName(createUnnamedName(GlobalPrefix, NameIndex)); |
| 64 setValueName(I, "global", GlobalPrefix, NameIndex, errs); | 65 ++NameIndex; |
| 66 } else { |
| 67 checkIfUnnamedNameSafe(V->getName(), "global", GlobalPrefix, |
| 68 Ctx->getStrDump()); |
| 65 } | 69 } |
| 66 } | 70 } |
| 71 } |
| 72 |
| 73 void Translator::nameUnnamedFunctions(llvm::Module *Mod) { |
| 67 const IceString &FunctionPrefix = Flags.DefaultFunctionPrefix; | 74 const IceString &FunctionPrefix = Flags.DefaultFunctionPrefix; |
| 68 if (FunctionPrefix.empty()) | 75 if (FunctionPrefix.empty()) |
| 69 return; | 76 return; |
| 70 uint32_t NameIndex = 0; | 77 uint32_t NameIndex = 0; |
| 71 for (llvm::Module::iterator I = Mod->begin(), E = Mod->end(); I != E; ++I) { | 78 for (llvm::Function &F : *Mod) { |
| 72 setValueName(I, "function", FunctionPrefix, NameIndex, errs); | 79 if (!F.hasName()) { |
| 80 F.setName(createUnnamedName(FunctionPrefix, NameIndex)); |
| 81 ++NameIndex; |
| 82 } else { |
| 83 checkIfUnnamedNameSafe(F.getName(), "function", FunctionPrefix, |
| 84 Ctx->getStrDump()); |
| 85 } |
| 73 } | 86 } |
| 74 } | 87 } |
| 75 | 88 |
| 76 void Translator::translateFcn(Cfg *Fcn) { | 89 void Translator::translateFcn(Cfg *Fcn) { |
| 77 Ctx->resetStats(); | 90 Ctx->resetStats(); |
| 78 Func.reset(Fcn); | 91 Func.reset(Fcn); |
| 79 if (Ctx->getFlags().DisableInternal) | 92 if (Ctx->getFlags().DisableInternal) |
| 80 Func->setInternal(false); | 93 Func->setInternal(false); |
| 81 if (Ctx->getFlags().DisableTranslation) { | 94 if (Ctx->getFlags().DisableTranslation) { |
| 82 Func->dump(); | 95 Func->dump(); |
| 83 } else { | 96 } else { |
| 84 Func->translate(); | 97 Func->translate(); |
| 85 if (Func->hasError()) { | 98 if (Func->hasError()) { |
| 86 std::cerr << "ICE translation error: " << Func->getError() << "\n"; | 99 std::cerr << "ICE translation error: " << Func->getError() << "\n"; |
| 87 ErrorStatus = true; | 100 ErrorStatus = true; |
| 88 } | 101 } |
| 89 | 102 |
| 90 Func->emit(); | 103 Func->emit(); |
| 91 Ctx->dumpStats(Func->getFunctionName()); | 104 Ctx->dumpStats(Func->getFunctionName()); |
| 92 } | 105 } |
| 93 } | 106 } |
| 94 | 107 |
| 95 void Translator::emitConstants() { | 108 void Translator::emitConstants() { |
| 96 if (!Ctx->getFlags().DisableTranslation && Func) | 109 if (!Ctx->getFlags().DisableTranslation && Func) |
| 97 Func->getTarget()->emitConstants(); | 110 Func->getTarget()->emitConstants(); |
| 98 } | 111 } |
| 99 | 112 |
| 100 void Translator::convertGlobals(llvm::Module *Mod) { | 113 void Translator::lowerIceGlobals( |
| 101 std::unique_ptr<TargetGlobalInitLowering> GlobalLowering( | 114 const std::vector<Ice::GlobalAddress *> &GlobalAddresses) { |
| 102 TargetGlobalInitLowering::createLowering(Ctx->getTargetArch(), Ctx)); | 115 llvm::OwningPtr<Ice::TargetGlobalInitLowering> GlobalLowering( |
| 103 for (llvm::Module::const_global_iterator I = Mod->global_begin(), | 116 Ice::TargetGlobalInitLowering::createLowering(Ctx->getTargetArch(), Ctx)); |
| 104 E = Mod->global_end(); | 117 bool DisableTranslation = Ctx->getFlags().DisableTranslation; |
| 105 I != E; ++I) { | 118 for (const Ice::GlobalAddress *Addr : GlobalAddresses) { |
| 106 if (!I->hasInitializer()) | 119 GlobalLowering->lower(*Addr, DisableTranslation); |
| 107 continue; | |
| 108 const llvm::Constant *Initializer = I->getInitializer(); | |
| 109 IceString Name = I->getName(); | |
| 110 unsigned Align = I->getAlignment(); | |
| 111 uint64_t NumElements = 0; | |
| 112 const char *Data = NULL; | |
| 113 bool IsInternal = I->hasInternalLinkage(); | |
| 114 bool IsConst = I->isConstant(); | |
| 115 bool IsZeroInitializer = false; | |
| 116 | |
| 117 if (const llvm::ConstantDataArray *CDA = | |
| 118 llvm::dyn_cast<llvm::ConstantDataArray>(Initializer)) { | |
| 119 NumElements = CDA->getNumElements(); | |
| 120 assert(llvm::isa<llvm::IntegerType>(CDA->getElementType()) && | |
| 121 (llvm::cast<llvm::IntegerType>(CDA->getElementType()) | |
| 122 ->getBitWidth() == 8)); | |
| 123 Data = CDA->getRawDataValues().data(); | |
| 124 } else if (llvm::isa<llvm::ConstantAggregateZero>(Initializer)) { | |
| 125 if (const llvm::ArrayType *AT = | |
| 126 llvm::dyn_cast<llvm::ArrayType>(Initializer->getType())) { | |
| 127 assert(llvm::isa<llvm::IntegerType>(AT->getElementType()) && | |
| 128 (llvm::cast<llvm::IntegerType>(AT->getElementType()) | |
| 129 ->getBitWidth() == 8)); | |
| 130 NumElements = AT->getNumElements(); | |
| 131 IsZeroInitializer = true; | |
| 132 } else { | |
| 133 llvm_unreachable("Unhandled constant aggregate zero type"); | |
| 134 } | |
| 135 } else { | |
| 136 llvm_unreachable("Unhandled global initializer"); | |
| 137 } | |
| 138 | |
| 139 GlobalLowering->lower(Name, Align, IsInternal, IsConst, IsZeroInitializer, | |
| 140 NumElements, Data, | |
| 141 Ctx->getFlags().DisableTranslation); | |
| 142 } | 120 } |
| 143 GlobalLowering.reset(); | 121 GlobalLowering.reset(); |
| 144 } | 122 } |
| OLD | NEW |