<html><head><meta http-equiv="Content-Type" content="text/html charset=iso-8859-1"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><br><div><div>On Jan 31, 2013, at 1:33 PM, Eric Christopher <<a href="mailto:echristo@gmail.com">echristo@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div dir="ltr">What did you change between the two patches and how did it fix the issue with compiling googletest (also the original patch was <span style="font-family:arial,sans-serif;font-size:13px">173946)? Testcase for the latter part?</span></div></blockquote><div><br></div>Use identity map only when RF_IgnoreMissingEntries is on.</div><div>I did run bugpoint on the googletest, but it didn't reduce the metadata, so it is still 19K.</div><div>I will try to manually remove some of the metadata.</div><div><br></div><div>Thanks,</div><div>Manman<br><blockquote type="cite"><div dir="ltr"><div>
<span style="font-family:arial,sans-serif;font-size:13px"><br></span></div><div><span style="font-family:arial,sans-serif;font-size:13px">-eric</span></div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Thu, Jan 31, 2013 at 1:19 PM, Manman Ren <span dir="ltr"><<a href="mailto:mren@apple.com" target="_blank">mren@apple.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-color: rgb(204, 204, 204); border-left-style: solid; padding-left: 1ex; position: static; z-index: auto;">Author: mren<br>
Date: Thu Jan 31 15:19:18 2013<br>
New Revision: 174093<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=174093&view=rev" target="_blank">http://llvm.org/viewvc/llvm-project?rev=174093&view=rev</a><br>
Log:<br>
Linker: correctly link in dbg.declare<br>
<br>
This is a re-worked version of r174048.<br>
Given source IR:<br>
call void @llvm.dbg.declare(metadata !{i32* %argc.addr}, metadata !14), !dbg !15<br>
we used to generate<br>
call void @llvm.dbg.declare(metadata !27, metadata !28), !dbg !29<br>
!27 = metadata !{null}<br>
<br>
With this patch, we will correctly generate<br>
call void @llvm.dbg.declare(metadata !{i32* %argc.addr}, metadata !27), !dbg !28<br>
<br>
Looking up %argc.addr in ValueMap will return null, since %argc.addr is already<br>
correctly set up, we can use identity mapping.<br>
<br>
<a href="rdar://problem/13089880">rdar://problem/13089880</a><br>
<br>
Added:<br>
    llvm/trunk/test/Linker/DbgDeclare.ll<br>
    llvm/trunk/test/Linker/DbgDeclare2.ll<br>
Modified:<br>
    llvm/trunk/lib/Transforms/Utils/ValueMapper.cpp<br>
<br>
Modified: llvm/trunk/lib/Transforms/Utils/ValueMapper.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Utils/ValueMapper.cpp?rev=174093&r1=174092&r2=174093&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Utils/ValueMapper.cpp?rev=174093&r1=174092&r2=174093&view=diff</a><br>

