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

Side by Side Diff: src/IceConverter.cpp

Issue 892063002: Subzero: Manage each Cfg as a std::unique_ptr<Cfg>. (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: Commit fix + rebase Created 5 years, 10 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/IceCfg.cpp ('k') | src/IceDefs.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/IceConverter.cpp - Converts LLVM to Ice ---------------===// 1 //===- subzero/src/IceConverter.cpp - Converts LLVM to Ice ---------------===//
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 implements the LLVM to ICE converter. 10 // This file implements the LLVM to ICE converter.
(...skipping 30 matching lines...) Expand all
41 41
42 // Debugging helper 42 // Debugging helper
43 template <typename T> static std::string LLVMObjectAsString(const T *O) { 43 template <typename T> static std::string LLVMObjectAsString(const T *O) {
44 std::string Dump; 44 std::string Dump;
45 raw_string_ostream Stream(Dump); 45 raw_string_ostream Stream(Dump);
46 O->print(Stream); 46 O->print(Stream);
47 return Stream.str(); 47 return Stream.str();
48 } 48 }
49 49
50 // Base class for converting LLVM to ICE. 50 // Base class for converting LLVM to ICE.
51 // TODO(stichnot): Redesign Converter, LLVM2ICEConverter,
52 // LLVM2ICEFunctionConverter, and LLVM2ICEGlobalsConverter with
53 // respect to Translator. In particular, the unique_ptr ownership
54 // rules in LLVM2ICEFunctionConverter.
51 class LLVM2ICEConverter { 55 class LLVM2ICEConverter {
52 LLVM2ICEConverter(const LLVM2ICEConverter &) = delete; 56 LLVM2ICEConverter(const LLVM2ICEConverter &) = delete;
53 LLVM2ICEConverter &operator=(const LLVM2ICEConverter &) = delete; 57 LLVM2ICEConverter &operator=(const LLVM2ICEConverter &) = delete;
54 58
55 public: 59 public:
56 LLVM2ICEConverter(Ice::Converter &Converter) 60 LLVM2ICEConverter(Ice::Converter &Converter)
57 : Converter(Converter), Ctx(Converter.getContext()), 61 : Converter(Converter), Ctx(Converter.getContext()),
58 TypeConverter(Converter.getModule()->getContext()) {} 62 TypeConverter(Converter.getModule()->getContext()) {}
59 63
60 Ice::Converter &getConverter() const { return Converter; } 64 Ice::Converter &getConverter() const { return Converter; }
(...skipping 11 matching lines...) Expand all
72 // valid PNaCl bitcode. Otherwise, the behavior is undefined. 76 // valid PNaCl bitcode. Otherwise, the behavior is undefined.
73 class LLVM2ICEFunctionConverter : LLVM2ICEConverter { 77 class LLVM2ICEFunctionConverter : LLVM2ICEConverter {
74 LLVM2ICEFunctionConverter(const LLVM2ICEFunctionConverter &) = delete; 78 LLVM2ICEFunctionConverter(const LLVM2ICEFunctionConverter &) = delete;
75 LLVM2ICEFunctionConverter & 79 LLVM2ICEFunctionConverter &
76 operator=(const LLVM2ICEFunctionConverter &) = delete; 80 operator=(const LLVM2ICEFunctionConverter &) = delete;
77 81
78 public: 82 public:
79 LLVM2ICEFunctionConverter(Ice::Converter &Converter) 83 LLVM2ICEFunctionConverter(Ice::Converter &Converter)
80 : LLVM2ICEConverter(Converter), Func(nullptr) {} 84 : LLVM2ICEConverter(Converter), Func(nullptr) {}
81 85
82 // Caller is expected to delete the returned Ice::Cfg object. 86 void convertFunction(const Function *F) {
83 Ice::Cfg *convertFunction(const Function *F) { 87 Func = Ice::Cfg::create(Ctx);
88 Ice::Cfg::setCurrentCfg(Func.get());
89
84 VarMap.clear(); 90 VarMap.clear();
85 NodeMap.clear(); 91 NodeMap.clear();
86 Func = Ice::Cfg::create(Ctx);
87 Func->setFunctionName(F->getName()); 92 Func->setFunctionName(F->getName());
88 Func->setReturnType(convertToIceType(F->getReturnType())); 93 Func->setReturnType(convertToIceType(F->getReturnType()));
89 Func->setInternal(F->hasInternalLinkage()); 94 Func->setInternal(F->hasInternalLinkage());
90 Ice::TimerMarker T(Ice::TimerStack::TT_llvmConvert, Func); 95 Ice::TimerMarker T(Ice::TimerStack::TT_llvmConvert, Func.get());
91 96
92 // The initial definition/use of each arg is the entry node. 97 // The initial definition/use of each arg is the entry node.
93 for (auto ArgI = F->arg_begin(), ArgE = F->arg_end(); ArgI != ArgE; 98 for (auto ArgI = F->arg_begin(), ArgE = F->arg_end(); ArgI != ArgE;
94 ++ArgI) { 99 ++ArgI) {
95 Func->addArg(mapValueToIceVar(ArgI)); 100 Func->addArg(mapValueToIceVar(ArgI));
96 } 101 }
97 102
98 // Make an initial pass through the block list just to resolve the 103 // Make an initial pass through the block list just to resolve the
99 // blocks in the original linearized order. Otherwise the ICE 104 // blocks in the original linearized order. Otherwise the ICE
100 // linearized order will be affected by branch targets in 105 // linearized order will be affected by branch targets in
101 // terminator instructions. 106 // terminator instructions.
102 for (const BasicBlock &BBI : *F) 107 for (const BasicBlock &BBI : *F)
103 mapBasicBlockToNode(&BBI); 108 mapBasicBlockToNode(&BBI);
104 for (const BasicBlock &BBI : *F) 109 for (const BasicBlock &BBI : *F)
105 convertBasicBlock(&BBI); 110 convertBasicBlock(&BBI);
106 Func->setEntryNode(mapBasicBlockToNode(&F->getEntryBlock())); 111 Func->setEntryNode(mapBasicBlockToNode(&F->getEntryBlock()));
107 Func->computePredecessors(); 112 Func->computePredecessors();
108 113
109 return Func; 114 Ice::Cfg::setCurrentCfg(nullptr);
115 Converter.translateFcn(std::move(Func));
110 } 116 }
111 117
112 // convertConstant() does not use Func or require it to be a valid 118 // convertConstant() does not use Func or require it to be a valid
113 // Ice::Cfg pointer. As such, it's suitable for e.g. constructing 119 // Ice::Cfg pointer. As such, it's suitable for e.g. constructing
114 // global initializers. 120 // global initializers.
115 Ice::Constant *convertConstant(const Constant *Const) { 121 Ice::Constant *convertConstant(const Constant *Const) {
116 if (const auto GV = dyn_cast<GlobalValue>(Const)) { 122 if (const auto GV = dyn_cast<GlobalValue>(Const)) {
117 Ice::GlobalDeclaration *Decl = getConverter().getGlobalDeclaration(GV); 123 Ice::GlobalDeclaration *Decl = getConverter().getGlobalDeclaration(GV);
118 const Ice::RelocOffsetT Offset = 0; 124 const Ice::RelocOffsetT Offset = 0;
119 return Ctx->getConstantSym(Offset, Decl->getName(), 125 return Ctx->getConstantSym(Offset, Decl->getName(),
(...skipping 20 matching lines...) Expand all
140 private: 146 private:
141 // LLVM values (instructions, etc.) are mapped directly to ICE variables. 147 // LLVM values (instructions, etc.) are mapped directly to ICE variables.
142 // mapValueToIceVar has a version that forces an ICE type on the variable, 148 // mapValueToIceVar has a version that forces an ICE type on the variable,
143 // and a version that just uses convertToIceType on V. 149 // and a version that just uses convertToIceType on V.
144 Ice::Variable *mapValueToIceVar(const Value *V, Ice::Type IceTy) { 150 Ice::Variable *mapValueToIceVar(const Value *V, Ice::Type IceTy) {
145 if (IceTy == Ice::IceType_void) 151 if (IceTy == Ice::IceType_void)
146 return nullptr; 152 return nullptr;
147 if (VarMap.find(V) == VarMap.end()) { 153 if (VarMap.find(V) == VarMap.end()) {
148 VarMap[V] = Func->makeVariable(IceTy); 154 VarMap[V] = Func->makeVariable(IceTy);
149 if (ALLOW_DUMP) 155 if (ALLOW_DUMP)
150 VarMap[V]->setName(Func, V->getName()); 156 VarMap[V]->setName(Func.get(), V->getName());
151 } 157 }
152 return VarMap[V]; 158 return VarMap[V];
153 } 159 }
154 160
155 Ice::Variable *mapValueToIceVar(const Value *V) { 161 Ice::Variable *mapValueToIceVar(const Value *V) {
156 return mapValueToIceVar(V, convertToIceType(V->getType())); 162 return mapValueToIceVar(V, convertToIceType(V->getType()));
157 } 163 }
158 164
159 Ice::CfgNode *mapBasicBlockToNode(const BasicBlock *BB) { 165 Ice::CfgNode *mapBasicBlockToNode(const BasicBlock *BB) {
160 if (NodeMap.find(BB) == NodeMap.end()) { 166 if (NodeMap.find(BB) == NodeMap.end()) {
(...skipping 136 matching lines...) Expand 10 before | Expand all | Expand 10 after
297 LLVMObjectAsString(Inst)); 303 LLVMObjectAsString(Inst));
298 } 304 }
299 305
300 llvm_unreachable("convertInstruction"); 306 llvm_unreachable("convertInstruction");
301 return nullptr; 307 return nullptr;
302 } 308 }
303 309
304 Ice::Inst *convertLoadInstruction(const LoadInst *Inst) { 310 Ice::Inst *convertLoadInstruction(const LoadInst *Inst) {
305 Ice::Operand *Src = convertOperand(Inst, 0); 311 Ice::Operand *Src = convertOperand(Inst, 0);
306 Ice::Variable *Dest = mapValueToIceVar(Inst); 312 Ice::Variable *Dest = mapValueToIceVar(Inst);
307 return Ice::InstLoad::create(Func, Dest, Src); 313 return Ice::InstLoad::create(Func.get(), Dest, Src);
308 } 314 }
309 315
310 Ice::Inst *convertStoreInstruction(const StoreInst *Inst) { 316 Ice::Inst *convertStoreInstruction(const StoreInst *Inst) {
311 Ice::Operand *Addr = convertOperand(Inst, 1); 317 Ice::Operand *Addr = convertOperand(Inst, 1);
312 Ice::Operand *Val = convertOperand(Inst, 0); 318 Ice::Operand *Val = convertOperand(Inst, 0);
313 return Ice::InstStore::create(Func, Val, Addr); 319 return Ice::InstStore::create(Func.get(), Val, Addr);
314 } 320 }
315 321
316 Ice::Inst *convertArithInstruction(const Instruction *Inst, 322 Ice::Inst *convertArithInstruction(const Instruction *Inst,
317 Ice::InstArithmetic::OpKind Opcode) { 323 Ice::InstArithmetic::OpKind Opcode) {
318 const auto BinOp = cast<BinaryOperator>(Inst); 324 const auto BinOp = cast<BinaryOperator>(Inst);
319 Ice::Operand *Src0 = convertOperand(Inst, 0); 325 Ice::Operand *Src0 = convertOperand(Inst, 0);
320 Ice::Operand *Src1 = convertOperand(Inst, 1); 326 Ice::Operand *Src1 = convertOperand(Inst, 1);
321 Ice::Variable *Dest = mapValueToIceVar(BinOp); 327 Ice::Variable *Dest = mapValueToIceVar(BinOp);
322 return Ice::InstArithmetic::create(Func, Opcode, Dest, Src0, Src1); 328 return Ice::InstArithmetic::create(Func.get(), Opcode, Dest, Src0, Src1);
323 } 329 }
324 330
325 Ice::Inst *convertPHINodeInstruction(const PHINode *Inst) { 331 Ice::Inst *convertPHINodeInstruction(const PHINode *Inst) {
326 unsigned NumValues = Inst->getNumIncomingValues(); 332 unsigned NumValues = Inst->getNumIncomingValues();
327 Ice::InstPhi *IcePhi = 333 Ice::InstPhi *IcePhi =
328 Ice::InstPhi::create(Func, NumValues, mapValueToIceVar(Inst)); 334 Ice::InstPhi::create(Func.get(), NumValues, mapValueToIceVar(Inst));
329 for (unsigned N = 0, E = NumValues; N != E; ++N) { 335 for (unsigned N = 0, E = NumValues; N != E; ++N) {
330 IcePhi->addArgument(convertOperand(Inst, N), 336 IcePhi->addArgument(convertOperand(Inst, N),
331 mapBasicBlockToNode(Inst->getIncomingBlock(N))); 337 mapBasicBlockToNode(Inst->getIncomingBlock(N)));
332 } 338 }
333 return IcePhi; 339 return IcePhi;
334 } 340 }
335 341
336 Ice::Inst *convertBrInstruction(const BranchInst *Inst) { 342 Ice::Inst *convertBrInstruction(const BranchInst *Inst) {
337 if (Inst->isConditional()) { 343 if (Inst->isConditional()) {
338 Ice::Operand *Src = convertOperand(Inst, 0); 344 Ice::Operand *Src = convertOperand(Inst, 0);
339 BasicBlock *BBThen = Inst->getSuccessor(0); 345 BasicBlock *BBThen = Inst->getSuccessor(0);
340 BasicBlock *BBElse = Inst->getSuccessor(1); 346 BasicBlock *BBElse = Inst->getSuccessor(1);
341 Ice::CfgNode *NodeThen = mapBasicBlockToNode(BBThen); 347 Ice::CfgNode *NodeThen = mapBasicBlockToNode(BBThen);
342 Ice::CfgNode *NodeElse = mapBasicBlockToNode(BBElse); 348 Ice::CfgNode *NodeElse = mapBasicBlockToNode(BBElse);
343 return Ice::InstBr::create(Func, Src, NodeThen, NodeElse); 349 return Ice::InstBr::create(Func.get(), Src, NodeThen, NodeElse);
344 } else { 350 } else {
345 BasicBlock *BBSucc = Inst->getSuccessor(0); 351 BasicBlock *BBSucc = Inst->getSuccessor(0);
346 return Ice::InstBr::create(Func, mapBasicBlockToNode(BBSucc)); 352 return Ice::InstBr::create(Func.get(), mapBasicBlockToNode(BBSucc));
347 } 353 }
348 } 354 }
349 355
350 Ice::Inst *convertIntToPtrInstruction(const IntToPtrInst *Inst) { 356 Ice::Inst *convertIntToPtrInstruction(const IntToPtrInst *Inst) {
351 Ice::Operand *Src = convertOperand(Inst, 0); 357 Ice::Operand *Src = convertOperand(Inst, 0);
352 Ice::Variable *Dest = mapValueToIceVar(Inst, Ice::getPointerType()); 358 Ice::Variable *Dest = mapValueToIceVar(Inst, Ice::getPointerType());
353 return Ice::InstAssign::create(Func, Dest, Src); 359 return Ice::InstAssign::create(Func.get(), Dest, Src);
354 } 360 }
355 361
356 Ice::Inst *convertPtrToIntInstruction(const PtrToIntInst *Inst) { 362 Ice::Inst *convertPtrToIntInstruction(const PtrToIntInst *Inst) {
357 Ice::Operand *Src = convertOperand(Inst, 0); 363 Ice::Operand *Src = convertOperand(Inst, 0);
358 Ice::Variable *Dest = mapValueToIceVar(Inst); 364 Ice::Variable *Dest = mapValueToIceVar(Inst);
359 return Ice::InstAssign::create(Func, Dest, Src); 365 return Ice::InstAssign::create(Func.get(), Dest, Src);
360 } 366 }
361 367
362 Ice::Inst *convertRetInstruction(const ReturnInst *Inst) { 368 Ice::Inst *convertRetInstruction(const ReturnInst *Inst) {
363 Ice::Operand *RetOperand = convertOperand(Inst, 0); 369 Ice::Operand *RetOperand = convertOperand(Inst, 0);
364 if (RetOperand) { 370 if (RetOperand) {
365 return Ice::InstRet::create(Func, RetOperand); 371 return Ice::InstRet::create(Func.get(), RetOperand);
366 } else { 372 } else {
367 return Ice::InstRet::create(Func); 373 return Ice::InstRet::create(Func.get());
368 } 374 }
369 } 375 }
370 376
371 Ice::Inst *convertCastInstruction(const Instruction *Inst, 377 Ice::Inst *convertCastInstruction(const Instruction *Inst,
372 Ice::InstCast::OpKind CastKind) { 378 Ice::InstCast::OpKind CastKind) {
373 Ice::Operand *Src = convertOperand(Inst, 0); 379 Ice::Operand *Src = convertOperand(Inst, 0);
374 Ice::Variable *Dest = mapValueToIceVar(Inst); 380 Ice::Variable *Dest = mapValueToIceVar(Inst);
375 return Ice::InstCast::create(Func, CastKind, Dest, Src); 381 return Ice::InstCast::create(Func.get(), CastKind, Dest, Src);
376 } 382 }
377 383
378 Ice::Inst *convertICmpInstruction(const ICmpInst *Inst) { 384 Ice::Inst *convertICmpInstruction(const ICmpInst *Inst) {
379 Ice::Operand *Src0 = convertOperand(Inst, 0); 385 Ice::Operand *Src0 = convertOperand(Inst, 0);
380 Ice::Operand *Src1 = convertOperand(Inst, 1); 386 Ice::Operand *Src1 = convertOperand(Inst, 1);
381 Ice::Variable *Dest = mapValueToIceVar(Inst); 387 Ice::Variable *Dest = mapValueToIceVar(Inst);
382 388
383 Ice::InstIcmp::ICond Cond; 389 Ice::InstIcmp::ICond Cond;
384 switch (Inst->getPredicate()) { 390 switch (Inst->getPredicate()) {
385 default: 391 default:
(...skipping 23 matching lines...) Expand all
409 Cond = Ice::InstIcmp::Sge; 415 Cond = Ice::InstIcmp::Sge;
410 break; 416 break;
411 case CmpInst::ICMP_SLT: 417 case CmpInst::ICMP_SLT:
412 Cond = Ice::InstIcmp::Slt; 418 Cond = Ice::InstIcmp::Slt;
413 break; 419 break;
414 case CmpInst::ICMP_SLE: 420 case CmpInst::ICMP_SLE:
415 Cond = Ice::InstIcmp::Sle; 421 Cond = Ice::InstIcmp::Sle;
416 break; 422 break;
417 } 423 }
418 424
419 return Ice::InstIcmp::create(Func, Cond, Dest, Src0, Src1); 425 return Ice::InstIcmp::create(Func.get(), Cond, Dest, Src0, Src1);
420 } 426 }
421 427
422 Ice::Inst *convertFCmpInstruction(const FCmpInst *Inst) { 428 Ice::Inst *convertFCmpInstruction(const FCmpInst *Inst) {
423 Ice::Operand *Src0 = convertOperand(Inst, 0); 429 Ice::Operand *Src0 = convertOperand(Inst, 0);
424 Ice::Operand *Src1 = convertOperand(Inst, 1); 430 Ice::Operand *Src1 = convertOperand(Inst, 1);
425 Ice::Variable *Dest = mapValueToIceVar(Inst); 431 Ice::Variable *Dest = mapValueToIceVar(Inst);
426 432
427 Ice::InstFcmp::FCond Cond; 433 Ice::InstFcmp::FCond Cond;
428 switch (Inst->getPredicate()) { 434 switch (Inst->getPredicate()) {
429 435
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after
473 Cond = Ice::InstFcmp::Une; 479 Cond = Ice::InstFcmp::Une;
474 break; 480 break;
475 case CmpInst::FCMP_UNO: 481 case CmpInst::FCMP_UNO:
476 Cond = Ice::InstFcmp::Uno; 482 Cond = Ice::InstFcmp::Uno;
477 break; 483 break;
478 case CmpInst::FCMP_TRUE: 484 case CmpInst::FCMP_TRUE:
479 Cond = Ice::InstFcmp::True; 485 Cond = Ice::InstFcmp::True;
480 break; 486 break;
481 } 487 }
482 488
483 return Ice::InstFcmp::create(Func, Cond, Dest, Src0, Src1); 489 return Ice::InstFcmp::create(Func.get(), Cond, Dest, Src0, Src1);
484 } 490 }
485 491
486 Ice::Inst *convertExtractElementInstruction(const ExtractElementInst *Inst) { 492 Ice::Inst *convertExtractElementInstruction(const ExtractElementInst *Inst) {
487 Ice::Variable *Dest = mapValueToIceVar(Inst); 493 Ice::Variable *Dest = mapValueToIceVar(Inst);
488 Ice::Operand *Source1 = convertValue(Inst->getOperand(0)); 494 Ice::Operand *Source1 = convertValue(Inst->getOperand(0));
489 Ice::Operand *Source2 = convertValue(Inst->getOperand(1)); 495 Ice::Operand *Source2 = convertValue(Inst->getOperand(1));
490 return Ice::InstExtractElement::create(Func, Dest, Source1, Source2); 496 return Ice::InstExtractElement::create(Func.get(), Dest, Source1, Source2);
491 } 497 }
492 498
493 Ice::Inst *convertInsertElementInstruction(const InsertElementInst *Inst) { 499 Ice::Inst *convertInsertElementInstruction(const InsertElementInst *Inst) {
494 Ice::Variable *Dest = mapValueToIceVar(Inst); 500 Ice::Variable *Dest = mapValueToIceVar(Inst);
495 Ice::Operand *Source1 = convertValue(Inst->getOperand(0)); 501 Ice::Operand *Source1 = convertValue(Inst->getOperand(0));
496 Ice::Operand *Source2 = convertValue(Inst->getOperand(1)); 502 Ice::Operand *Source2 = convertValue(Inst->getOperand(1));
497 Ice::Operand *Source3 = convertValue(Inst->getOperand(2)); 503 Ice::Operand *Source3 = convertValue(Inst->getOperand(2));
498 return Ice::InstInsertElement::create(Func, Dest, Source1, Source2, 504 return Ice::InstInsertElement::create(Func.get(), Dest, Source1, Source2,
499 Source3); 505 Source3);
500 } 506 }
501 507
502 Ice::Inst *convertSelectInstruction(const SelectInst *Inst) { 508 Ice::Inst *convertSelectInstruction(const SelectInst *Inst) {
503 Ice::Variable *Dest = mapValueToIceVar(Inst); 509 Ice::Variable *Dest = mapValueToIceVar(Inst);
504 Ice::Operand *Cond = convertValue(Inst->getCondition()); 510 Ice::Operand *Cond = convertValue(Inst->getCondition());
505 Ice::Operand *Source1 = convertValue(Inst->getTrueValue()); 511 Ice::Operand *Source1 = convertValue(Inst->getTrueValue());
506 Ice::Operand *Source2 = convertValue(Inst->getFalseValue()); 512 Ice::Operand *Source2 = convertValue(Inst->getFalseValue());
507 return Ice::InstSelect::create(Func, Dest, Cond, Source1, Source2); 513 return Ice::InstSelect::create(Func.get(), Dest, Cond, Source1, Source2);
508 } 514 }
509 515
510 Ice::Inst *convertSwitchInstruction(const SwitchInst *Inst) { 516 Ice::Inst *convertSwitchInstruction(const SwitchInst *Inst) {
511 Ice::Operand *Source = convertValue(Inst->getCondition()); 517 Ice::Operand *Source = convertValue(Inst->getCondition());
512 Ice::CfgNode *LabelDefault = mapBasicBlockToNode(Inst->getDefaultDest()); 518 Ice::CfgNode *LabelDefault = mapBasicBlockToNode(Inst->getDefaultDest());
513 unsigned NumCases = Inst->getNumCases(); 519 unsigned NumCases = Inst->getNumCases();
514 Ice::InstSwitch *Switch = 520 Ice::InstSwitch *Switch =
515 Ice::InstSwitch::create(Func, NumCases, Source, LabelDefault); 521 Ice::InstSwitch::create(Func.get(), NumCases, Source, LabelDefault);
516 unsigned CurrentCase = 0; 522 unsigned CurrentCase = 0;
517 for (SwitchInst::ConstCaseIt I = Inst->case_begin(), E = Inst->case_end(); 523 for (SwitchInst::ConstCaseIt I = Inst->case_begin(), E = Inst->case_end();
518 I != E; ++I, ++CurrentCase) { 524 I != E; ++I, ++CurrentCase) {
519 uint64_t CaseValue = I.getCaseValue()->getSExtValue(); 525 uint64_t CaseValue = I.getCaseValue()->getSExtValue();
520 Ice::CfgNode *CaseSuccessor = mapBasicBlockToNode(I.getCaseSuccessor()); 526 Ice::CfgNode *CaseSuccessor = mapBasicBlockToNode(I.getCaseSuccessor());
521 Switch->addBranch(CurrentCase, CaseValue, CaseSuccessor); 527 Switch->addBranch(CurrentCase, CaseValue, CaseSuccessor);
522 } 528 }
523 return Switch; 529 return Switch;
524 } 530 }
525 531
(...skipping 11 matching lines...) Expand all
537 static const char LLVMPrefix[] = "llvm."; 543 static const char LLVMPrefix[] = "llvm.";
538 const size_t LLVMPrefixLen = strlen(LLVMPrefix); 544 const size_t LLVMPrefixLen = strlen(LLVMPrefix);
539 Ice::IceString Name = Target->getName(); 545 Ice::IceString Name = Target->getName();
540 if (Name.substr(0, LLVMPrefixLen) == LLVMPrefix) { 546 if (Name.substr(0, LLVMPrefixLen) == LLVMPrefix) {
541 Ice::IceString NameSuffix = Name.substr(LLVMPrefixLen); 547 Ice::IceString NameSuffix = Name.substr(LLVMPrefixLen);
542 Info = Ctx->getIntrinsicsInfo().find(NameSuffix); 548 Info = Ctx->getIntrinsicsInfo().find(NameSuffix);
543 if (!Info) { 549 if (!Info) {
544 report_fatal_error(std::string("Invalid PNaCl intrinsic call: ") + 550 report_fatal_error(std::string("Invalid PNaCl intrinsic call: ") +
545 LLVMObjectAsString(Inst)); 551 LLVMObjectAsString(Inst));
546 } 552 }
547 NewInst = Ice::InstIntrinsicCall::create(Func, NumArgs, Dest, 553 NewInst = Ice::InstIntrinsicCall::create(Func.get(), NumArgs, Dest,
548 CallTarget, Info->Info); 554 CallTarget, Info->Info);
549 } 555 }
550 } 556 }
551 557
552 // Not an intrinsic call. 558 // Not an intrinsic call.
553 if (NewInst == nullptr) { 559 if (NewInst == nullptr) {
554 NewInst = Ice::InstCall::create(Func, NumArgs, Dest, CallTarget, 560 NewInst = Ice::InstCall::create(Func.get(), NumArgs, Dest, CallTarget,
555 Inst->isTailCall()); 561 Inst->isTailCall());
556 } 562 }
557 for (unsigned i = 0; i < NumArgs; ++i) { 563 for (unsigned i = 0; i < NumArgs; ++i) {
558 NewInst->addArg(convertOperand(Inst, i)); 564 NewInst->addArg(convertOperand(Inst, i));
559 } 565 }
560 if (Info) { 566 if (Info) {
561 validateIntrinsicCall(NewInst, Info); 567 validateIntrinsicCall(NewInst, Info);
562 } 568 }
563 return NewInst; 569 return NewInst;
564 } 570 }
565 571
566 Ice::Inst *convertAllocaInstruction(const AllocaInst *Inst) { 572 Ice::Inst *convertAllocaInstruction(const AllocaInst *Inst) {
567 // PNaCl bitcode only contains allocas of byte-granular objects. 573 // PNaCl bitcode only contains allocas of byte-granular objects.
568 Ice::Operand *ByteCount = convertValue(Inst->getArraySize()); 574 Ice::Operand *ByteCount = convertValue(Inst->getArraySize());
569 uint32_t Align = Inst->getAlignment(); 575 uint32_t Align = Inst->getAlignment();
570 Ice::Variable *Dest = mapValueToIceVar(Inst, Ice::getPointerType()); 576 Ice::Variable *Dest = mapValueToIceVar(Inst, Ice::getPointerType());
571 577
572 return Ice::InstAlloca::create(Func, ByteCount, Align, Dest); 578 return Ice::InstAlloca::create(Func.get(), ByteCount, Align, Dest);
573 } 579 }
574 580
575 Ice::Inst *convertUnreachableInstruction(const UnreachableInst * /*Inst*/) { 581 Ice::Inst *convertUnreachableInstruction(const UnreachableInst * /*Inst*/) {
576 return Ice::InstUnreachable::create(Func); 582 return Ice::InstUnreachable::create(Func.get());
577 } 583 }
578 584
579 Ice::CfgNode *convertBasicBlock(const BasicBlock *BB) { 585 Ice::CfgNode *convertBasicBlock(const BasicBlock *BB) {
580 Ice::CfgNode *Node = mapBasicBlockToNode(BB); 586 Ice::CfgNode *Node = mapBasicBlockToNode(BB);
581 for (const Instruction &II : *BB) { 587 for (const Instruction &II : *BB) {
582 Ice::Inst *Inst = convertInstruction(&II); 588 Ice::Inst *Inst = convertInstruction(&II);
583 Node->appendInst(Inst); 589 Node->appendInst(Inst);
584 } 590 }
585 return Node; 591 return Node;
586 } 592 }
(...skipping 27 matching lines...) Expand all
614 << I->getArgType(ArgIndex) 620 << I->getArgType(ArgIndex)
615 << ". Found: " << Call->getArg(ArgIndex)->getType(); 621 << ". Found: " << Call->getArg(ArgIndex)->getType();
616 report_fatal_error(StrBuf.str()); 622 report_fatal_error(StrBuf.str());
617 break; 623 break;
618 } 624 }
619 } 625 }
620 } 626 }
621 627
622 private: 628 private:
623 // Data 629 // Data
624 Ice::Cfg *Func; 630 std::unique_ptr<Ice::Cfg> Func;
625 std::map<const Value *, Ice::Variable *> VarMap; 631 std::map<const Value *, Ice::Variable *> VarMap;
626 std::map<const BasicBlock *, Ice::CfgNode *> NodeMap; 632 std::map<const BasicBlock *, Ice::CfgNode *> NodeMap;
627 }; 633 };
628 634
629 // Converter from LLVM global variables to ICE. The entry point is the 635 // Converter from LLVM global variables to ICE. The entry point is the
630 // convertGlobalsToIce method. 636 // convertGlobalsToIce method.
631 // 637 //
632 // Note: this currently assumes that the given IR was verified to be 638 // Note: this currently assumes that the given IR was verified to be
633 // valid PNaCl bitcode. Othewise, the behavior is undefined. 639 // valid PNaCl bitcode. Othewise, the behavior is undefined.
634 class LLVM2ICEGlobalsConverter : public LLVM2ICEConverter { 640 class LLVM2ICEGlobalsConverter : public LLVM2ICEConverter {
(...skipping 230 matching lines...) Expand 10 before | Expand all | Expand 10 after
865 } 871 }
866 872
867 void Converter::convertGlobals(Module *Mod) { 873 void Converter::convertGlobals(Module *Mod) {
868 LLVM2ICEGlobalsConverter GlobalsConverter(*this); 874 LLVM2ICEGlobalsConverter GlobalsConverter(*this);
869 VariableDeclarationList VariableDeclarations; 875 VariableDeclarationList VariableDeclarations;
870 GlobalsConverter.convertGlobalsToIce(Mod, VariableDeclarations); 876 GlobalsConverter.convertGlobalsToIce(Mod, VariableDeclarations);
871 lowerGlobals(VariableDeclarations); 877 lowerGlobals(VariableDeclarations);
872 } 878 }
873 879
874 void Converter::convertFunctions() { 880 void Converter::convertFunctions() {
875 TimerStackIdT StackID = GlobalContext::TSK_Funcs; 881 const TimerStackIdT StackID = GlobalContext::TSK_Funcs;
876 for (const Function &I : *Mod) { 882 for (const Function &I : *Mod) {
877 if (I.empty()) 883 if (I.empty())
878 continue; 884 continue;
879 885
880 TimerIdT TimerID = 0; 886 TimerIdT TimerID = 0;
881 if (ALLOW_DUMP && Ctx->getFlags().TimeEachFunction) { 887 const bool TimeThisFunction =
888 ALLOW_DUMP && Ctx->getFlags().TimeEachFunction;
889 if (TimeThisFunction) {
882 TimerID = Ctx->getTimerID(StackID, I.getName()); 890 TimerID = Ctx->getTimerID(StackID, I.getName());
883 Ctx->pushTimer(TimerID, StackID); 891 Ctx->pushTimer(TimerID, StackID);
884 } 892 }
885 LLVM2ICEFunctionConverter FunctionConverter(*this); 893 LLVM2ICEFunctionConverter FunctionConverter(*this);
886 894 FunctionConverter.convertFunction(&I);
887 Cfg *Fcn = FunctionConverter.convertFunction(&I); 895 if (TimeThisFunction)
888 translateFcn(Fcn);
889 if (ALLOW_DUMP && Ctx->getFlags().TimeEachFunction)
890 Ctx->popTimer(TimerID, StackID); 896 Ctx->popTimer(TimerID, StackID);
891 } 897 }
892 } 898 }
893 899
894 } // end of namespace Ice 900 } // end of namespace Ice
OLDNEW
« no previous file with comments | « src/IceCfg.cpp ('k') | src/IceDefs.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698