Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(147)

Side by Side Diff: src/IceTranslator.cpp

Issue 624663002: Introduce model of global initializers in Subzero. (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: Fix nits. Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/IceTranslator.h ('k') | src/IceTypeConverter.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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;
59 if (GlobalPrefix.empty())
60 return;
61 uint32_t NameIndex = 0;
58 Ostream &errs = Ctx->getStrDump(); 62 Ostream &errs = Ctx->getStrDump();
59 if (!GlobalPrefix.empty()) { 63 for (auto V = Mod->global_begin(), E = Mod->global_end(); V != E; ++V) {
60 uint32_t NameIndex = 0; 64 if (!V->hasName()) {
61 for (auto I = Mod->global_begin(), E = Mod->global_end(); I != E; ++I) 65 V->setName(createUnnamedName(GlobalPrefix, NameIndex));
62 setValueName(I, "global", GlobalPrefix, NameIndex, errs); 66 ++NameIndex;
67 } else {
68 checkIfUnnamedNameSafe(V->getName(), "global", GlobalPrefix, errs);
69 }
63 } 70 }
71 }
72
73 void Translator::nameUnnamedFunctions(llvm::Module *Mod) {
64 const IceString &FunctionPrefix = Flags.DefaultFunctionPrefix; 74 const IceString &FunctionPrefix = Flags.DefaultFunctionPrefix;
65 if (FunctionPrefix.empty()) 75 if (FunctionPrefix.empty())
66 return; 76 return;
67 uint32_t NameIndex = 0; 77 uint32_t NameIndex = 0;
68 for (llvm::Function &I : *Mod) 78 Ostream &errs = Ctx->getStrDump();
69 setValueName(&I, "function", FunctionPrefix, NameIndex, errs); 79 for (llvm::Function &F : *Mod) {
80 if (!F.hasName()) {
81 F.setName(createUnnamedName(FunctionPrefix, NameIndex));
82 ++NameIndex;
83 } else {
84 checkIfUnnamedNameSafe(F.getName(), "function", FunctionPrefix, errs);
85 }
86 }
70 } 87 }
71 88
72 void Translator::translateFcn(Cfg *Fcn) { 89 void Translator::translateFcn(Cfg *Fcn) {
73 Ctx->resetStats(); 90 Ctx->resetStats();
74 Func.reset(Fcn); 91 Func.reset(Fcn);
75 if (Ctx->getFlags().DisableInternal) 92 if (Ctx->getFlags().DisableInternal)
76 Func->setInternal(false); 93 Func->setInternal(false);
77 if (Ctx->getFlags().DisableTranslation) { 94 if (Ctx->getFlags().DisableTranslation) {
78 Func->dump(); 95 Func->dump();
79 } else { 96 } else {
80 Func->translate(); 97 Func->translate();
81 if (Func->hasError()) { 98 if (Func->hasError()) {
82 std::cerr << "ICE translation error: " << Func->getError() << "\n"; 99 std::cerr << "ICE translation error: " << Func->getError() << "\n";
83 ErrorStatus = true; 100 ErrorStatus = true;
84 } 101 }
85 102
86 Func->emit(); 103 Func->emit();
87 Ctx->dumpStats(Func->getFunctionName()); 104 Ctx->dumpStats(Func->getFunctionName());
88 } 105 }
89 } 106 }
90 107
91 void Translator::emitConstants() { 108 void Translator::emitConstants() {
92 if (!Ctx->getFlags().DisableTranslation && Func) 109 if (!Ctx->getFlags().DisableTranslation && Func)
93 Func->getTarget()->emitConstants(); 110 Func->getTarget()->emitConstants();
94 } 111 }
95 112
96 void Translator::convertGlobals(llvm::Module *Mod) { 113 void Translator::lowerGlobals(const GlobalAddressList &GlobalAddresses) {
97 std::unique_ptr<TargetGlobalInitLowering> GlobalLowering( 114 llvm::OwningPtr<Ice::TargetGlobalInitLowering> GlobalLowering(
98 TargetGlobalInitLowering::createLowering(Ctx->getTargetArch(), Ctx)); 115 Ice::TargetGlobalInitLowering::createLowering(Ctx->getTargetArch(), Ctx));
99 for (auto I = Mod->global_begin(), E = Mod->global_end(); I != E; ++I) { 116 bool DisableTranslation = Ctx->getFlags().DisableTranslation;
100 if (!I->hasInitializer()) 117 for (const Ice::GlobalAddress *Addr : GlobalAddresses) {
101 continue; 118 GlobalLowering->lower(*Addr, DisableTranslation);
102 const llvm::Constant *Initializer = I->getInitializer();
103 IceString Name = I->getName();
104 unsigned Align = I->getAlignment();
105 uint64_t NumElements = 0;
106 const char *Data = NULL;
107 bool IsInternal = I->hasInternalLinkage();
108 bool IsConst = I->isConstant();
109 bool IsZeroInitializer = false;
110
111 if (const llvm::ConstantDataArray *CDA =
112 llvm::dyn_cast<llvm::ConstantDataArray>(Initializer)) {
113 NumElements = CDA->getNumElements();
114 assert(llvm::isa<llvm::IntegerType>(CDA->getElementType()) &&
115 (llvm::cast<llvm::IntegerType>(CDA->getElementType())
116 ->getBitWidth() == 8));
117 Data = CDA->getRawDataValues().data();
118 } else if (llvm::isa<llvm::ConstantAggregateZero>(Initializer)) {
119 if (const llvm::ArrayType *AT =
120 llvm::dyn_cast<llvm::ArrayType>(Initializer->getType())) {
121 assert(llvm::isa<llvm::IntegerType>(AT->getElementType()) &&
122 (llvm::cast<llvm::IntegerType>(AT->getElementType())
123 ->getBitWidth() == 8));
124 NumElements = AT->getNumElements();
125 IsZeroInitializer = true;
126 } else {
127 llvm_unreachable("Unhandled constant aggregate zero type");
128 }
129 } else {
130 llvm_unreachable("Unhandled global initializer");
131 }
132
133 GlobalLowering->lower(Name, Align, IsInternal, IsConst, IsZeroInitializer,
134 NumElements, Data,
135 Ctx->getFlags().DisableTranslation);
136 } 119 }
137 GlobalLowering.reset(); 120 GlobalLowering.reset();
138 } 121 }
OLDNEW
« no previous file with comments | « src/IceTranslator.h ('k') | src/IceTypeConverter.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698