==============================================================================<br>
--- llvm/trunk/lib/Transforms/Utils/ValueMapper.cpp (original)<br>
+++ llvm/trunk/lib/Transforms/Utils/ValueMapper.cpp Thu Jan 31 15:19:18 2013<br>
@@ -63,14 +63,29 @@ Value *llvm::MapValue(const Value *V, Va<br>
     // Check all operands to see if any need to be remapped.<br>
     for (unsigned i = 0, e = MD->getNumOperands(); i != e; ++i) {<br>
       Value *OP = MD->getOperand(i);<br>
-      if (OP == 0 || MapValue(OP, VM, Flags, TypeMapper) == OP) continue;<br>
+      if (OP == 0) continue;<br>
+      Value *Mapped_OP = MapValue(OP, VM, Flags, TypeMapper);<br>
+      // Use identity map if Mapped_Op is null and we can ignore missing<br>
+      // entries.<br>
+      if (Mapped_OP == OP ||<br>
+          (Mapped_OP == 0 && (Flags & RF_IgnoreMissingEntries)))<br>
+        continue;<br>
<br>
       // Ok, at least one operand needs remapping.<br>
       SmallVector<Value*, 4> Elts;<br>
       Elts.reserve(MD->getNumOperands());<br>
       for (i = 0; i != e; ++i) {<br>
         Value *Op = MD->getOperand(i);<br>
-        Elts.push_back(Op ? MapValue(Op, VM, Flags, TypeMapper) : 0);<br>
+        if (Op == 0)<br>
+          Elts.push_back(0);<br>
+        else {<br>
+          Value *Mapped_Op = MapValue(Op, VM, Flags, TypeMapper);<br>
+          // Use identity map if Mapped_Op is null and we can ignore missing<br>
+          // entries.<br>
+          if (Mapped_Op == 0 && (Flags & RF_IgnoreMissingEntries))<br>
+            Mapped_Op = Op;<br>
+          Elts.push_back(Mapped_Op);<br>
+        }<br>
       }<br>
       MDNode *NewMD = MDNode::get(V->getContext(), Elts);<br>
       Dummy->replaceAllUsesWith(NewMD);<br>
<br>
Added: llvm/trunk/test/Linker/DbgDeclare.ll<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Linker/DbgDeclare.ll?rev=174093&view=auto" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Linker/DbgDeclare.ll?rev=174093&view=auto</a><br>

==============================================================================<br>
--- llvm/trunk/test/Linker/DbgDeclare.ll (added)<br>
+++ llvm/trunk/test/Linker/DbgDeclare.ll Thu Jan 31 15:19:18 2013<br>
@@ -0,0 +1,58 @@<br>
+; RUN: llvm-link %s %p/DbgDeclare2.ll -o %t.bc<br>
+; RUN: llvm-dis < %t.bc | FileCheck %s<br>
+; Test if metadata in dbg.declare is mapped properly or not.<br>
+<br>
+; <a href="rdar://13089880">rdar://13089880</a><br>
+; CHECK: define i32 @main(i32 %argc, i8** %argv)<br>
+; CHECK: call void @llvm.dbg.declare(metadata !{i32* %argc.addr}, metadata !{{[0-9]+}})<br>
+; CHECK: call void @llvm.dbg.declare(metadata !{i8*** %argv.addr}, metadata !{{[0-9]+}})<br>
+; CHECK: define void @test(i32 %argc, i8** %argv)<br>
+; CHECK: call void @llvm.dbg.declare(metadata !{i32* %argc.addr}, metadata !{{[0-9]+}})<br>
+; CHECK: call void @llvm.dbg.declare(metadata !{i8*** %argv.addr}, metadata !{{[0-9]+}})<br>
+; CHECK: call void @llvm.dbg.declare(metadata !{i32* %i}, metadata !{{[0-9]+}})<br>
+<br>
+target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"<br>
+target triple = "x86_64-apple-macosx10.9.0"<br>
+<br>
+define i32 @main(i32 %argc, i8** %argv) uwtable ssp {<br>
+entry:<br>
+  %retval = alloca i32, align 4<br>
+  %argc.addr = alloca i32, align 4<br>
+  %argv.addr = alloca i8**, align 8<br>
+  store i32 0, i32* %retval<br>
+  store i32 %argc, i32* %argc.addr, align 4<br>
+  call void @llvm.dbg.declare(metadata !{i32* %argc.addr}, metadata !14), !dbg !15<br>
+  store i8** %argv, i8*** %argv.addr, align 8<br>
+  call void @llvm.dbg.declare(metadata !{i8*** %argv.addr}, metadata !16), !dbg !15<br>
+  %0 = load i32* %argc.addr, align 4, !dbg !17<br>
+  %1 = load i8*** %argv.addr, align 8, !dbg !17<br>
+  call void @test(i32 %0, i8** %1), !dbg !17<br>
+  ret i32 0, !dbg !19<br>
+}<br>
+<br>
+declare void @llvm.dbg.declare(metadata, metadata) nounwind readnone<br>
+<br>
+declare void @test(i32, i8**)<br>
+<br>
+!<a href="http://llvm.dbg.cu/" target="_blank">llvm.dbg.cu</a> = !{!0}<br>
+<br>
+!0 = metadata !{i32 786449, i32 0, i32 4, metadata !"main.cpp", metadata !"/private/tmp", metadata !"clang version 3.3 (trunk 173515)", i1 true, i1 false, metadata !"", i32 0, metadata !1, metadata !1, metadata !3, metadata !1} ; [ DW_TAG_compile_unit ]<br>

+!1 = metadata !{metadata !2}<br>
+!2 = metadata !{i32 0}<br>
+!3 = metadata !{metadata !4}<br>
+!4 = metadata !{metadata !5}<br>
+!5 = metadata !{i32 786478, i32 0, metadata !6, metadata !"main", metadata !"main", metadata !"", metadata !6, i32 3, metadata !7, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, i32 (i32, i8**)* @main, null, null, metadata !1, i32 4} ; [ DW_TAG_subprogram ]<br>

+!6 = metadata !{i32 786473, metadata !"main.cpp", metadata !"/private/tmp", null} ; [ DW_TAG_file_type ]<br>
+!7 = metadata !{i32 786453, i32 0, metadata !"", i32 0, i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !8, i32 0, i32 0} ; [ DW_TAG_subroutine_type ]<br>
+!8 = metadata !{metadata !9, metadata !9, metadata !10}<br>
+!9 = metadata !{i32 786468, null, metadata !"int", null, i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ]<br>
+!10 = metadata !{i32 786447, null, metadata !"", null, i32 0, i64 64, i64 64, i64 0, i32 0, metadata !11} ; [ DW_TAG_pointer_type ]<br>
+!11 = metadata !{i32 786447, null, metadata !"", null, i32 0, i64 64, i64 64, i64 0, i32 0, metadata !12} ; [ DW_TAG_pointer_type ]<br>
+!12 = metadata !{i32 786470, null, metadata !"", null, i32 0, i64 0, i64 0, i64 0, i32 0, metadata !13} ; [ DW_TAG_const_type ]<br>
+!13 = metadata !{i32 786468, null, metadata !"char", null, i32 0, i64 8, i64 8, i64 0, i32 0, i32 6} ; [ DW_TAG_base_type ]<br>
+!14 = metadata !{i32 786689, metadata !5, metadata !"argc", metadata !6, i32 16777219, metadata !9, i32 0, i32 0} ; [ DW_TAG_arg_variable ]<br>
+!15 = metadata !{i32 3, i32 0, metadata !5, null}<br>
+!16 = metadata !{i32 786689, metadata !5, metadata !"argv", metadata !6, i32 33554435, metadata !10, i32 0, i32 0} ; [ DW_TAG_arg_variable ]<br>
+!17 = metadata !{i32 5, i32 0, metadata !18, null}<br>
+!18 = metadata !{i32 786443, metadata !5, i32 4, i32 0, metadata !6, i32 0} ; [ DW_TAG_lexical_block ]<br>
+!19 = metadata !{i32 6, i32 0, metadata !18, null}<br>
<br>
Added: llvm/trunk/test/Linker/DbgDeclare2.ll<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Linker/DbgDeclare2.ll?rev=174093&view=auto" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Linker/DbgDeclare2.ll?rev=174093&view=auto</a><br>

==============================================================================<br>
--- llvm/trunk/test/Linker/DbgDeclare2.ll (added)<br>
+++ llvm/trunk/test/Linker/DbgDeclare2.ll Thu Jan 31 15:19:18 2013<br>
@@ -0,0 +1,76 @@<br>
+; This file is used by 2011-08-04-DebugLoc.ll, so it doesn't actually do anything itself<br>
+;<br>
+; RUN: true<br>
+<br>
+target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"<br>
+target triple = "x86_64-apple-macosx10.9.0"<br>
+<br>
+define void @test(i32 %argc, i8** %argv) uwtable ssp {<br>
+entry:<br>
+  %argc.addr = alloca i32, align 4<br>
+  %argv.addr = alloca i8**, align 8<br>
+  %i = alloca i32, align 4<br>
+  store i32 %argc, i32* %argc.addr, align 4<br>
+  call void @llvm.dbg.declare(metadata !{i32* %argc.addr}, metadata !14), !dbg !15<br>
+  store i8** %argv, i8*** %argv.addr, align 8<br>
+  call void @llvm.dbg.declare(metadata !{i8*** %argv.addr}, metadata !16), !dbg !15<br>
+  call void @llvm.dbg.declare(metadata !{i32* %i}, metadata !17), !dbg !20<br>
+  store i32 0, i32* %i, align 4, !dbg !20<br>
+  br label %for.cond, !dbg !20<br>
+<br>
+for.cond:                                         ; preds = %for.inc, %entry<br>
+  %0 = load i32* %i, align 4, !dbg !20<br>
+  %1 = load i32* %argc.addr, align 4, !dbg !20<br>
+  %cmp = icmp slt i32 %0, %1, !dbg !20<br>
+  br i1 %cmp, label %for.body, label %for.end, !dbg !20<br>
+<br>
+for.body:                                         ; preds = %for.cond<br>
+  %2 = load i32* %i, align 4, !dbg !21<br>
+  %idxprom = sext i32 %2 to i64, !dbg !21<br>
+  %3 = load i8*** %argv.addr, align 8, !dbg !21<br>
+  %arrayidx = getelementptr inbounds i8** %3, i64 %idxprom, !dbg !21<br>
+  %4 = load i8** %arrayidx, align 8, !dbg !21<br>
+  %call = call i32 @puts(i8* %4), !dbg !21<br>
+  br label %for.inc, !dbg !23<br>
+<br>
+for.inc:                                          ; preds = %for.body<br>
+  %5 = load i32* %i, align 4, !dbg !20<br>
+  %inc = add nsw i32 %5, 1, !dbg !20<br>
+  store i32 %inc, i32* %i, align 4, !dbg !20<br>
+  br label %for.cond, !dbg !20<br>
+<br>
+for.end:                                          ; preds = %for.cond<br>
+  ret void, !dbg !24<br>
+}<br>
+<br>
+declare void @llvm.dbg.declare(metadata, metadata) nounwind readnone<br>
+<br>
+declare i32 @puts(i8*)<br>
+<br>
+!<a href="http://llvm.dbg.cu/" target="_blank">llvm.dbg.cu</a> = !{!0}<br>
+<br>
+!0 = metadata !{i32 786449, i32 0, i32 4, metadata !"main.cpp", metadata !"/private/tmp", metadata !"clang version 3.3 (trunk 173515)", i1 true, i1 false, metadata !"", i32 0, metadata !1, metadata !1, metadata !3, metadata !1} ; [ DW_TAG_compile_unit ]<br>

+!1 = metadata !{metadata !2}<br>
+!2 = metadata !{i32 0}<br>
+!3 = metadata !{metadata !4}<br>
+!4 = metadata !{metadata !5}<br>
+!5 = metadata !{i32 786478, i32 0, metadata !6, metadata !"print_args", metadata !"print_args", metadata !"test", metadata !6, i32 4, metadata !7, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, void (i32, i8**)* @test, null, null, metadata !1, i32 5} ; [ DW_TAG_subprogram ]<br>

+!6 = metadata !{i32 786473, metadata !"test.cpp", metadata !"/private/tmp", null} ; [ DW_TAG_file_type ]<br>
+!7 = metadata !{i32 786453, i32 0, metadata !"", i32 0, i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !8, i32 0, i32 0} ; [ DW_TAG_subroutine_type ]<br>
+!8 = metadata !{null, metadata !9, metadata !10}<br>
+!9 = metadata !{i32 786468, null, metadata !"int", null, i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ]<br>
+!10 = metadata !{i32 786447, null, metadata !"", null, i32 0, i64 64, i64 64, i64 0, i32 0, metadata !11} ; [ DW_TAG_pointer_type ]<br>
+!11 = metadata !{i32 786447, null, metadata !"", null, i32 0, i64 64, i64 64, i64 0, i32 0, metadata !12} ; [ DW_TAG_pointer_type ]<br>
+!12 = metadata !{i32 786470, null, metadata !"", null, i32 0, i64 0, i64 0, i64 0, i32 0, metadata !13} ; [ DW_TAG_const_type ]<br>
+!13 = metadata !{i32 786468, null, metadata !"char", null, i32 0, i64 8, i64 8, i64 0, i32 0, i32 6} ; [ DW_TAG_base_type ]<br>
+!14 = metadata !{i32 786689, metadata !5, metadata !"argc", metadata !6, i32 16777220, metadata !9, i32 0, i32 0} ; [ DW_TAG_arg_variable ]<br>
+!15 = metadata !{i32 4, i32 0, metadata !5, null}<br>
+!16 = metadata !{i32 786689, metadata !5, metadata !"argv", metadata !6, i32 33554436, metadata !10, i32 0, i32 0} ; [ DW_TAG_arg_variable ]<br>
+!17 = metadata !{i32 786688, metadata !18, metadata !"i", metadata !6, i32 6, metadata !9, i32 0, i32 0} ; [ DW_TAG_auto_variable ]<br>
+!18 = metadata !{i32 786443, metadata !19, i32 6, i32 0, metadata !6, i32 1} ; [ DW_TAG_lexical_block ]<br>
+!19 = metadata !{i32 786443, metadata !5, i32 5, i32 0, metadata !6, i32 0} ; [ DW_TAG_lexical_block ]<br>
+!20 = metadata !{i32 6, i32 0, metadata !18, null}<br>
+!21 = metadata !{i32 8, i32 0, metadata !22, null}<br>
+!22 = metadata !{i32 786443, metadata !18, i32 7, i32 0, metadata !6, i32 2} ; [ DW_TAG_lexical_block ]<br>
+!23 = metadata !{i32 9, i32 0, metadata !22, null}<br>
+!24 = metadata !{i32 10, i32 0, metadata !19, null}<br>
<br>
<br>
_______________________________________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br>
</blockquote></div><br></div>
</blockquote></div><br></body></html>