summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms/Utils/AddDiscriminators.cpp
diff options
context:
space:
mode:
authorDehao Chen <dehao@google.com>2015-10-30 04:29:05 +0000
committerDehao Chen <dehao@google.com>2015-10-30 04:29:05 +0000
commit4d84b9321e37d68ed1f436638130d159c638f626 (patch)
tree571c04bb54e6b143cff8cc8f64306021626438a9 /llvm/lib/Transforms/Utils/AddDiscriminators.cpp
parent4761f782e12266c0deaa82063cc337175c82ef64 (diff)
downloadbcm5719-llvm-4d84b9321e37d68ed1f436638130d159c638f626.tar.gz
bcm5719-llvm-4d84b9321e37d68ed1f436638130d159c638f626.zip
Revert r251680:
Update the discriminator assignment algorithm * If a scope has already been assigned a discriminator, do not reassign a nested discriminator for it. * If the file and line both match, even if the column does not match, we should assign a new discriminator for the stmt. original code: ; #1 int foo(int i) { ; #2 if (i == 3 || i == 5) return 100; else return 99; ; #3 } ; i == 3: discriminator 0 ; i == 5: discriminator 2 ; return 100: discriminator 1 ; return 99: discriminator 3 llvm-svn: 251685
Diffstat (limited to 'llvm/lib/Transforms/Utils/AddDiscriminators.cpp')
-rw-r--r--llvm/lib/Transforms/Utils/AddDiscriminators.cpp23
1 files changed, 11 insertions, 12 deletions
diff --git a/llvm/lib/Transforms/Utils/AddDiscriminators.cpp b/llvm/lib/Transforms/Utils/AddDiscriminators.cpp
index 1a101879d26..34c2f4525ea 100644
--- a/llvm/lib/Transforms/Utils/AddDiscriminators.cpp
+++ b/llvm/lib/Transforms/Utils/AddDiscriminators.cpp
@@ -180,7 +180,7 @@ bool AddDiscriminators::runOnFunction(Function &F) {
BasicBlock *Succ = Last->getSuccessor(I);
Instruction *First = Succ->getFirstNonPHIOrDbgOrLifetime();
const DILocation *FirstDIL = First->getDebugLoc();
- if (!FirstDIL || FirstDIL->getDiscriminator())
+ if (!FirstDIL)
continue;
// If the first instruction (First) of Succ is at the same file
@@ -202,22 +202,21 @@ bool AddDiscriminators::runOnFunction(Function &F) {
unsigned Discriminator = FirstDIL->computeNewDiscriminator();
auto *NewScope =
Builder.createLexicalBlockFile(Scope, File, Discriminator);
+ auto *NewDIL =
+ DILocation::get(Ctx, FirstDIL->getLine(), FirstDIL->getColumn(),
+ NewScope, FirstDIL->getInlinedAt());
+ DebugLoc newDebugLoc = NewDIL;
// Attach this new debug location to First and every
// instruction following First that shares the same location.
for (BasicBlock::iterator I1(*First), E1 = Succ->end(); I1 != E1;
++I1) {
- const DILocation *CurrentDIL = I1->getDebugLoc();
- if (CurrentDIL && CurrentDIL->getLine() == FirstDIL->getLine() &&
- CurrentDIL->getFilename() == FirstDIL->getFilename()) {
- I1->setDebugLoc(DILocation::get(Ctx, CurrentDIL->getLine(),
- CurrentDIL->getColumn(), NewScope,
- CurrentDIL->getInlinedAt()));
- DEBUG(dbgs() << CurrentDIL->getFilename() << ":"
- << CurrentDIL->getLine() << ":"
- << CurrentDIL->getColumn() << ":"
- << CurrentDIL->getDiscriminator() << *I1 << "\n");
- }
+ if (I1->getDebugLoc().get() != FirstDIL)
+ break;
+ I1->setDebugLoc(newDebugLoc);
+ DEBUG(dbgs() << NewDIL->getFilename() << ":" << NewDIL->getLine()
+ << ":" << NewDIL->getColumn() << ":"
+ << NewDIL->getDiscriminator() << *I1 << "\n");
}
DEBUG(dbgs() << "\n");
Changed = true;
OpenPOWER on IntegriCloud