{DebugInfo][LSR] Don't cache dbg.value that are already undef
authorChris Jackson <chris.jackson@sony.com>
Thu, 5 Aug 2021 14:46:09 +0000 (15:46 +0100)
committerChris Jackson <chris.jackson@sony.com>
Thu, 5 Aug 2021 18:16:43 +0000 (19:16 +0100)
The SCEV-based salvaging method caches dbg.value information pre-LSR so
that salvaging may be attempted post-LSR. If the dbg.value are already
undef pre-LSR then a salvage attempt would be fruitless, so avoid
caching them.

Reviewed By: StephenTozer

Differential Revision: https://reviews.llvm.org/D107448

llvm/lib/Transforms/Scalar/LoopStrengthReduce.cpp
llvm/test/Transforms/LoopStrengthReduce/pr51329.ll

index eea5623..a126c54 100644 (file)
@@ -6222,6 +6222,9 @@ DbgGatherSalvagableDVI(Loop *L, ScalarEvolution &SE,
       if (!DVI)
         continue;
 
+      if (DVI->isUndef())
+        continue;
+
       if (DVI->hasArgList())
         continue;
 
index f8f1c48..ffdb785 100644 (file)
@@ -2,7 +2,10 @@
 ;\r
 ; Test that LSR SCEV-based salvaging does not crash when translating SCEVs\r
 ; that contain integers with binary representations greater than 64-bits. \r
+; Also show that no salvaging attempt is made for dbg.value that are undef\r
+; pre-LSR.\r
 ;\r
+; CHECK: call void @llvm.dbg.value(metadata i64 undef, metadata !{{[0-9]+}}, metadata !DIExpression(DW_OP_plus_uconst, 228, DW_OP_stack_value))\r
 ; CHECK: call void @llvm.dbg.value(metadata i64 %var2, metadata !{{[0-9]+}}, metadata !DIExpression(DW_OP_plus_uconst, 228, DW_OP_stack_value))\r
 \r
 \r
@@ -23,6 +26,7 @@ init:
 \r
 Label_d0:                                         ; preds = %Label_d0, %init\r
   %var3 = phi i64 [ %var2, %init ], [ %var4, %Label_d0 ]\r
+  call void @llvm.dbg.value(metadata i64 undef, metadata !11, metadata !DIExpression(DW_OP_plus_uconst, 228, DW_OP_stack_value)), !dbg !12\r
   call void @llvm.dbg.value(metadata i64 %var2, metadata !11, metadata !DIExpression(DW_OP_plus_uconst, 228, DW_OP_stack_value)), !dbg !12\r
   %var4 = add i64 %var3, -1\r
   %var5 = icmp eq i64 %var4, 0\r
@@ -47,4 +51,4 @@ Label_1bc:                                        ; preds = %Label_d0
 !9 = !DIBasicType(name: "my_type", size: 64, encoding: DW_ATE_unsigned)\r
 !10 = !{!11}\r
 !11 = !DILocalVariable(name: "my_var", arg: 1, scope: !5, file: !1, line: 904320, type: !8)\r
-!12 = !DILocation(line: 904544, scope: !5)\r
+!12 = !DILocation(line: 904544, scope: !5)
\ No newline at end of file