diff options
Diffstat (limited to 'lib/Transforms/Utils/SimplifyCFG.cpp')
| -rw-r--r-- | lib/Transforms/Utils/SimplifyCFG.cpp | 10 | 
1 files changed, 9 insertions, 1 deletions
| diff --git a/lib/Transforms/Utils/SimplifyCFG.cpp b/lib/Transforms/Utils/SimplifyCFG.cpp index 3846b21c502e..54390e77bb1f 100644 --- a/lib/Transforms/Utils/SimplifyCFG.cpp +++ b/lib/Transforms/Utils/SimplifyCFG.cpp @@ -1574,12 +1574,20 @@ static bool sinkLastInstruction(ArrayRef<BasicBlock*> Blocks) {      I0->getOperandUse(O).set(NewOperands[O]);    I0->moveBefore(&*BBEnd->getFirstInsertionPt()); -  // Update metadata and IR flags. +  // The debug location for the "common" instruction is the merged locations of +  // all the commoned instructions.  We start with the original location of the +  // "common" instruction and iteratively merge each location in the loop below. +  DILocation *Loc = I0->getDebugLoc(); + +  // Update metadata and IR flags, and merge debug locations.    for (auto *I : Insts)      if (I != I0) { +      Loc = DILocation::getMergedLocation(Loc, I->getDebugLoc());        combineMetadataForCSE(I0, I);        I0->andIRFlags(I);      } +  if (!isa<CallInst>(I0)) +    I0->setDebugLoc(Loc);    if (!isa<StoreInst>(I0)) {      // canSinkLastInstruction checked that all instructions were used by | 
