diff options
author | Stephen Hines <srhines@google.com> | 2014-04-23 16:57:46 -0700 |
---|---|---|
committer | Stephen Hines <srhines@google.com> | 2014-04-24 15:53:16 -0700 |
commit | 36b56886974eae4f9c5ebc96befd3e7bfe5de338 (patch) | |
tree | e6cfb69fbbd937f450eeb83bfb83b9da3b01275a /test/Linker | |
parent | 69a8640022b04415ae9fac62f8ab090601d8f889 (diff) | |
download | external_llvm-36b56886974eae4f9c5ebc96befd3e7bfe5de338.zip external_llvm-36b56886974eae4f9c5ebc96befd3e7bfe5de338.tar.gz external_llvm-36b56886974eae4f9c5ebc96befd3e7bfe5de338.tar.bz2 |
Update to LLVM 3.5a.
Change-Id: Ifadecab779f128e62e430c2b4f6ddd84953ed617
Diffstat (limited to 'test/Linker')
-rw-r--r-- | test/Linker/2011-08-22-ResolveAlias2.ll | 108 | ||||
-rw-r--r-- | test/Linker/Inputs/datalayout-a.ll | 1 | ||||
-rw-r--r-- | test/Linker/Inputs/datalayout-b.ll | 1 | ||||
-rw-r--r-- | test/Linker/Inputs/targettriple-a.ll | 1 | ||||
-rw-r--r-- | test/Linker/Inputs/targettriple-b.ll | 1 | ||||
-rw-r--r-- | test/Linker/Inputs/type-unique-simple2-a.ll | 2 | ||||
-rw-r--r-- | test/Linker/Inputs/type-unique-simple2-b.ll | 2 | ||||
-rw-r--r-- | test/Linker/datalayout.ll | 14 | ||||
-rw-r--r-- | test/Linker/dllstorage-a.ll | 4 | ||||
-rw-r--r-- | test/Linker/dllstorage-b.ll | 3 | ||||
-rw-r--r-- | test/Linker/func-attrs-a.ll | 14 | ||||
-rw-r--r-- | test/Linker/func-attrs-b.ll | 8 | ||||
-rw-r--r-- | test/Linker/targettriple.ll | 14 | ||||
-rw-r--r-- | test/Linker/type-unique-odr-a.ll | 98 | ||||
-rw-r--r-- | test/Linker/type-unique-odr-b.ll | 86 | ||||
-rw-r--r-- | test/Linker/type-unique-simple-a.ll | 4 | ||||
-rw-r--r-- | test/Linker/type-unique-simple-b.ll | 2 | ||||
-rw-r--r-- | test/Linker/type-unique-simple2-a.ll | 129 | ||||
-rw-r--r-- | test/Linker/type-unique-simple2-b.ll | 88 | ||||
-rw-r--r-- | test/Linker/type-unique-simple2.ll | 2 |
20 files changed, 549 insertions, 33 deletions
diff --git a/test/Linker/2011-08-22-ResolveAlias2.ll b/test/Linker/2011-08-22-ResolveAlias2.ll index 2549040..eee60d4 100644 --- a/test/Linker/2011-08-22-ResolveAlias2.ll +++ b/test/Linker/2011-08-22-ResolveAlias2.ll @@ -37,56 +37,110 @@ @_ZL33__gthrw_pthread_mutexattr_settypeP19pthread_mutexattr_ti = alias weak i32 (%union.pthread_mutexattr_t*, i32)* @pthread_mutexattr_settype @_ZL33__gthrw_pthread_mutexattr_destroyP19pthread_mutexattr_t = alias weak i32 (%union.pthread_mutexattr_t*)* @pthread_mutexattr_destroy -declare void @_ZN13HexxagonBoardC2ERKS_(%struct.HexxagonBoard*, %struct.HexxagonBoard*) uwtable align 2 +define void @_ZN13HexxagonBoardC2ERKS_(%struct.HexxagonBoard*, %struct.HexxagonBoard*) uwtable align 2 { + ret void +} -declare extern_weak i32 @pthread_once(i32*, void ()*) +define weak i32 @pthread_once(i32*, void ()*) { + ret i32 0 +} -declare extern_weak i8* @pthread_getspecific(i32) +define weak i8* @pthread_getspecific(i32) { + ret i8* null +} -declare extern_weak i32 @pthread_setspecific(i32, i8*) +define weak i32 @pthread_setspecific(i32, i8*) { + ret i32 0 +} -declare extern_weak i32 @pthread_create(i64*, %union.pthread_attr_t*, i8* (i8*)*, i8*) +define weak i32 @pthread_create(i64*, %union.pthread_attr_t*, i8* (i8*)*, i8*) { + ret i32 0 +} -declare extern_weak i32 @pthread_join(i64, i8**) +define weak i32 @pthread_join(i64, i8**) { + ret i32 0 +} -declare extern_weak i32 @pthread_equal(i64, i64) +define weak i32 @pthread_equal(i64, i64) { + ret i32 0 +} -declare extern_weak i64 @pthread_self() +define weak i64 @pthread_self() { + ret i64 0 +} -declare extern_weak i32 @pthread_detach(i64) +define weak i32 @pthread_detach(i64) { + ret i32 0 +} -declare extern_weak i32 @pthread_cancel(i64) +define weak i32 @pthread_cancel(i64) { + ret i32 0 +} -declare extern_weak i32 @sched_yield() +define weak i32 @sched_yield() { + ret i32 0 +} -declare extern_weak i32 @pthread_mutex_lock(%union.pthread_mutex_t*) +define weak i32 @pthread_mutex_lock(%union.pthread_mutex_t*) { + ret i32 0 +} -declare extern_weak i32 @pthread_mutex_trylock(%union.pthread_mutex_t*) +define weak i32 @pthread_mutex_trylock(%union.pthread_mutex_t*) { + ret i32 0 +} -declare extern_weak i32 @pthread_mutex_timedlock(%union.pthread_mutex_t*, %struct.timespec*) +define weak i32 @pthread_mutex_timedlock(%union.pthread_mutex_t*, %struct.timespec*) { + ret i32 0 +} -declare extern_weak i32 @pthread_mutex_unlock(%union.pthread_mutex_t*) +define weak i32 @pthread_mutex_unlock(%union.pthread_mutex_t*) { + ret i32 0 +} -declare extern_weak i32 @pthread_mutex_init(%union.pthread_mutex_t*, %union.pthread_mutexattr_t*) +define weak i32 @pthread_mutex_init(%union.pthread_mutex_t*, %union.pthread_mutexattr_t*) { + ret i32 0 +} -declare extern_weak i32 @pthread_mutex_destroy(%union.pthread_mutex_t*) +define weak i32 @pthread_mutex_destroy(%union.pthread_mutex_t*) { + ret i32 0 +} -declare extern_weak i32 @pthread_cond_broadcast(%union.pthread_cond_t*) +define weak i32 @pthread_cond_broadcast(%union.pthread_cond_t*) { + ret i32 0 +} -declare extern_weak i32 @pthread_cond_signal(%union.pthread_cond_t*) +define weak i32 @pthread_cond_signal(%union.pthread_cond_t*) { + ret i32 0 +} -declare extern_weak i32 @pthread_cond_wait(%union.pthread_cond_t*, %union.pthread_mutex_t*) +define weak i32 @pthread_cond_wait(%union.pthread_cond_t*, %union.pthread_mutex_t*) { + ret i32 0 +} -declare extern_weak i32 @pthread_cond_timedwait(%union.pthread_cond_t*, %union.pthread_mutex_t*, %struct.timespec*) +define weak i32 @pthread_cond_timedwait(%union.pthread_cond_t*, %union.pthread_mutex_t*, %struct.timespec*) { + ret i32 0 +} -declare extern_weak i32 @pthread_cond_destroy(%union.pthread_cond_t*) +define weak i32 @pthread_cond_destroy(%union.pthread_cond_t*) { + ret i32 0 +} -declare extern_weak i32 @pthread_key_create(i32*, void (i8*)*) +define weak i32 @pthread_key_create(i32*, void (i8*)*) { + ret i32 0 +} -declare extern_weak i32 @pthread_key_delete(i32) +define weak i32 @pthread_key_delete(i32) { + ret i32 0 +} -declare extern_weak i32 @pthread_mutexattr_init(%union.pthread_mutexattr_t*) +define weak i32 @pthread_mutexattr_init(%union.pthread_mutexattr_t*) { + ret i32 0 +} -declare extern_weak i32 @pthread_mutexattr_settype(%union.pthread_mutexattr_t*, i32) +define weak i32 @pthread_mutexattr_settype(%union.pthread_mutexattr_t*, i32) { + ret i32 0 +} -declare extern_weak i32 @pthread_mutexattr_destroy(%union.pthread_mutexattr_t*) +define weak i32 @pthread_mutexattr_destroy(%union.pthread_mutexattr_t*) { + ret i32 0 +} diff --git a/test/Linker/Inputs/datalayout-a.ll b/test/Linker/Inputs/datalayout-a.ll new file mode 100644 index 0000000..e78478e --- /dev/null +++ b/test/Linker/Inputs/datalayout-a.ll @@ -0,0 +1 @@ +target datalayout = "e" diff --git a/test/Linker/Inputs/datalayout-b.ll b/test/Linker/Inputs/datalayout-b.ll new file mode 100644 index 0000000..59cdb68 --- /dev/null +++ b/test/Linker/Inputs/datalayout-b.ll @@ -0,0 +1 @@ +target datalayout = "E" diff --git a/test/Linker/Inputs/targettriple-a.ll b/test/Linker/Inputs/targettriple-a.ll new file mode 100644 index 0000000..296d2df --- /dev/null +++ b/test/Linker/Inputs/targettriple-a.ll @@ -0,0 +1 @@ +target triple = "e" diff --git a/test/Linker/Inputs/targettriple-b.ll b/test/Linker/Inputs/targettriple-b.ll new file mode 100644 index 0000000..cca872e --- /dev/null +++ b/test/Linker/Inputs/targettriple-b.ll @@ -0,0 +1 @@ +target triple = "E" diff --git a/test/Linker/Inputs/type-unique-simple2-a.ll b/test/Linker/Inputs/type-unique-simple2-a.ll index 63470f3..676b410 100644 --- a/test/Linker/Inputs/type-unique-simple2-a.ll +++ b/test/Linker/Inputs/type-unique-simple2-a.ll @@ -65,7 +65,7 @@ attributes #1 = { nounwind readnone } !0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.4 (http://llvm.org/git/clang.git 8a3f9e46cb988d2c664395b21910091e3730ae82) (http://llvm.org/git/llvm.git 4699e9549358bc77824a59114548eecc3f7c523c)", i1 false, metadata !"", i32 0, metadata !2, metadata !3, metadata !11, metadata !2, metadata !2, metadata !""} ; [ DW_TAG_compile_unit ] [foo.cpp] [DW_LANG_C_plus_plus] !1 = metadata !{metadata !"foo.cpp", metadata !"."} -!2 = metadata !{i32 0} +!2 = metadata !{} !3 = metadata !{metadata !4} !4 = metadata !{i32 786451, metadata !5, null, metadata !"Base", i32 1, i64 128, i64 64, i32 0, i32 0, null, metadata !6, i32 0, null, null, metadata !"_ZTS4Base"} ; [ DW_TAG_structure_type ] [Base] [line 1, size 128, align 64, offset 0] [def] [from ] !5 = metadata !{metadata !"./a.hpp", metadata !"."} diff --git a/test/Linker/Inputs/type-unique-simple2-b.ll b/test/Linker/Inputs/type-unique-simple2-b.ll index f564d81..3ec79e5 100644 --- a/test/Linker/Inputs/type-unique-simple2-b.ll +++ b/test/Linker/Inputs/type-unique-simple2-b.ll @@ -38,7 +38,7 @@ attributes #3 = { "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "n !0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.4 (http://llvm.org/git/clang.git 8a3f9e46cb988d2c664395b21910091e3730ae82) (http://llvm.org/git/llvm.git 4699e9549358bc77824a59114548eecc3f7c523c)", i1 false, metadata !"", i32 0, metadata !2, metadata !3, metadata !11, metadata !2, metadata !2, metadata !""} ; [ DW_TAG_compile_unit ] [bar.cpp] [DW_LANG_C_plus_plus] !1 = metadata !{metadata !"bar.cpp", metadata !"."} -!2 = metadata !{i32 0} +!2 = metadata !{} !3 = metadata !{metadata !4} !4 = metadata !{i32 786451, metadata !5, null, metadata !"Base", i32 1, i64 128, i64 64, i32 0, i32 0, null, metadata !6, i32 0, null, null, metadata !"_ZTS4Base"} ; [ DW_TAG_structure_type ] [Base] [line 1, size 128, align 64, offset 0] [def] [from ] !5 = metadata !{metadata !"./a.hpp", metadata !"."} diff --git a/test/Linker/datalayout.ll b/test/Linker/datalayout.ll new file mode 100644 index 0000000..8cbfc19 --- /dev/null +++ b/test/Linker/datalayout.ll @@ -0,0 +1,14 @@ +; REQUIRES: shell +; RUN: llvm-link %s %S/Inputs/datalayout-a.ll -S -o - 2>%t.a.err | FileCheck %s +; RUN: (echo foo ;cat %t.a.err) | FileCheck --check-prefix=WARN-A %s + +; RUN: llvm-link %s %S/Inputs/datalayout-b.ll -S -o - 2>%t.b.err | FileCheck %s +; RUN: cat %t.b.err | FileCheck --check-prefix=WARN-B %s + +target datalayout = "e" + +; CHECK: target datalayout = "e" + +; WARN-A-NOT: WARNING + +; WARN-B: WARNING: Linking two modules of different data layouts: diff --git a/test/Linker/dllstorage-a.ll b/test/Linker/dllstorage-a.ll new file mode 100644 index 0000000..91b9818 --- /dev/null +++ b/test/Linker/dllstorage-a.ll @@ -0,0 +1,4 @@ +; RUN: llvm-link %s %p/dllstorage-b.ll -S -o - | FileCheck %s +@foo = external global i32 + +; CHECK: @foo = dllexport global i32 42 diff --git a/test/Linker/dllstorage-b.ll b/test/Linker/dllstorage-b.ll new file mode 100644 index 0000000..4c7dbcd --- /dev/null +++ b/test/Linker/dllstorage-b.ll @@ -0,0 +1,3 @@ +; RUN: true + +@foo = dllexport global i32 42 diff --git a/test/Linker/func-attrs-a.ll b/test/Linker/func-attrs-a.ll new file mode 100644 index 0000000..d5495e1 --- /dev/null +++ b/test/Linker/func-attrs-a.ll @@ -0,0 +1,14 @@ +; RUN: llvm-link %s %p/func-attrs-b.ll -S -o - | FileCheck %s +; PR2382 + +; CHECK: call void @check0(%struct.S0* sret null, %struct.S0* byval align 4 null, %struct.S0* align 4 null, %struct.S0* byval align 4 null) +; CHECK: define void @check0(%struct.S0* sret %agg.result, %struct.S0* byval %arg0, %struct.S0* %arg1, %struct.S0* byval %arg2) + +%struct.S0 = type <{ i8, i8, i8, i8 }> + +define void @a() { + call void @check0(%struct.S0* sret null, %struct.S0* byval align 4 null, %struct.S0* align 4 null, %struct.S0* byval align 4 null) + ret void +} + +declare void @check0(%struct.S0*, %struct.S0*, %struct.S0*, %struct.S0*) diff --git a/test/Linker/func-attrs-b.ll b/test/Linker/func-attrs-b.ll new file mode 100644 index 0000000..df78e5f --- /dev/null +++ b/test/Linker/func-attrs-b.ll @@ -0,0 +1,8 @@ +; This file is used with func-attrs-a.ll +; RUN: true + +%struct.S0 = type <{ i8, i8, i8, i8 }> + +define void @check0(%struct.S0* sret %agg.result, %struct.S0* byval %arg0, %struct.S0* %arg1, %struct.S0* byval %arg2) { + ret void +} diff --git a/test/Linker/targettriple.ll b/test/Linker/targettriple.ll new file mode 100644 index 0000000..7183047 --- /dev/null +++ b/test/Linker/targettriple.ll @@ -0,0 +1,14 @@ +; REQUIRES: shell +; RUN: llvm-link %s %S/Inputs/targettriple-a.ll -S -o - 2>%t.a.err | FileCheck %s +; RUN: (echo foo ;cat %t.a.err) | FileCheck --check-prefix=WARN-A %s + +; RUN: llvm-link %s %S/Inputs/targettriple-b.ll -S -o - 2>%t.b.err | FileCheck %s +; RUN: cat %t.b.err | FileCheck --check-prefix=WARN-B %s + +target triple = "e" + +; CHECK: target triple = "e" + +; WARN-A-NOT: WARNING + +; WARN-B: WARNING: Linking two modules of different target triples: diff --git a/test/Linker/type-unique-odr-a.ll b/test/Linker/type-unique-odr-a.ll new file mode 100644 index 0000000..a1b8d28 --- /dev/null +++ b/test/Linker/type-unique-odr-a.ll @@ -0,0 +1,98 @@ +; REQUIRES: object-emission +; +; RUN: llvm-link %s %p/type-unique-odr-b.ll -S -o - | %llc_dwarf -filetype=obj -O0 | llvm-dwarfdump -debug-dump=info - | FileCheck %s +; +; Test ODR-based type uniquing for C++ class members. +; rdar://problem/15851313. +; +; $ cat -n type-unique-odr-a.cpp +; 1 class A { +; 2 int data; +; 3 protected: +; 4 void getFoo(); +; 5 }; +; 6 +; 7 static void bar() { +; 8 A a; +; 9 } +; 10 +; 11 void baz() { bar(); } +;; #include "ab.h" +; foo_t bar() { +; return A().getFoo(); +; } +; +; CHECK: DW_TAG_subprogram +; CHECK-NEXT: DW_AT_MIPS_linkage_name {{.*}} "_Z3bazv" +; CHECK: DW_TAG_subprogram +; CHECK-NEXT: DW_AT_MIPS_linkage_name {{.*}} "_ZL3barv" +; CHECK: DW_TAG_class_type +; CHECK-NEXT: DW_AT_name {{.*}} "A" +; CHECK-NOT: DW_TAG +; CHECK: DW_TAG_member +; CHECK-NEXT: DW_AT_name {{.*}} "data" +; CHECK-NOT: DW_TAG +; CHECK: DW_TAG_subprogram +; CHECK-NEXT: DW_AT_MIPS_linkage_name {{.*}} "_ZN1A6getFooEv" +; CHECK-NEXT: DW_AT_name {{.*}} "getFoo" + +; getFoo and A may only appear once. +; CHECK-NOT: {{(getFoo)|("A")}} + + +; ModuleID = 'type-unique-odr-a.cpp' + +%class.A = type { i32 } + +; Function Attrs: nounwind +define void @_Z3bazv() #0 { +entry: + call void @_ZL3barv(), !dbg !23 + ret void, !dbg !23 +} + +; Function Attrs: nounwind +define internal void @_ZL3barv() #0 { +entry: + %a = alloca %class.A, align 4 + call void @llvm.dbg.declare(metadata !{%class.A* %a}, metadata !24), !dbg !25 + ret void, !dbg !26 +} + +; Function Attrs: nounwind readnone +declare void @llvm.dbg.declare(metadata, metadata) #1 + +attributes #0 = { nounwind } +attributes #1 = { nounwind readnone } + +!llvm.dbg.cu = !{!0} +!llvm.module.flags = !{!20, !21} +!llvm.ident = !{!22} + +!0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.5.0 ", i1 false, metadata !"", i32 0, metadata !2, metadata !3, metadata !14, metadata !2, metadata !2, metadata !"", i32 1} ; [ DW_TAG_compile_unit ] [<unknown>] [DW_LANG_C_plus_plus] +!1 = metadata !{metadata !"<unknown>", metadata !""} +!2 = metadata !{} +!3 = metadata !{metadata !4} +!4 = metadata !{i32 786434, metadata !5, null, metadata !"A", i32 1, i64 32, i64 32, i32 0, i32 0, null, metadata !6, i32 0, null, null, metadata !"_ZTS1A"} ; [ DW_TAG_class_type ] [A] [line 1, size 32, align 32, offset 0] [def] [from ] +!5 = metadata !{metadata !"type-unique-odr-a.cpp", metadata !""} +!6 = metadata !{metadata !7, metadata !9} +!7 = metadata !{i32 786445, metadata !5, metadata !"_ZTS1A", metadata !"data", i32 2, i64 32, i64 32, i64 0, i32 1, metadata !8} ; [ DW_TAG_member ] [data] [line 2, size 32, align 32, offset 0] [private] [from int] +!8 = metadata !{i32 786468, null, null, metadata !"int", i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ] [int] [line 0, size 32, align 32, offset 0, enc DW_ATE_signed] +!9 = metadata !{i32 786478, metadata !5, metadata !"_ZTS1A", metadata !"getFoo", metadata !"getFoo", metadata !"_ZN1A6getFooEv", i32 4, metadata !10, i1 false, i1 false, i32 0, i32 0, null, i32 258, i1 false, null, null, i32 0, metadata !13, i32 4} ; [ DW_TAG_subprogram ] [line 4] [protected] [getFoo] +!10 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !11, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!11 = metadata !{null, metadata !12} +!12 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 1088, metadata !"_ZTS1A"} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [artificial] [from _ZTS1A] +!13 = metadata !{i32 786468} +!14 = metadata !{metadata !15, metadata !19} +!15 = metadata !{i32 786478, metadata !5, metadata !16, metadata !"baz", metadata !"baz", metadata !"_Z3bazv", i32 11, metadata !17, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, void ()* @_Z3bazv, null, null, metadata !2, i32 11} ; [ DW_TAG_subprogram ] [line 11] [def] [baz] +!16 = metadata !{i32 786473, metadata !5} ; [ DW_TAG_file_type ] [type-unique-odr-a.cpp] +!17 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !18, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!18 = metadata !{null} +!19 = metadata !{i32 786478, metadata !5, metadata !16, metadata !"bar", metadata !"bar", metadata !"_ZL3barv", i32 7, metadata !17, i1 true, i1 true, i32 0, i32 0, null, i32 256, i1 false, void ()* @_ZL3barv, null, null, metadata !2, i32 7} ; [ DW_TAG_subprogram ] [line 7] [local] [def] [bar] +!20 = metadata !{i32 2, metadata !"Dwarf Version", i32 4} +!21 = metadata !{i32 1, metadata !"Debug Info Version", i32 1} +!22 = metadata !{metadata !"clang version 3.5.0 "} +!23 = metadata !{i32 11, i32 0, metadata !15, null} +!24 = metadata !{i32 786688, metadata !19, metadata !"a", metadata !16, i32 8, metadata !"_ZTS1A", i32 0, i32 0} ; [ DW_TAG_auto_variable ] [a] [line 8] +!25 = metadata !{i32 8, i32 0, metadata !19, null} ; [ DW_TAG_imported_declaration ] +!26 = metadata !{i32 9, i32 0, metadata !19, null} diff --git a/test/Linker/type-unique-odr-b.ll b/test/Linker/type-unique-odr-b.ll new file mode 100644 index 0000000..3c8b7a1 --- /dev/null +++ b/test/Linker/type-unique-odr-b.ll @@ -0,0 +1,86 @@ +; RUN: true +; This file belongs to type-unique-odr-a.ll. +; +; Test ODR-based type uniquing for C++ class members. +; rdar://problem/15851313. +; +; $ cat -n type-unique-odr-b.cpp +; 1 // Make this declaration start on a different line. +; 2 class A { +; 3 int data; +; 4 protected: +; 5 void getFoo(); +; 6 }; +; 7 +; 8 void A::getFoo() {} +; 9 +; 10 static void bar() {} +; 11 void f() { bar(); }; + +; ModuleID = 'type-unique-odr-b.cpp' + +%class.A = type { i32 } + +; Function Attrs: nounwind +define void @_ZN1A6getFooEv(%class.A* %this) #0 align 2 { +entry: + %this.addr = alloca %class.A*, align 8 + store %class.A* %this, %class.A** %this.addr, align 8 + call void @llvm.dbg.declare(metadata !{%class.A** %this.addr}, metadata !24), !dbg !26 + %this1 = load %class.A** %this.addr + ret void, !dbg !27 +} + +; Function Attrs: nounwind readnone +declare void @llvm.dbg.declare(metadata, metadata) #1 + +; Function Attrs: nounwind +define void @_Z1fv() #0 { +entry: + call void @_ZL3barv(), !dbg !28 + ret void, !dbg !28 +} + +; Function Attrs: nounwind +define internal void @_ZL3barv() #0 { +entry: + ret void, !dbg !29 +} + +attributes #0 = { nounwind } +attributes #1 = { nounwind readnone } + +!llvm.dbg.cu = !{!0} +!llvm.module.flags = !{!21, !22} +!llvm.ident = !{!23} + +!0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.5.0 ", i1 false, metadata !"", i32 0, metadata !2, metadata !3, metadata !14, metadata !2, metadata !2, metadata !"", i32 1} ; [ DW_TAG_compile_unit ] [<unknown>] [DW_LANG_C_plus_plus] +!1 = metadata !{metadata !"<unknown>", metadata !""} +!2 = metadata !{} +!3 = metadata !{metadata !4} +!4 = metadata !{i32 786434, metadata !5, null, metadata !"A", i32 2, i64 32, i64 32, i32 0, i32 0, null, metadata !6, i32 0, null, null, metadata !"_ZTS1A"} ; [ DW_TAG_class_type ] [A] [line 2, size 32, align 32, offset 0] [def] [from ] +!5 = metadata !{metadata !"type-unique-odr-b.cpp", metadata !""} +!6 = metadata !{metadata !7, metadata !9} +!7 = metadata !{i32 786445, metadata !5, metadata !"_ZTS1A", metadata !"data", i32 3, i64 32, i64 32, i64 0, i32 1, metadata !8} ; [ DW_TAG_member ] [data] [line 3, size 32, align 32, offset 0] [private] [from int] +!8 = metadata !{i32 786468, null, null, metadata !"int", i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ] [int] [line 0, size 32, align 32, offset 0, enc DW_ATE_signed] +!9 = metadata !{i32 786478, metadata !5, metadata !"_ZTS1A", metadata !"getFoo", metadata !"getFoo", metadata !"_ZN1A6getFooEv", i32 5, metadata !10, i1 false, i1 false, i32 0, i32 0, null, i32 258, i1 false, null, null, i32 0, metadata !13, i32 5} ; [ DW_TAG_subprogram ] [line 5] [protected] [getFoo] +!10 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !11, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!11 = metadata !{null, metadata !12} +!12 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 1088, metadata !"_ZTS1A"} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [artificial] [from _ZTS1A] +!13 = metadata !{i32 786468} +!14 = metadata !{metadata !15, metadata !16, metadata !20} +!15 = metadata !{i32 786478, metadata !5, metadata !"_ZTS1A", metadata !"getFoo", metadata !"getFoo", metadata !"_ZN1A6getFooEv", i32 8, metadata !10, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, void (%class.A*)* @_ZN1A6getFooEv, null, metadata !9, metadata !2, i32 8} ; [ DW_TAG_subprogram ] [line 8] [def] [getFoo] +!16 = metadata !{i32 786478, metadata !5, metadata !17, metadata !"f", metadata !"f", metadata !"_Z1fv", i32 11, metadata !18, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, void ()* @_Z1fv, null, null, metadata !2, i32 11} ; [ DW_TAG_subprogram ] [line 11] [def] [f] +!17 = metadata !{i32 786473, metadata !5} ; [ DW_TAG_file_type ] [type-unique-odr-b.cpp] +!18 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !19, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!19 = metadata !{null} +!20 = metadata !{i32 786478, metadata !5, metadata !17, metadata !"bar", metadata !"bar", metadata !"_ZL3barv", i32 10, metadata !18, i1 true, i1 true, i32 0, i32 0, null, i32 256, i1 false, void ()* @_ZL3barv, null, null, metadata !2, i32 10} ; [ DW_TAG_subprogram ] [line 10] [local] [def] [bar] +!21 = metadata !{i32 2, metadata !"Dwarf Version", i32 4} +!22 = metadata !{i32 1, metadata !"Debug Info Version", i32 1} +!23 = metadata !{metadata !"clang version 3.5.0 "} +!24 = metadata !{i32 786689, metadata !15, metadata !"this", null, i32 16777216, metadata !25, i32 1088, i32 0} ; [ DW_TAG_arg_variable ] [this] [line 0] +!25 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 0, metadata !"_ZTS1A"} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [from _ZTS1A] +!26 = metadata !{i32 0, i32 0, metadata !15, null} +!27 = metadata !{i32 8, i32 0, metadata !15, null} ; [ DW_TAG_imported_declaration ] +!28 = metadata !{i32 11, i32 0, metadata !16, null} +!29 = metadata !{i32 10, i32 0, metadata !20, null} diff --git a/test/Linker/type-unique-simple-a.ll b/test/Linker/type-unique-simple-a.ll index 4bfdff9..350cd1f 100644 --- a/test/Linker/type-unique-simple-a.ll +++ b/test/Linker/type-unique-simple-a.ll @@ -2,7 +2,7 @@ ; RUN: llvm-link %s %p/type-unique-simple-b.ll -S -o %t ; RUN: cat %t | FileCheck %s -check-prefix=LINK -; RUN: llc -filetype=obj -O0 < %t > %t2 +; RUN: %llc_dwarf -filetype=obj -O0 < %t > %t2 ; RUN: llvm-dwarfdump -debug-dump=info %t2 | FileCheck %s ; Make sure the backend generates a single DIE and uses ref_addr. @@ -70,7 +70,7 @@ attributes #1 = { nounwind readnone } !0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.4 (http://llvm.org/git/clang.git c23b1db6268c8e7ce64026d57d1510c1aac200a0) (http://llvm.org/git/llvm.git 09b98fe3978eddefc2145adc1056cf21580ce945)", i1 false, metadata !"", i32 0, metadata !2, metadata !3, metadata !9, metadata !2, metadata !2, metadata !""} ; [ DW_TAG_compile_unit ] [/Users/mren/c_testing/type_unique_air/simple/foo.cpp] [DW_LANG_C_plus_plus] !1 = metadata !{metadata !"foo.cpp", metadata !"/Users/mren/c_testing/type_unique_air/simple"} -!2 = metadata !{i32 0} +!2 = metadata !{} !3 = metadata !{metadata !4} !4 = metadata !{i32 786451, metadata !5, null, metadata !"Base", i32 1, i64 32, i64 32, i32 0, i32 0, null, metadata !6, i32 0, null, null, metadata !"_ZTS4Base"} ; [ DW_TAG_structure_type ] [Base] [line 1, size 32, align 32, offset 0] [def] [from ] !5 = metadata !{metadata !"./a.hpp", metadata !"/Users/mren/c_testing/type_unique_air/simple"} diff --git a/test/Linker/type-unique-simple-b.ll b/test/Linker/type-unique-simple-b.ll index c46e67f..854ec15 100644 --- a/test/Linker/type-unique-simple-b.ll +++ b/test/Linker/type-unique-simple-b.ll @@ -40,7 +40,7 @@ attributes #3 = { "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "n !0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.4 (http://llvm.org/git/clang.git c23b1db6268c8e7ce64026d57d1510c1aac200a0) (http://llvm.org/git/llvm.git 09b98fe3978eddefc2145adc1056cf21580ce945)", i1 false, metadata !"", i32 0, metadata !2, metadata !3, metadata !9, metadata !2, metadata !2, metadata !""} ; [ DW_TAG_compile_unit ] [/Users/mren/c_testing/type_unique_air/simple/bar.cpp] [DW_LANG_C_plus_plus] !1 = metadata !{metadata !"bar.cpp", metadata !"/Users/mren/c_testing/type_unique_air/simple"} -!2 = metadata !{i32 0} +!2 = metadata !{} !3 = metadata !{metadata !4} !4 = metadata !{i32 786451, metadata !5, null, metadata !"Base", i32 1, i64 32, i64 32, i32 0, i32 0, null, metadata !6, i32 0, null, null, metadata !"_ZTS4Base"} ; [ DW_TAG_structure_type ] [Base] [line 1, size 32, align 32, offset 0] [def] [from ] !5 = metadata !{metadata !"./a.hpp", metadata !"/Users/mren/c_testing/type_unique_air/simple"} diff --git a/test/Linker/type-unique-simple2-a.ll b/test/Linker/type-unique-simple2-a.ll new file mode 100644 index 0000000..d0f1155 --- /dev/null +++ b/test/Linker/type-unique-simple2-a.ll @@ -0,0 +1,129 @@ +; REQUIRES: object-emission +; +; RUN: llvm-link %s %p/type-unique-simple2-b.ll -S -o - | %llc_dwarf -filetype=obj -O0 | llvm-dwarfdump -debug-dump=info - | FileCheck %s +; +; Tests for a merge error where attributes are inserted twice into the same DIE. +; +; $ cat ab.h +; typedef int foo_t; +; class A { +; public: +; virtual void setFoo(); +; virtual const foo_t getFoo(); +; }; +; +; $ cat a.cpp +; #include "ab.h" +; foo_t bar() { +; return A().getFoo(); +; } +; +; CHECK: _ZN1A6setFooEv +; CHECK: DW_AT_accessibility [DW_FORM_data1] (0x01) +; CHECK-NOT: DW_AT_accessibility +; CHECK: DW_TAG + +; ModuleID = 'a.cpp' + +%class.A = type { i32 (...)** } + +@_ZTV1A = external unnamed_addr constant [4 x i8*] + +; Function Attrs: nounwind +define i32 @_Z3barv() #0 { +entry: + %tmp = alloca %class.A, align 8 + %0 = bitcast %class.A* %tmp to i8*, !dbg !38 + call void @llvm.memset.p0i8.i64(i8* %0, i8 0, i64 8, i32 8, i1 false), !dbg !38 + call void @_ZN1AC1Ev(%class.A* %tmp) #1, !dbg !38 + %call = call i32 @_ZN1A6getFooEv(%class.A* %tmp), !dbg !38 + ret i32 %call, !dbg !38 +} + +; Function Attrs: nounwind +declare void @llvm.memset.p0i8.i64(i8* nocapture, i8, i64, i32, i1) #1 + +; Function Attrs: inlinehint nounwind +define linkonce_odr void @_ZN1AC1Ev(%class.A* %this) unnamed_addr #2 align 2 { +entry: + %this.addr = alloca %class.A*, align 8 + store %class.A* %this, %class.A** %this.addr, align 8 + call void @llvm.dbg.declare(metadata !{%class.A** %this.addr}, metadata !39), !dbg !41 + %this1 = load %class.A** %this.addr + call void @_ZN1AC2Ev(%class.A* %this1) #1, !dbg !42 + ret void, !dbg !42 +} + +declare i32 @_ZN1A6getFooEv(%class.A*) + +; Function Attrs: nounwind readnone +declare void @llvm.dbg.declare(metadata, metadata) #4 + +; Function Attrs: inlinehint nounwind +define linkonce_odr void @_ZN1AC2Ev(%class.A* %this) unnamed_addr #2 align 2 { +entry: + %this.addr = alloca %class.A*, align 8 + store %class.A* %this, %class.A** %this.addr, align 8 + call void @llvm.dbg.declare(metadata !{%class.A** %this.addr}, metadata !44), !dbg !45 + %this1 = load %class.A** %this.addr + %0 = bitcast %class.A* %this1 to i8***, !dbg !46 + store i8** getelementptr inbounds ([4 x i8*]* @_ZTV1A, i64 0, i64 2), i8*** %0, !dbg !46 + ret void, !dbg !46 +} + +attributes #0 = { nounwind } +attributes #1 = { nounwind } +attributes #2 = { inlinehint nounwind } +attributes #4 = { nounwind readnone } + +!llvm.dbg.cu = !{!0} +!llvm.module.flags = !{!35, !36} +!llvm.ident = !{!37} + +!0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.5 ", i1 false, metadata !"", i32 0, metadata !2, metadata !3, metadata !26, metadata !2, metadata !2, metadata !""} ; [ DW_TAG_compile_unit ] [/<unknown>] [DW_LANG_C_plus_plus] +!1 = metadata !{metadata !"<unknown>", metadata !""} +!2 = metadata !{} +!3 = metadata !{metadata !4} +!4 = metadata !{i32 786434, metadata !5, null, metadata !"A", i32 2, i64 64, i64 64, i32 0, i32 0, null, metadata !6, i32 0, metadata !"_ZTS1A", null, metadata !"_ZTS1A"} ; [ DW_TAG_class_type ] [A] [line 2, size 64, align 64, offset 0] [def] [from ] +!5 = metadata !{metadata !"./ab.h", metadata !""} +!6 = metadata !{metadata !7, metadata !14, metadata !19} +!7 = metadata !{i32 786445, metadata !5, metadata !8, metadata !"_vptr$A", i32 0, i64 64, i64 0, i64 0, i32 64, metadata !9} ; [ DW_TAG_member ] [_vptr$A] [line 0, size 64, align 0, offset 0] [artificial] [from ] +!8 = metadata !{i32 786473, metadata !5} ; [ DW_TAG_file_type ] [/./ab.h] +!9 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 0, i64 0, i32 0, metadata !10} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 0, offset 0] [from __vtbl_ptr_type] +!10 = metadata !{i32 786447, null, null, metadata !"__vtbl_ptr_type", i32 0, i64 64, i64 0, i64 0, i32 0, metadata !11} ; [ DW_TAG_pointer_type ] [__vtbl_ptr_type] [line 0, size 64, align 0, offset 0] [from ] +!11 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !12, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!12 = metadata !{metadata !13} +!13 = metadata !{i32 786468, null, null, metadata !"int", i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ] [int] [line 0, size 32, align 32, offset 0, enc DW_ATE_signed] +!14 = metadata !{i32 786478, metadata !5, metadata !"_ZTS1A", metadata !"setFoo", metadata !"setFoo", metadata !"_ZN1A6setFooEv", i32 4, metadata !15, i1 false, i1 false, i32 1, i32 0, metadata !"_ZTS1A", i32 256, i1 false, null, null, i32 0, metadata !18, i32 4} ; [ DW_TAG_subprogram ] [line 4] [setFoo] +!15 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !16, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!16 = metadata !{null, metadata !17} +!17 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 1088, metadata !"_ZTS1A"} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [artificial] [from _ZTS1A] +!18 = metadata !{i32 786468} +!19 = metadata !{i32 786478, metadata !5, metadata !"_ZTS1A", metadata !"getFoo", metadata !"getFoo", metadata !"_ZN1A6getFooEv", i32 5, metadata !20, i1 false, i1 false, i32 1, i32 1, metadata !"_ZTS1A", i32 256, i1 false, null, null, i32 0, metadata !25, i32 5} ; [ DW_TAG_subprogram ] [line 5] [getFoo] +!20 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !21, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!21 = metadata !{metadata !22, metadata !17} +!22 = metadata !{i32 786470, null, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, metadata !23} ; [ DW_TAG_const_type ] [line 0, size 0, align 0, offset 0] [from foo_t] +!23 = metadata !{i32 786454, metadata !24, null, metadata !"foo_t", i32 1, i64 0, i64 0, i64 0, i32 0, metadata !13} ; [ DW_TAG_typedef ] [foo_t] [line 1, size 0, align 0, offset 0] [from int] +!24 = metadata !{metadata !"a.cpp", metadata !""} +!25 = metadata !{i32 786468} +!26 = metadata !{metadata !27, metadata !31, metadata !34} +!27 = metadata !{i32 786478, metadata !24, metadata !28, metadata !"bar", metadata !"bar", metadata !"_Z3barv", i32 2, metadata !29, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, i32 ()* @_Z3barv, null, null, metadata !2, i32 2} ; [ DW_TAG_subprogram ] [line 2] [def] [bar] +!28 = metadata !{i32 786473, metadata !24} ; [ DW_TAG_file_type ] [/a.cpp] +!29 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !30, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!30 = metadata !{metadata !23} +!31 = metadata !{i32 786478, metadata !5, metadata !"_ZTS1A", metadata !"A", metadata !"A", metadata !"_ZN1AC1Ev", i32 2, metadata !15, i1 false, i1 true, i32 0, i32 0, null, i32 320, i1 false, void (%class.A*)* @_ZN1AC1Ev, null, metadata !32, metadata !2, i32 2} ; [ DW_TAG_subprogram ] [line 2] [def] [A] +!32 = metadata !{i32 786478, null, metadata !"_ZTS1A", metadata !"A", metadata !"A", metadata !"", i32 0, metadata !15, i1 false, i1 false, i32 0, i32 0, null, i32 320, i1 false, null, null, i32 0, metadata !33, i32 0} ; [ DW_TAG_subprogram ] [line 0] [A] +!33 = metadata !{i32 786468} +!34 = metadata !{i32 786478, metadata !5, metadata !"_ZTS1A", metadata !"A", metadata !"A", metadata !"_ZN1AC2Ev", i32 2, metadata !15, i1 false, i1 true, i32 0, i32 0, null, i32 320, i1 false, void (%class.A*)* @_ZN1AC2Ev, null, metadata !32, metadata !2, i32 2} ; [ DW_TAG_subprogram ] [line 2] [def] [A] +!35 = metadata !{i32 2, metadata !"Dwarf Version", i32 2} +!36 = metadata !{i32 1, metadata !"Debug Info Version", i32 1} +!37 = metadata !{metadata !"clang version 3.5 "} +!38 = metadata !{i32 3, i32 0, metadata !27, null} +!39 = metadata !{i32 786689, metadata !31, metadata !"this", null, i32 16777216, metadata !40, i32 1088, i32 0} ; [ DW_TAG_arg_variable ] [this] [line 0] +!40 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 0, metadata !"_ZTS1A"} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [from _ZTS1A] +!41 = metadata !{i32 0, i32 0, metadata !31, null} +!42 = metadata !{i32 2, i32 0, metadata !43, null} +!43 = metadata !{i32 786443, metadata !5, metadata !31} ; [ DW_TAG_lexical_block ] [/./ab.h] +!44 = metadata !{i32 786689, metadata !34, metadata !"this", null, i32 16777216, metadata !40, i32 1088, i32 0} ; [ DW_TAG_arg_variable ] [this] [line 0] +!45 = metadata !{i32 0, i32 0, metadata !34, null} +!46 = metadata !{i32 2, i32 0, metadata !34, null} diff --git a/test/Linker/type-unique-simple2-b.ll b/test/Linker/type-unique-simple2-b.ll new file mode 100644 index 0000000..9155f69 --- /dev/null +++ b/test/Linker/type-unique-simple2-b.ll @@ -0,0 +1,88 @@ +; RUN: true +; This file belongs to type-unique-simple2-a.ll. +; +; $ cat b.cpp +; #include "ab.h" +; void A::setFoo() {} +; const +; foo_t A::getFoo() { return 1; } +; ModuleID = 'b.cpp' +; target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128" +; target triple = "x86_64-apple-macosx10.9.0" + +%class.A = type { i32 (...)** } + +@_ZTV1A = unnamed_addr constant [4 x i8*] [i8* null, i8* bitcast ({ i8*, i8* }* @_ZTI1A to i8*), i8* bitcast (void (%class.A*)* @_ZN1A6setFooEv to i8*), i8* bitcast (i32 (%class.A*)* @_ZN1A6getFooEv to i8*)] +@_ZTVN10__cxxabiv117__class_type_infoE = external global i8* +@_ZTS1A = constant [3 x i8] c"1A\00" +@_ZTI1A = unnamed_addr constant { i8*, i8* } { i8* bitcast (i8** getelementptr inbounds (i8** @_ZTVN10__cxxabiv117__class_type_infoE, i64 2) to i8*), i8* getelementptr inbounds ([3 x i8]* @_ZTS1A, i32 0, i32 0) } + +; Function Attrs: nounwind +define void @_ZN1A6setFooEv(%class.A* %this) unnamed_addr #0 align 2 { +entry: + %this.addr = alloca %class.A*, align 8 + store %class.A* %this, %class.A** %this.addr, align 8 + call void @llvm.dbg.declare(metadata !{%class.A** %this.addr}, metadata !32), !dbg !34 + %this1 = load %class.A** %this.addr + ret void, !dbg !35 +} + +; Function Attrs: nounwind readnone +declare void @llvm.dbg.declare(metadata, metadata) #1 + +; Function Attrs: nounwind +define i32 @_ZN1A6getFooEv(%class.A* %this) unnamed_addr #0 align 2 { +entry: + %this.addr = alloca %class.A*, align 8 + store %class.A* %this, %class.A** %this.addr, align 8 + call void @llvm.dbg.declare(metadata !{%class.A** %this.addr}, metadata !36), !dbg !37 + %this1 = load %class.A** %this.addr + ret i32 1, !dbg !38 +} + +attributes #0 = { nounwind } +attributes #1 = { nounwind readnone } + +!llvm.dbg.cu = !{!0} +!llvm.module.flags = !{!29, !30} +!llvm.ident = !{!31} + +!0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.5 ", i1 false, metadata !"", i32 0, metadata !2, metadata !3, metadata !25, metadata !2, metadata !2, metadata !""} ; [ DW_TAG_compile_unit ] [/<unknown>] [DW_LANG_C_plus_plus] +!1 = metadata !{metadata !"<unknown>", metadata !""} +!2 = metadata !{} +!3 = metadata !{metadata !4} +!4 = metadata !{i32 786434, metadata !5, null, metadata !"A", i32 2, i64 64, i64 64, i32 0, i32 0, null, metadata !6, i32 0, metadata !"_ZTS1A", null, metadata !"_ZTS1A"} ; [ DW_TAG_class_type ] [A] [line 2, size 64, align 64, offset 0] [def] [from ] +!5 = metadata !{metadata !"./ab.h", metadata !""} +!6 = metadata !{metadata !7, metadata !14, metadata !19} +!7 = metadata !{i32 786445, metadata !5, metadata !8, metadata !"_vptr$A", i32 0, i64 64, i64 0, i64 0, i32 64, metadata !9} ; [ DW_TAG_member ] [_vptr$A] [line 0, size 64, align 0, offset 0] [artificial] [from ] +!8 = metadata !{i32 786473, metadata !5} ; [ DW_TAG_file_type ] [/./ab.h] +!9 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 0, i64 0, i32 0, metadata !10} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 0, offset 0] [from __vtbl_ptr_type] +!10 = metadata !{i32 786447, null, null, metadata !"__vtbl_ptr_type", i32 0, i64 64, i64 0, i64 0, i32 0, metadata !11} ; [ DW_TAG_pointer_type ] [__vtbl_ptr_type] [line 0, size 64, align 0, offset 0] [from ] +!11 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !12, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!12 = metadata !{metadata !13} +!13 = metadata !{i32 786468, null, null, metadata !"int", i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ] [int] [line 0, size 32, align 32, offset 0, enc DW_ATE_signed] +!14 = metadata !{i32 786478, metadata !5, metadata !"_ZTS1A", metadata !"setFoo", metadata !"setFoo", metadata !"_ZN1A6setFooEv", i32 4, metadata !15, i1 false, i1 false, i32 1, i32 0, metadata !"_ZTS1A", i32 256, i1 false, null, null, i32 0, metadata !18, i32 4} ; [ DW_TAG_subprogram ] [line 4] [setFoo] +!15 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !16, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!16 = metadata !{null, metadata !17} +!17 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 1088, metadata !"_ZTS1A"} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [artificial] [from _ZTS1A] +!18 = metadata !{i32 786468} +!19 = metadata !{i32 786478, metadata !5, metadata !"_ZTS1A", metadata !"getFoo", metadata !"getFoo", metadata !"_ZN1A6getFooEv", i32 5, metadata !20, i1 false, i1 false, i32 1, i32 1, metadata !"_ZTS1A", i32 256, i1 false, null, null, i32 0, metadata !24, i32 5} ; [ DW_TAG_subprogram ] [line 5] [getFoo] +!20 = metadata !{i32 786453, i32 0, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !21, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ] +!21 = metadata !{metadata !22, metadata !17} +!22 = metadata !{i32 786470, null, null, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, metadata !23} ; [ DW_TAG_const_type ] [line 0, size 0, align 0, offset 0] [from foo_t] +!23 = metadata !{i32 786454, metadata !5, null, metadata !"foo_t", i32 1, i64 0, i64 0, i64 0, i32 0, metadata !13} ; [ DW_TAG_typedef ] [foo_t] [line 1, size 0, align 0, offset 0] [from int] +!24 = metadata !{i32 786468} +!25 = metadata !{metadata !26, metadata !28} +!26 = metadata !{i32 786478, metadata !27, metadata !"_ZTS1A", metadata !"setFoo", metadata !"setFoo", metadata !"_ZN1A6setFooEv", i32 2, metadata !15, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, void (%class.A*)* @_ZN1A6setFooEv, null, metadata !14, metadata !2, i32 2} ; [ DW_TAG_subprogram ] [line 2] [def] [setFoo] +!27 = metadata !{metadata !"b.cpp", metadata !""} +!28 = metadata !{i32 786478, metadata !27, metadata !"_ZTS1A", metadata !"getFoo", metadata !"getFoo", metadata !"_ZN1A6getFooEv", i32 4, metadata !20, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, i32 (%class.A*)* @_ZN1A6getFooEv, null, metadata !19, metadata !2, i32 4} ; [ DW_TAG_subprogram ] [line 4] [def] [getFoo] +!29 = metadata !{i32 2, metadata !"Dwarf Version", i32 2} +!30 = metadata !{i32 1, metadata !"Debug Info Version", i32 1} +!31 = metadata !{metadata !"clang version 3.5 "} +!32 = metadata !{i32 786689, metadata !26, metadata !"this", null, i32 16777216, metadata !33, i32 1088, i32 0} ; [ DW_TAG_arg_variable ] [this] [line 0] +!33 = metadata !{i32 786447, null, null, metadata !"", i32 0, i64 64, i64 64, i64 0, i32 0, metadata !"_ZTS1A"} ; [ DW_TAG_pointer_type ] [line 0, size 64, align 64, offset 0] [from _ZTS1A] +!34 = metadata !{i32 0, i32 0, metadata !26, null} +!35 = metadata !{i32 2, i32 0, metadata !26, null} +!36 = metadata !{i32 786689, metadata !28, metadata !"this", null, i32 16777216, metadata !33, i32 1088, i32 0} ; [ DW_TAG_arg_variable ] [this] [line 0] +!37 = metadata !{i32 0, i32 0, metadata !28, null} +!38 = metadata !{i32 4, i32 0, metadata !28, null} diff --git a/test/Linker/type-unique-simple2.ll b/test/Linker/type-unique-simple2.ll index ead91df..8a56e2e 100644 --- a/test/Linker/type-unique-simple2.ll +++ b/test/Linker/type-unique-simple2.ll @@ -2,5 +2,5 @@ ; RUN: llvm-link %S/Inputs/type-unique-simple2-a.ll %S/Inputs/type-unique-simple2-b.ll -S -o %t ; RUN: cat %t | FileCheck %S/Inputs/type-unique-simple2-a.ll -check-prefix=LINK -; RUN: llc -filetype=obj -O0 < %t > %t2 +; RUN: %llc_dwarf -filetype=obj -O0 < %t > %t2 ; RUN: llvm-dwarfdump -debug-dump=info %t2 | FileCheck %S/Inputs/type-unique-simple2-a.ll |