2012-12-04 02:45:45 +08:00
; For http://llvm.org/bugs/show_bug.cgi?id=12942
; There are two CUs coming from /tmp/foo.c in this module. Make sure it doesn't
; blow llc up and produces something reasonable.
;
2013-04-11 03:53:26 +08:00
; REQUIRES: object-emission
2014-01-30 09:39:17 +08:00
; RUN: %llc_dwarf %s -o %t -filetype=obj -O0
2017-09-12 06:59:45 +08:00
; RUN: llvm-dwarfdump -debug-info %t | FileCheck %s
2012-12-04 02:45:45 +08:00
; ModuleID = 'test.bc'
@str = private unnamed_addr constant [ 4 x i8 ] c "FOO\00"
@str1 = private unnamed_addr constant [ 6 x i8 ] c "Main!\00"
2015-11-06 06:03:56 +08:00
define void @foo ( ) nounwind !dbg !5 {
2012-12-04 02:45:45 +08:00
entry:
2015-03-14 02:20:45 +08:00
%puts = tail call i32 @puts ( i8 * getelementptr inbounds ( [ 4 x i8 ] , [ 4 x i8 ] * @str , i32 0 , i32 0 ) ) , !dbg !23
2012-12-04 02:45:45 +08:00
ret void , !dbg !25
}
declare i32 @puts ( i8 * nocapture ) nounwind
2015-11-06 06:03:56 +08:00
define i32 @main ( i32 %argc , i8 * * nocapture %argv ) nounwind !dbg !12 {
2012-12-04 02:45:45 +08:00
entry:
2017-07-29 04:21:02 +08:00
tail call void @llvm.dbg.value ( metadata i32 %argc , metadata !21 , metadata !DIExpression ( ) ) , !dbg !26
2016-01-15 08:46:17 +08:00
; Avoid talking about the pointer size in debug info because that's target dependent
2017-07-29 04:21:02 +08:00
tail call void @llvm.dbg.value ( metadata i8 * * %argv , metadata !22 , metadata !DIExpression ( D W _ O P _ d e r e f , D W _ O P _ d e r e f ) ) , !dbg !27
2015-03-14 02:20:45 +08:00
%puts = tail call i32 @puts ( i8 * getelementptr inbounds ( [ 6 x i8 ] , [ 6 x i8 ] * @str1 , i32 0 , i32 0 ) ) , !dbg !28
2012-12-04 02:45:45 +08:00
tail call void @foo ( ) nounwind , !dbg !30
ret i32 0 , !dbg !31
}
2017-07-29 04:21:02 +08:00
declare void @llvm.dbg.value ( metadata , metadata , metadata ) nounwind readnone
2012-12-04 02:45:45 +08:00
!llvm.dbg.cu = ! { !0 , !9 }
2013-11-23 05:49:45 +08:00
!llvm.module.flags = ! { !33 }
2012-12-04 02:45:45 +08:00
2016-04-15 23:57:41 +08:00
!0 = distinct !DICompileUnit ( language: D W _ L A N G _ C 99 , producer: "clang version 3.2 (trunk 156513)" , isOptimized: true , emissionKind: F u l l D e b u g , file: !32 , enums: !1 , retainedTypes: !1 , globals: !1 , imports: !1 )
IR: Make metadata typeless in assembly
Now that `Metadata` is typeless, reflect that in the assembly. These
are the matching assembly changes for the metadata/value split in
r223802.
- Only use the `metadata` type when referencing metadata from a call
intrinsic -- i.e., only when it's used as a `Value`.
- Stop pretending that `ValueAsMetadata` is wrapped in an `MDNode`
when referencing it from call intrinsics.
So, assembly like this:
define @foo(i32 %v) {
call void @llvm.foo(metadata !{i32 %v}, metadata !0)
call void @llvm.foo(metadata !{i32 7}, metadata !0)
call void @llvm.foo(metadata !1, metadata !0)
call void @llvm.foo(metadata !3, metadata !0)
call void @llvm.foo(metadata !{metadata !3}, metadata !0)
ret void, !bar !2
}
!0 = metadata !{metadata !2}
!1 = metadata !{i32* @global}
!2 = metadata !{metadata !3}
!3 = metadata !{}
turns into this:
define @foo(i32 %v) {
call void @llvm.foo(metadata i32 %v, metadata !0)
call void @llvm.foo(metadata i32 7, metadata !0)
call void @llvm.foo(metadata i32* @global, metadata !0)
call void @llvm.foo(metadata !3, metadata !0)
call void @llvm.foo(metadata !{!3}, metadata !0)
ret void, !bar !2
}
!0 = !{!2}
!1 = !{i32* @global}
!2 = !{!3}
!3 = !{}
I wrote an upgrade script that handled almost all of the tests in llvm
and many of the tests in cfe (even handling many `CHECK` lines). I've
attached it (or will attach it in a moment if you're speedy) to PR21532
to help everyone update their out-of-tree testcases.
This is part of PR21532.
llvm-svn: 224257
2014-12-16 03:07:53 +08:00
!1 = ! { }
2016-04-15 23:57:41 +08:00
!5 = distinct !DISubprogram ( name: "foo" , line: 5 , isLocal: false , isDefinition: true , virtualIndex: 6 , flags: D I F l a g P r o t o t y p e d , isOptimized: true , unit: !0 , scopeLine: 5 , file: !32 , scope: !6 , type: !7 , variables: !1 )
2015-04-30 00:38:44 +08:00
!6 = !DIFile ( filename: "foo.c" , directory: "/tmp" )
!7 = !DISubroutineType ( types: !8 )
IR: Make metadata typeless in assembly
Now that `Metadata` is typeless, reflect that in the assembly. These
are the matching assembly changes for the metadata/value split in
r223802.
- Only use the `metadata` type when referencing metadata from a call
intrinsic -- i.e., only when it's used as a `Value`.
- Stop pretending that `ValueAsMetadata` is wrapped in an `MDNode`
when referencing it from call intrinsics.
So, assembly like this:
define @foo(i32 %v) {
call void @llvm.foo(metadata !{i32 %v}, metadata !0)
call void @llvm.foo(metadata !{i32 7}, metadata !0)
call void @llvm.foo(metadata !1, metadata !0)
call void @llvm.foo(metadata !3, metadata !0)
call void @llvm.foo(metadata !{metadata !3}, metadata !0)
ret void, !bar !2
}
!0 = metadata !{metadata !2}
!1 = metadata !{i32* @global}
!2 = metadata !{metadata !3}
!3 = metadata !{}
turns into this:
define @foo(i32 %v) {
call void @llvm.foo(metadata i32 %v, metadata !0)
call void @llvm.foo(metadata i32 7, metadata !0)
call void @llvm.foo(metadata i32* @global, metadata !0)
call void @llvm.foo(metadata !3, metadata !0)
call void @llvm.foo(metadata !{!3}, metadata !0)
ret void, !bar !2
}
!0 = !{!2}
!1 = !{i32* @global}
!2 = !{!3}
!3 = !{}
I wrote an upgrade script that handled almost all of the tests in llvm
and many of the tests in cfe (even handling many `CHECK` lines). I've
attached it (or will attach it in a moment if you're speedy) to PR21532
to help everyone update their out-of-tree testcases.
This is part of PR21532.
llvm-svn: 224257
2014-12-16 03:07:53 +08:00
!8 = ! { null }
2016-04-15 23:57:41 +08:00
!9 = distinct !DICompileUnit ( language: D W _ L A N G _ C 99 , producer: "clang version 3.2 (trunk 156513)" , isOptimized: true , emissionKind: F u l l D e b u g , file: !32 , enums: !1 , retainedTypes: !1 , globals: !1 , imports: !1 )
!12 = distinct !DISubprogram ( name: "main" , line: 11 , isLocal: false , isDefinition: true , virtualIndex: 6 , flags: D I F l a g P r o t o t y p e d , isOptimized: true , unit: !9 , scopeLine: 11 , file: !32 , scope: !6 , type: !13 , variables: !19 )
2015-04-30 00:38:44 +08:00
!13 = !DISubroutineType ( types: !14 )
2016-01-15 08:46:17 +08:00
!14 = ! { !15 , !15 , !18 }
2015-04-30 00:38:44 +08:00
!15 = !DIBasicType ( tag: D W _ T A G _ b a s e _ type , name: "int" , size: 32 , align: 32 , encoding: D W _ A T E _ s i g n e d )
!18 = !DIBasicType ( tag: D W _ T A G _ b a s e _ type , name: "char" , size: 8 , align: 8 , encoding: D W _ A T E _ s i g n e d _ c h a r )
IR: Make metadata typeless in assembly
Now that `Metadata` is typeless, reflect that in the assembly. These
are the matching assembly changes for the metadata/value split in
r223802.
- Only use the `metadata` type when referencing metadata from a call
intrinsic -- i.e., only when it's used as a `Value`.
- Stop pretending that `ValueAsMetadata` is wrapped in an `MDNode`
when referencing it from call intrinsics.
So, assembly like this:
define @foo(i32 %v) {
call void @llvm.foo(metadata !{i32 %v}, metadata !0)
call void @llvm.foo(metadata !{i32 7}, metadata !0)
call void @llvm.foo(metadata !1, metadata !0)
call void @llvm.foo(metadata !3, metadata !0)
call void @llvm.foo(metadata !{metadata !3}, metadata !0)
ret void, !bar !2
}
!0 = metadata !{metadata !2}
!1 = metadata !{i32* @global}
!2 = metadata !{metadata !3}
!3 = metadata !{}
turns into this:
define @foo(i32 %v) {
call void @llvm.foo(metadata i32 %v, metadata !0)
call void @llvm.foo(metadata i32 7, metadata !0)
call void @llvm.foo(metadata i32* @global, metadata !0)
call void @llvm.foo(metadata !3, metadata !0)
call void @llvm.foo(metadata !{!3}, metadata !0)
ret void, !bar !2
}
!0 = !{!2}
!1 = !{i32* @global}
!2 = !{!3}
!3 = !{}
I wrote an upgrade script that handled almost all of the tests in llvm
and many of the tests in cfe (even handling many `CHECK` lines). I've
attached it (or will attach it in a moment if you're speedy) to PR21532
to help everyone update their out-of-tree testcases.
This is part of PR21532.
llvm-svn: 224257
2014-12-16 03:07:53 +08:00
!19 = ! { !21 , !22 }
2015-08-01 02:58:39 +08:00
!21 = !DILocalVariable ( name: "argc" , line: 11 , arg: 1 , scope: !12 , file: !6 , type: !15 )
2016-01-15 08:46:17 +08:00
!22 = !DILocalVariable ( name: "argv" , line: 11 , arg: 2 , scope: !12 , file: !6 , type: !18 )
2015-04-30 00:38:44 +08:00
!23 = !DILocation ( line: 6 , column: 3 , scope: !24 )
!24 = distinct !DILexicalBlock ( line: 5 , column: 16 , file: !32 , scope: !5 )
!25 = !DILocation ( line: 7 , column: 1 , scope: !24 )
!26 = !DILocation ( line: 11 , column: 14 , scope: !12 )
!27 = !DILocation ( line: 11 , column: 26 , scope: !12 )
!28 = !DILocation ( line: 12 , column: 3 , scope: !29 )
!29 = distinct !DILexicalBlock ( line: 11 , column: 34 , file: !32 , scope: !12 )
!30 = !DILocation ( line: 13 , column: 3 , scope: !29 )
!31 = !DILocation ( line: 14 , column: 3 , scope: !29 )
!32 = !DIFile ( filename: "foo.c" , directory: "/tmp" )
2012-12-04 02:45:45 +08:00
2012-12-04 03:58:12 +08:00
; This test is simple to be cross platform (many targets don't yet have
; sufficiently good DWARF emission and/or dumping)
; CHECK: {{DW_TAG_compile_unit}}
; CHECK: {{foo\.c}}
2012-12-04 02:45:45 +08:00
2015-03-04 01:24:31 +08:00
!33 = ! { i32 1 , !"Debug Info Version" , i32 3 }