OLD | NEW |
1 //===- subzero/src/IceGlobalContext.cpp - Global context defs -------------===// | 1 //===- subzero/src/IceGlobalContext.cpp - Global context defs -------------===// |
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 aspects of the compilation that persist across | 10 // This file defines aspects of the compilation that persist across |
(...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
153 newTimerStackID("Total across all functions"); | 153 newTimerStackID("Total across all functions"); |
154 newTimerStackID("Per-function summary"); | 154 newTimerStackID("Per-function summary"); |
155 } | 155 } |
156 Timers.initInto(MyTLS->Timers); | 156 Timers.initInto(MyTLS->Timers); |
157 if (Flags.UseELFWriter) { | 157 if (Flags.UseELFWriter) { |
158 ObjectWriter.reset(new ELFObjectWriter(*this, *ELFStr)); | 158 ObjectWriter.reset(new ELFObjectWriter(*this, *ELFStr)); |
159 } | 159 } |
160 } | 160 } |
161 | 161 |
162 void GlobalContext::translateFunctions() { | 162 void GlobalContext::translateFunctions() { |
163 while (Cfg *Func = cfgQueueBlockingPop()) { | 163 while (std::unique_ptr<Cfg> Func = cfgQueueBlockingPop()) { |
| 164 // Install Func in TLS for Cfg-specific container allocators. |
| 165 Cfg::updateTLS(Func.get()); |
164 // Reset per-function stats being accumulated in TLS. | 166 // Reset per-function stats being accumulated in TLS. |
165 resetStats(); | 167 resetStats(); |
166 // Install Func in TLS for Cfg-specific container allocators. | |
167 Func->updateTLS(); | |
168 // Set verbose level to none if the current function does NOT | 168 // Set verbose level to none if the current function does NOT |
169 // match the -verbose-focus command-line option. | 169 // match the -verbose-focus command-line option. |
170 if (!matchSymbolName(Func->getFunctionName(), getFlags().VerboseFocusOn)) | 170 if (!matchSymbolName(Func->getFunctionName(), getFlags().VerboseFocusOn)) |
171 Func->setVerbose(IceV_None); | 171 Func->setVerbose(IceV_None); |
172 // Disable translation if -notranslate is specified, or if the | 172 // Disable translation if -notranslate is specified, or if the |
173 // current function matches the -translate-only option. If | 173 // current function matches the -translate-only option. If |
174 // translation is disabled, just dump the high-level IR and | 174 // translation is disabled, just dump the high-level IR and |
175 // continue. | 175 // continue. |
176 if (getFlags().DisableTranslation || | 176 if (getFlags().DisableTranslation || |
177 !matchSymbolName(Func->getFunctionName(), getFlags().TranslateOnly)) { | 177 !matchSymbolName(Func->getFunctionName(), getFlags().TranslateOnly)) { |
178 Func->dump(); | 178 Func->dump(); |
179 } else { | 179 } else { |
180 Func->translate(); | 180 Func->translate(); |
181 if (Func->hasError()) { | 181 if (Func->hasError()) { |
182 getErrorStatus()->assign(EC_Translation); | 182 getErrorStatus()->assign(EC_Translation); |
183 OstreamLocker L(this); | 183 OstreamLocker L(this); |
184 getStrDump() << "ICE translation error: " << Func->getError() << "\n"; | 184 getStrDump() << "ICE translation error: " << Func->getError() << "\n"; |
185 } else { | 185 } else { |
186 if (getFlags().UseIntegratedAssembler) | 186 if (getFlags().UseIntegratedAssembler) |
187 Func->emitIAS(); | 187 Func->emitIAS(); |
188 else | 188 else |
189 Func->emit(); | 189 Func->emit(); |
190 // TODO(stichnot): actually add to emit queue | 190 // TODO(stichnot): actually add to emit queue |
191 } | 191 } |
192 // TODO(stichnot): fix multithreaded stats dumping. | |
193 dumpStats(Func->getFunctionName()); | 192 dumpStats(Func->getFunctionName()); |
194 } | 193 } |
195 delete Func; | 194 // The Cfg now gets deleted as Func goes out of scope. This also |
| 195 // resets the thread-local CurrentCfg field. |
196 } | 196 } |
197 } | 197 } |
198 | 198 |
199 // Scan a string for S[0-9A-Z]*_ patterns and replace them with | 199 // Scan a string for S[0-9A-Z]*_ patterns and replace them with |
200 // S<num>_ where <num> is the next base-36 value. If a type name | 200 // S<num>_ where <num> is the next base-36 value. If a type name |
201 // legitimately contains that pattern, then the substitution will be | 201 // legitimately contains that pattern, then the substitution will be |
202 // made in error and most likely the link will fail. In this case, | 202 // made in error and most likely the link will fail. In this case, |
203 // the test classes can be rewritten not to use that pattern, which is | 203 // the test classes can be rewritten not to use that pattern, which is |
204 // much simpler and more reliable than implementing a full demangling | 204 // much simpler and more reliable than implementing a full demangling |
205 // parser. Another substitution-in-error may occur if a type | 205 // parser. Another substitution-in-error may occur if a type |
(...skipping 322 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
528 Timers->at(StackID).reset(); | 528 Timers->at(StackID).reset(); |
529 } | 529 } |
530 | 530 |
531 void GlobalContext::setTimerName(TimerStackIdT StackID, | 531 void GlobalContext::setTimerName(TimerStackIdT StackID, |
532 const IceString &NewName) { | 532 const IceString &NewName) { |
533 auto Timers = &ICE_TLS_GET_FIELD(TLS)->Timers; | 533 auto Timers = &ICE_TLS_GET_FIELD(TLS)->Timers; |
534 assert(StackID < Timers->size()); | 534 assert(StackID < Timers->size()); |
535 Timers->at(StackID).setName(NewName); | 535 Timers->at(StackID).setName(NewName); |
536 } | 536 } |
537 | 537 |
| 538 std::unique_ptr<Cfg> GlobalContext::cfgQueueBlockingPop() { |
| 539 return std::unique_ptr<Cfg>(CfgQ.blockingPop()); |
| 540 } |
| 541 |
538 void GlobalContext::dumpStats(const IceString &Name, bool Final) { | 542 void GlobalContext::dumpStats(const IceString &Name, bool Final) { |
539 if (!ALLOW_DUMP || !getFlags().DumpStats) | 543 if (!ALLOW_DUMP || !getFlags().DumpStats) |
540 return; | 544 return; |
541 OstreamLocker OL(this); | 545 OstreamLocker OL(this); |
542 if (Final) { | 546 if (Final) { |
543 getStatsCumulative()->dump(Name, getStrDump()); | 547 getStatsCumulative()->dump(Name, getStrDump()); |
544 } else { | 548 } else { |
545 ICE_TLS_GET_FIELD(TLS)->StatsFunction.dump(Name, getStrDump()); | 549 ICE_TLS_GET_FIELD(TLS)->StatsFunction.dump(Name, getStrDump()); |
546 } | 550 } |
547 } | 551 } |
(...skipping 25 matching lines...) Expand all Loading... |
573 void TimerMarker::pushCfg(const Cfg *Func) { | 577 void TimerMarker::pushCfg(const Cfg *Func) { |
574 Ctx = Func->getContext(); | 578 Ctx = Func->getContext(); |
575 Active = Func->getFocusedTiming() || Ctx->getFlags().SubzeroTimingEnabled; | 579 Active = Func->getFocusedTiming() || Ctx->getFlags().SubzeroTimingEnabled; |
576 if (Active) | 580 if (Active) |
577 Ctx->pushTimer(ID, StackID); | 581 Ctx->pushTimer(ID, StackID); |
578 } | 582 } |
579 | 583 |
580 ICE_TLS_DEFINE_FIELD(GlobalContext::ThreadContext *, GlobalContext, TLS); | 584 ICE_TLS_DEFINE_FIELD(GlobalContext::ThreadContext *, GlobalContext, TLS); |
581 | 585 |
582 } // end of namespace Ice | 586 } // end of namespace Ice |
OLD | NEW |