| 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 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 64 const IceString &FunctionPrefix = Flags.DefaultFunctionPrefix; | 64 const IceString &FunctionPrefix = Flags.DefaultFunctionPrefix; |
| 65 if (FunctionPrefix.empty()) | 65 if (FunctionPrefix.empty()) |
| 66 return; | 66 return; |
| 67 uint32_t NameIndex = 0; | 67 uint32_t NameIndex = 0; |
| 68 for (llvm::Module::iterator I = Mod->begin(), E = Mod->end(); I != E; ++I) { | 68 for (llvm::Module::iterator I = Mod->begin(), E = Mod->end(); I != E; ++I) { |
| 69 setValueName(I, "function", FunctionPrefix, NameIndex, errs); | 69 setValueName(I, "function", FunctionPrefix, NameIndex, errs); |
| 70 } | 70 } |
| 71 } | 71 } |
| 72 | 72 |
| 73 void Translator::translateFcn(Cfg *Fcn) { | 73 void Translator::translateFcn(Cfg *Fcn) { |
| 74 Ctx->resetStats(); |
| 74 Func.reset(Fcn); | 75 Func.reset(Fcn); |
| 75 if (Ctx->getFlags().DisableInternal) | 76 if (Ctx->getFlags().DisableInternal) |
| 76 Func->setInternal(false); | 77 Func->setInternal(false); |
| 77 if (Ctx->getFlags().DisableTranslation) { | 78 if (Ctx->getFlags().DisableTranslation) { |
| 78 Func->dump(); | 79 Func->dump(); |
| 79 } else { | 80 } else { |
| 80 Timer TTranslate; | 81 Timer TTranslate; |
| 81 Func->translate(); | 82 Func->translate(); |
| 82 if (Ctx->getFlags().SubzeroTimingEnabled) { | 83 if (Ctx->getFlags().SubzeroTimingEnabled) { |
| 83 std::cerr << "[Subzero timing] Translate function " | 84 std::cerr << "[Subzero timing] Translate function " |
| 84 << Func->getFunctionName() << ": " << TTranslate.getElapsedSec() | 85 << Func->getFunctionName() << ": " << TTranslate.getElapsedSec() |
| 85 << " sec\n"; | 86 << " sec\n"; |
| 86 } | 87 } |
| 87 if (Func->hasError()) { | 88 if (Func->hasError()) { |
| 88 std::cerr << "ICE translation error: " << Func->getError() << "\n"; | 89 std::cerr << "ICE translation error: " << Func->getError() << "\n"; |
| 89 ErrorStatus = true; | 90 ErrorStatus = true; |
| 90 } | 91 } |
| 91 | 92 |
| 92 Timer TEmit; | 93 Timer TEmit; |
| 93 Func->emit(); | 94 Func->emit(); |
| 94 if (Ctx->getFlags().SubzeroTimingEnabled) { | 95 if (Ctx->getFlags().SubzeroTimingEnabled) { |
| 95 std::cerr << "[Subzero timing] Emit function " << Func->getFunctionName() | 96 std::cerr << "[Subzero timing] Emit function " << Func->getFunctionName() |
| 96 << ": " << TEmit.getElapsedSec() << " sec\n"; | 97 << ": " << TEmit.getElapsedSec() << " sec\n"; |
| 97 } | 98 } |
| 99 Ctx->dumpStats(Func->getFunctionName()); |
| 98 } | 100 } |
| 99 } | 101 } |
| 100 | 102 |
| 101 void Translator::emitConstants() { | 103 void Translator::emitConstants() { |
| 102 if (!Ctx->getFlags().DisableTranslation && Func) | 104 if (!Ctx->getFlags().DisableTranslation && Func) |
| 103 Func->getTarget()->emitConstants(); | 105 Func->getTarget()->emitConstants(); |
| 104 } | 106 } |
| OLD | NEW |