[PATCH] D48769: [DebugInfo][LoopVectorize] Preserve DL in generated phi instruction
Anastasis via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Sat Jun 30 05:26:19 PDT 2018
gramanas updated this revision to Diff 153625.
gramanas added a comment.
Formatting
Repository:
rL LLVM
https://reviews.llvm.org/D48769
Files:
lib/Transforms/Vectorize/LoopVectorize.cpp
test/Transforms/LoopVectorize/duplicated-metadata.ll
Index: test/Transforms/LoopVectorize/duplicated-metadata.ll
===================================================================
--- test/Transforms/LoopVectorize/duplicated-metadata.ll
+++ test/Transforms/LoopVectorize/duplicated-metadata.ll
@@ -1,10 +1,14 @@
; RUN: opt < %s -loop-vectorize -S 2>&1 | FileCheck %s
+; RUN: opt < %s -debugify -loop-vectorize -S | FileCheck %s -check-prefix DEBUGLOC
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
; This test makes sure we don't duplicate the loop vectorizer's metadata
; while marking them as already vectorized (by setting width = 1), even
; at lower optimization levels, where no extra cleanup is done
+; DEBUGLOC-LABEL: define void @_Z3fooPf(
+; Check that the phi to resume the scalar part of the loop
+; has Debug Location.
define void @_Z3fooPf(float* %a) {
entry:
br label %for.body
@@ -19,6 +23,11 @@
%exitcond = icmp eq i64 %indvars.iv.next, 1024
br i1 %exitcond, label %for.end, label %for.body, !llvm.loop !0
+; DEBUGLOC: scalar.ph:
+; DEBUGLOC-NEXT: %bc.resume.val = phi {{.*}} !dbg ![[DbgLoc:[0-9]+]]
+;
+; DEBUGLOC: ![[DbgLoc]] = !DILocation(line: 2
+
for.end: ; preds = %for.body
ret void
}
Index: lib/Transforms/Vectorize/LoopVectorize.cpp
===================================================================
--- lib/Transforms/Vectorize/LoopVectorize.cpp
+++ lib/Transforms/Vectorize/LoopVectorize.cpp
@@ -2912,6 +2912,8 @@
// Create phi nodes to merge from the backedge-taken check block.
PHINode *BCResumeVal = PHINode::Create(
OrigPhi->getType(), 3, "bc.resume.val", ScalarPH->getTerminator());
+ // Copy original phi DL over to the new one.
+ BCResumeVal->setDebugLoc(OrigPhi->getDebugLoc());
Value *&EndValue = IVEndValues[OrigPhi];
if (OrigPhi == OldInduction) {
// We know what the end value is.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D48769.153625.patch
Type: text/x-patch
Size: 1896 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20180630/b6c9d975/attachment.bin>
More information about the llvm-commits
mailing list