2014-04-02 07:19:23 +08:00
; RUN: llc -O1 -filetype=obj -mtriple=x86_64-apple-darwin < %s > %t
2017-09-12 07:05:20 +08:00
; RUN: llvm-dwarfdump -v %t | FileCheck %s
2014-04-04 07:20:02 +08:00
; RUN: llvm-objdump -r %t | FileCheck -check-prefix=DARWIN %s
2014-04-02 07:19:23 +08:00
; RUN: llc -O1 -filetype=obj -mtriple=x86_64-pc-linux-gnu < %s > %t
2017-09-12 07:05:20 +08:00
; RUN: llvm-dwarfdump -v %t | FileCheck %s
2014-04-02 07:19:23 +08:00
; RUN: llvm-objdump -r %t | FileCheck -check-prefix=LINUX %s
2012-06-22 09:25:12 +08:00
; PR9493
; Adapted from the original test case in r127757.
; We use 'llc -O1' to induce variable 'x' to live in different locations.
; We don't actually care where 'x' lives, or what exact optimizations get
; used, as long as 'x' moves around we're fine.
; // The variable 'x' lives in different locations, so it needs an entry in
; // the .debug_loc table section, referenced by DW_AT_location.
; // This ref is not relocatable on Darwin, and is relocatable elsewhere.
; extern int g(int, int);
; extern int a;
;
; void f(void) {
; int x;
; a = g(0, 0);
; x = 1;
; while (x & 1) { x *= a; }
; a = g(x, 0);
; x = 2;
; while (x & 2) { x *= a; }
; a = g(0, x);
; }
; // The 'x' variable and its symbol reference location
2014-04-02 07:19:23 +08:00
; CHECK: .debug_info contents:
; CHECK: DW_TAG_variable
[dwarfdump] Pretty print location expressions and location lists
Summary:
Based on Fred's patch here: https://reviews.llvm.org/D6771
I can't seem to commandeer the old review, so I'm creating a new one.
With that change the locations exrpessions are pretty printed inline in the
DIE tree. The output looks like this for debug_loc entries:
DW_AT_location [DW_FORM_data4] (0x00000000
0x0000000000000001 - 0x000000000000000b: DW_OP_consts +3
0x000000000000000b - 0x0000000000000012: DW_OP_consts +7
0x0000000000000012 - 0x000000000000001b: DW_OP_reg0 RAX, DW_OP_piece 0x4
0x000000000000001b - 0x0000000000000024: DW_OP_breg5 RDI+0)
And like this for debug_loc.dwo entries:
DW_AT_location [DW_FORM_sec_offset] (0x00000000
Addr idx 2 (w/ length 190): DW_OP_consts +0, DW_OP_stack_value
Addr idx 3 (w/ length 23): DW_OP_reg0 RAX, DW_OP_piece 0x4)
Simple locations without ranges are printed inline:
DW_AT_location [DW_FORM_block1] (DW_OP_reg4 RSI, DW_OP_piece 0x4, DW_OP_bit_piece 0x20 0x0)
The debug_loc(.dwo) dumping in changed accordingly to factor the code.
Reviewers: dblaikie, aprantl, friss
Subscribers: mgorny, javed.absar, hiraditya, llvm-commits, JDevlieghere
Differential Revision: https://reviews.llvm.org/D37123
llvm-svn: 312042
2017-08-30 05:41:21 +08:00
; CHECK-NEXT: DW_AT_location [DW_FORM_sec_offset] (0x00000000
; Check that the location contains only 4 ranges - this verifies that the 4th
; and 5th ranges were successfully merged into a single range.
; CHECK-NEXT: 0x{{[0-9a-f]*}} - 0x{{[0-9a-f]*}}:
; CHECK-NEXT: 0x{{[0-9a-f]*}} - 0x{{[0-9a-f]*}}:
; CHECK-NEXT: 0x{{[0-9a-f]*}} - 0x{{[0-9a-f]*}}:
; CHECK-NEXT: 0x{{[0-9a-f]*}} - 0x{{[0-9a-f]*}}: {{.*}})
2014-04-02 07:19:23 +08:00
; CHECK-NEXT: DW_AT_name {{.*}} "x"
; CHECK-NEXT: DW_AT_decl_file
; CHECK-NEXT: DW_AT_decl_line
; CHECK-NEXT: DW_AT_type
; Check that we have no relocations in Darwin's output.
; DARWIN-NOT: X86_64_RELOC{{.*}} __debug_loc
2012-06-22 09:25:12 +08:00
2014-04-02 07:19:23 +08:00
; Check we have a relocation for the debug_loc entry in Linux output.
; LINUX: RELOCATION RECORDS FOR [.rela.debug_info]
; LINUX-NOT: RELOCATION RECORDS
; LINUX: R_X86_64{{.*}} .debug_loc+0
2012-06-22 09:25:12 +08:00
; ModuleID = 'simple.c'
target datalayout = "e-p:32:32:32-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-n32"
@a = external global i32
2015-11-06 06:03:56 +08:00
define void @f ( ) nounwind !dbg !0 {
2012-06-22 09:25:12 +08:00
entry:
%call = tail call i32 @g ( i32 0 , i32 0 ) nounwind , !dbg !8
2013-05-01 01:52:57 +08:00
store i32 %call , i32 * @a , align 4 , !dbg !8
2017-07-29 04:21:02 +08:00
tail call void @llvm.dbg.value ( metadata i32 1 , metadata !5 , metadata !DIExpression ( ) ) , !dbg !13
2012-06-22 09:25:12 +08:00
br label %while.body
while.body: ; preds = %entry, %while.body
%x.017 = phi i32 [ 1 , %entry ] , [ %mul , %while.body ]
%mul = mul nsw i32 %call , %x.017 , !dbg !14
%and = and i32 %mul , 1 , !dbg !14
%tobool = icmp eq i32 %and , 0 , !dbg !14
br i1 %tobool , label %while.end , label %while.body , !dbg !14
while.end: ; preds = %while.body
2017-07-29 04:21:02 +08:00
tail call void @llvm.dbg.value ( metadata i32 %mul , metadata !5 , metadata !DIExpression ( ) ) , !dbg !14
2012-06-22 09:25:12 +08:00
%call4 = tail call i32 @g ( i32 %mul , i32 0 ) nounwind , !dbg !15
2013-05-01 01:52:57 +08:00
store i32 %call4 , i32 * @a , align 4 , !dbg !15
2017-07-29 04:21:02 +08:00
tail call void @llvm.dbg.value ( metadata i32 2 , metadata !5 , metadata !DIExpression ( ) ) , !dbg !17
2012-06-22 09:25:12 +08:00
br label %while.body9
while.body9: ; preds = %while.end, %while.body9
%x.116 = phi i32 [ 2 , %while.end ] , [ %mul12 , %while.body9 ]
%mul12 = mul nsw i32 %call4 , %x.116 , !dbg !18
%and7 = and i32 %mul12 , 2 , !dbg !18
%tobool8 = icmp eq i32 %and7 , 0 , !dbg !18
br i1 %tobool8 , label %while.end13 , label %while.body9 , !dbg !18
while.end13: ; preds = %while.body9
2017-07-29 04:21:02 +08:00
tail call void @llvm.dbg.value ( metadata i32 %mul12 , metadata !5 , metadata !DIExpression ( ) ) , !dbg !18
2012-06-22 09:25:12 +08:00
%call15 = tail call i32 @g ( i32 0 , i32 %mul12 ) nounwind , !dbg !19
2013-05-01 01:52:57 +08:00
store i32 %call15 , i32 * @a , align 4 , !dbg !19
2012-06-22 09:25:12 +08:00
ret void , !dbg !20
}
declare i32 @g ( i32 , i32 )
2017-07-29 04:21:02 +08:00
declare void @llvm.dbg.value ( metadata , metadata , metadata ) nounwind readnone
2012-06-22 09:25:12 +08:00
2013-03-08 08:23:31 +08:00
!llvm.dbg.cu = ! { !2 }
2013-11-23 05:49:45 +08:00
!llvm.module.flags = ! { !24 }
2012-06-22 09:25:12 +08:00
2016-04-15 23:57:41 +08:00
!0 = distinct !DISubprogram ( name: "f" , line: 4 , 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: !2 , scopeLine: 4 , file: !23 , scope: !1 , type: !3 , variables: !22 )
2015-04-30 00:38:44 +08:00
!1 = !DIFile ( filename: "simple.c" , directory: "/home/rengol01/temp/tests/dwarf/relocation" )
2016-04-15 23:57:41 +08:00
!2 = distinct !DICompileUnit ( language: D W _ L A N G _ C 99 , producer: "clang version 3.0 (trunk)" , isOptimized: true , emissionKind: F u l l D e b u g , file: !23 , enums: ! { } , retainedTypes: ! { } , imports: null )
2015-04-30 00:38:44 +08:00
!3 = !DISubroutineType ( types: !4 )
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
!4 = ! { null }
2015-08-01 02:58:39 +08:00
!5 = !DILocalVariable ( name: "x" , line: 5 , scope: !6 , file: !1 , type: !7 )
2015-04-30 00:38:44 +08:00
!6 = distinct !DILexicalBlock ( line: 4 , column: 14 , file: !23 , scope: !0 )
!7 = !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 )
!8 = !DILocation ( line: 6 , column: 3 , scope: !6 )
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
!12 = ! { i32 1 }
2015-04-30 00:38:44 +08:00
!13 = !DILocation ( line: 7 , column: 3 , scope: !6 )
!14 = !DILocation ( line: 8 , column: 3 , scope: !6 )
!15 = !DILocation ( line: 9 , column: 3 , scope: !6 )
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
!16 = ! { i32 2 }
2015-04-30 00:38:44 +08:00
!17 = !DILocation ( line: 10 , column: 3 , scope: !6 )
!18 = !DILocation ( line: 11 , column: 3 , scope: !6 )
!19 = !DILocation ( line: 12 , column: 3 , scope: !6 )
!20 = !DILocation ( line: 13 , column: 1 , scope: !6 )
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
!22 = ! { !5 }
2015-04-30 00:38:44 +08:00
!23 = !DIFile ( filename: "simple.c" , directory: "/home/rengol01/temp/tests/dwarf/relocation" )
2015-03-04 01:24:31 +08:00
!24 = ! { i32 1 , !"Debug Info Version" , i32 3 }