[PATCH] D25953: [IndVarSimplify][DebugLoc] When widening the exit loop condition, correctly reuse the debug location of the original comparison.
Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Oct 26 03:37:55 PDT 2016
This revision was automatically updated to reflect the committed changes.
Closed by commit rL285185: [IndVarSimplify][DebugLoc] When widening the exit loop condition, correctly… (authored by adibiagio).
Changed prior to commit:
https://reviews.llvm.org/D25953?vs=75734&id=75842#toc
Repository:
rL LLVM
https://reviews.llvm.org/D25953
Files:
llvm/trunk/lib/Transforms/Scalar/IndVarSimplify.cpp
llvm/trunk/test/DebugInfo/Generic/indvar-discriminator.ll
Index: llvm/trunk/test/DebugInfo/Generic/indvar-discriminator.ll
===================================================================
--- llvm/trunk/test/DebugInfo/Generic/indvar-discriminator.ll
+++ llvm/trunk/test/DebugInfo/Generic/indvar-discriminator.ll
@@ -2,6 +2,8 @@
;
; When the induction variable is widened by indvars, check that the debug loc
; associated with the loop increment is correctly propagated.
+; Also, when the exit condition of a loop is rewritten to be a canonical !=
+; comparison, check that the debug loc of the orginal comparison is reused.
;
; Test case obtained from the following source code:
;
@@ -19,10 +21,16 @@
; Check that the debug location for the loop increment still refers to
; line 4, column 26, discriminator 2.
;
+; Check that the canonicalized compare instruction for the loop exit
+; condition still refers to line 4, column 21, discriminator 1.
+;
; CHECK-LABEL: for.body:
; CHECK: [[PHI:%[0-9a-zA-Z.]+]] = phi i64 [
; CHECK-LABEL: for.inc:
; CHECK: add nuw nsw i64 [[PHI]], 1, !dbg ![[INDVARMD:[0-9]+]]
+; CHECK: icmp ne i64 %{{.+}}, %{{.+}}, !dbg ![[ICMPMD:[0-9]+]]
+; CHECK-DAG: ![[ICMPMD]] = !DILocation(line: 4, column: 21, scope: ![[ICMPSCOPEMD:[0-9]+]]
+; CHECK-DAG: ![[ICMPSCOPEMD]] = !DILexicalBlockFile(scope: !{{[0-9]+}}, file: !{{[0-9]+}}, discriminator: 1)
; CHECK-DAG: ![[INDVARMD]] = !DILocation(line: 4, column: 26, scope: ![[INDVARSCOPEMD:[0-9]+]])
; CHECK-DAG: ![[INDVARSCOPEMD]] = !DILexicalBlockFile(scope: !{{[0-9]+}}, file: !{{[0-9]+}}, discriminator: 2)
Index: llvm/trunk/lib/Transforms/Scalar/IndVarSimplify.cpp
===================================================================
--- llvm/trunk/lib/Transforms/Scalar/IndVarSimplify.cpp
+++ llvm/trunk/lib/Transforms/Scalar/IndVarSimplify.cpp
@@ -2189,6 +2189,11 @@
IRBuilder<> Builder(BI);
+ // The new loop exit condition should reuse the debug location of the
+ // original loop exit condition.
+ if (auto *Cond = dyn_cast<Instruction>(BI->getCondition()))
+ Builder.SetCurrentDebugLocation(Cond->getDebugLoc());
+
// LFTR can ignore IV overflow and truncate to the width of
// BECount. This avoids materializing the add(zext(add)) expression.
unsigned CmpIndVarSize = SE->getTypeSizeInBits(CmpIndVar->getType());
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D25953.75842.patch
Type: text/x-patch
Size: 2276 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20161026/941f2054/attachment.bin>
More information about the llvm-commits
mailing list