[PATCH] D26622: Linker: Remove unnecessary call to copyMetadata in IRLinker::linkGlobalVariable.
Peter Collingbourne via llvm-commits
llvm-commits at lists.llvm.org
Mon Nov 14 11:20:11 PST 2016
pcc created this revision.
pcc added a reviewer: aprantl.
pcc added a subscriber: llvm-commits.
This was causing us to create duplicate metadata on global variables.
Test case by Adrian Prantl.
https://reviews.llvm.org/D26622
Files:
llvm/lib/Linker/IRMover.cpp
llvm/test/Linker/debug-info-global-var.ll
Index: llvm/test/Linker/debug-info-global-var.ll
===================================================================
--- /dev/null
+++ llvm/test/Linker/debug-info-global-var.ll
@@ -0,0 +1,23 @@
+; RUN: llvm-link -S %s %S/debug-info-version-a.ll | FileCheck %s
+source_filename = "debug-info-global-var.c"
+target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-apple-macosx10.12.0"
+
+; CHECK: @g = global i32 0, align 4, !dbg ![[G:[0-9]+]]{{$}}
+ at g = global i32 0, align 4, !dbg !0
+
+!llvm.dbg.cu = !{!1}
+!llvm.module.flags = !{!6, !7, !8}
+!llvm.ident = !{!9}
+
+; CHECK: ![[G]] = distinct !DIGlobalVariable(name: "g"
+!0 = distinct !DIGlobalVariable(name: "g", scope: !1, file: !2, line: 1, type: !5, isLocal: false, isDefinition: true)
+!1 = distinct !DICompileUnit(language: DW_LANG_C99, file: !2, producer: "clang", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !3, globals: !4)
+!2 = !DIFile(filename: "debug-info-global-var.c", directory: "/")
+!3 = !{}
+!4 = !{!0}
+!5 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
+!6 = !{i32 2, !"Dwarf Version", i32 4}
+!7 = !{i32 2, !"Debug Info Version", i32 3}
+!8 = !{i32 1, !"PIC Level", i32 2}
+!9 = !{!"clang version 4.0.0 (trunk 286129) (llvm/trunk 286128)"}
Index: llvm/lib/Linker/IRMover.cpp
===================================================================
--- llvm/lib/Linker/IRMover.cpp
+++ llvm/lib/Linker/IRMover.cpp
@@ -950,8 +950,6 @@
/// Update the initializers in the Dest module now that all globals that may be
/// referenced are in Dest.
void IRLinker::linkGlobalVariable(GlobalVariable &Dst, GlobalVariable &Src) {
- Dst.copyMetadata(&Src, 0);
-
// Figure out what the initializer looks like in the dest module.
Mapper.scheduleMapGlobalInitializer(Dst, *Src.getInitializer());
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D26622.77845.patch
Type: text/x-patch
Size: 1834 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20161114/bd8738c8/attachment.bin>
More information about the llvm-commits
mailing list