2016-08-16 02:18:26 +08:00
; REQUIRES: object-emission
; Check that when variables are allocated on the stack we generate debug locations
; for the stack location directly instead of generating a register+offset indirection.
2016-08-16 06:54:26 +08:00
; RUN: llc -O2 -filetype=obj -disable-post-ra -mtriple=x86_64-unknown-linux-gnu < %s \
2017-09-12 07:05:20 +08:00
; RUN: | llvm-dwarfdump -v - | FileCheck %s
2016-08-16 02:18:26 +08:00
;
; int data = 17;
; int sum = 0;
; int zero = 0;
; int *ptr;
;
; extern void foo(int i, int *p);
;
; int main()
; {
; int val;
; val = data;
; foo(1, &val);
; foo(2, &data);
; return zero;
; }
;
; CHECK: .debug_info contents
; CHECK: DW_TAG_subprogram
; CHECK-NOT: NULL
; 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: DW_AT_location [DW_FORM_sec_offset] ({{.*}}
2018-01-16 19:17:57 +08:00
; CHECK-NEXT: [{{0x.*}}, {{0x.*}}): DW_OP_reg0 RAX
; CHECK-NEXT: [{{0x.*}}, {{0x.*}}): DW_OP_breg7 RSP+4, DW_OP_deref)
[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_name {{.*}}"val"
2016-08-16 02:18:26 +08:00
; ModuleID = 'frame.c'
source_filename = "frame.c"
2016-12-22 08:45:21 +08:00
@data = global i32 17 , align 4 , !dbg !0
2016-09-13 09:12:59 +08:00
@sum = local_unnamed_addr global i32 0 , align 4 , !dbg !6
2016-12-22 08:45:21 +08:00
@zero = local_unnamed_addr global i32 0 , align 4 , !dbg !9
@ptr = common local_unnamed_addr global i32 * null , align 8 , !dbg !11
2016-08-16 02:18:26 +08:00
2016-12-22 08:45:21 +08:00
define i32 @main ( ) local_unnamed_addr !dbg !17 {
2016-08-16 02:18:26 +08:00
entry:
%val = alloca i32 , align 4
2016-12-22 08:45:21 +08:00
%0 = bitcast i32 * %val to i8 * , !dbg !22
call void @llvm.lifetime.start ( i64 4 , i8 * %0 ) , !dbg !22
%1 = load i32 , i32 * @data , align 4 , !dbg !23 , !tbaa !24
2017-07-29 04:21:02 +08:00
tail call void @llvm.dbg.value ( metadata i32 %1 , metadata !21 , metadata !28 ) , !dbg !29
2016-12-22 08:45:21 +08:00
store i32 %1 , i32 * %val , align 4 , !dbg !30 , !tbaa !24
2017-07-29 04:21:02 +08:00
tail call void @llvm.dbg.value ( metadata i32 * %val , metadata !21 , metadata !31 ) , !dbg !29
2016-12-22 08:45:21 +08:00
call void @foo ( i32 1 , i32 * nonnull %val ) , !dbg !32
call void @foo ( i32 2 , i32 * nonnull @data ) , !dbg !33
%2 = load i32 , i32 * @zero , align 4 , !dbg !34 , !tbaa !24
call void @llvm.lifetime.end ( i64 4 , i8 * %0 ) , !dbg !35
ret i32 %2 , !dbg !36
2016-08-16 02:18:26 +08:00
}
; Function Attrs: argmemonly nounwind
2016-12-22 08:45:21 +08:00
declare void @llvm.lifetime.start ( i64 , i8 * nocapture ) #0
2016-08-16 02:18:26 +08:00
declare void @foo ( i32 , i32 * ) local_unnamed_addr
; Function Attrs: argmemonly nounwind
2016-12-22 08:45:21 +08:00
declare void @llvm.lifetime.end ( i64 , i8 * nocapture ) #0
2016-08-16 02:18:26 +08:00
; Function Attrs: nounwind readnone
2017-07-29 04:21:02 +08:00
declare void @llvm.dbg.value ( metadata , metadata , metadata ) #1
2016-08-16 02:18:26 +08:00
2016-12-22 08:45:21 +08:00
attributes #0 = { argmemonly nounwind }
attributes #1 = { nounwind readnone }
!llvm.dbg.cu = ! { !2 }
!llvm.module.flags = ! { !14 , !15 }
!llvm.ident = ! { !16 }
2017-08-31 02:06:51 +08:00
!0 = distinct !DIGlobalVariableExpression ( var: !1 , expr: !DIExpression ( ) )
2016-12-22 08:45:21 +08:00
!1 = !DIGlobalVariable ( name: "data" , scope: !2 , file: !3 , line: 1 , type: !8 , isLocal: false , isDefinition: true )
!2 = distinct !DICompileUnit ( language: D W _ L A N G _ C 99 , file: !3 , producer: "clang version 3.9.0 (trunk 273961)" , isOptimized: true , runtimeVersion: 0 , emissionKind: F u l l D e b u g , enums: !4 , globals: !5 )
!3 = !DIFile ( filename: "frame.c" , directory: "/home/user/test" )
!4 = ! { }
!5 = ! { !0 , !6 , !9 , !11 }
2017-08-31 02:06:51 +08:00
!6 = distinct !DIGlobalVariableExpression ( var: !7 , expr: !DIExpression ( ) )
2016-12-22 08:45:21 +08:00
!7 = !DIGlobalVariable ( name: "sum" , scope: !2 , file: !3 , line: 2 , type: !8 , isLocal: false , isDefinition: true )
!8 = !DIBasicType ( name: "int" , size: 32 , align: 32 , encoding: D W _ A T E _ s i g n e d )
2017-08-31 02:06:51 +08:00
!9 = distinct !DIGlobalVariableExpression ( var: !10 , expr: !DIExpression ( ) )
2016-12-22 08:45:21 +08:00
!10 = !DIGlobalVariable ( name: "zero" , scope: !2 , file: !3 , line: 3 , type: !8 , isLocal: false , isDefinition: true )
2017-08-31 02:06:51 +08:00
!11 = distinct !DIGlobalVariableExpression ( var: !12 , expr: !DIExpression ( ) )
2016-12-22 08:45:21 +08:00
!12 = !DIGlobalVariable ( name: "ptr" , scope: !2 , file: !3 , line: 4 , type: !13 , isLocal: false , isDefinition: true )
!13 = !DIDerivedType ( tag: D W _ T A G _ p o i n t e r _ type , baseType: !8 , size: 64 , align: 64 )
!14 = ! { i32 2 , !"Dwarf Version" , i32 4 }
!15 = ! { i32 2 , !"Debug Info Version" , i32 3 }
!16 = ! { !"clang version 3.9.0 (trunk 273961)" }
!17 = distinct !DISubprogram ( name: "main" , scope: !3 , file: !3 , line: 8 , type: !18 , isLocal: false , isDefinition: true , scopeLine: 9 , isOptimized: true , unit: !2 , variables: !20 )
!18 = !DISubroutineType ( types: !19 )
!19 = ! { !8 }
!20 = ! { !21 }
!21 = !DILocalVariable ( name: "val" , scope: !17 , file: !3 , line: 10 , type: !8 )
!22 = !DILocation ( line: 10 , column: 3 , scope: !17 )
!23 = !DILocation ( line: 11 , column: 9 , scope: !17 )
!24 = ! { !25 , !25 , i64 0 }
!25 = ! { !"int" , !26 , i64 0 }
!26 = ! { !"omnipotent char" , !27 , i64 0 }
!27 = ! { !"Simple C/C++ TBAA" }
!28 = !DIExpression ( )
!29 = !DILocation ( line: 10 , column: 7 , scope: !17 )
!30 = !DILocation ( line: 11 , column: 7 , scope: !17 )
!31 = !DIExpression ( D W _ O P _ d e r e f )
!32 = !DILocation ( line: 12 , column: 3 , scope: !17 )
!33 = !DILocation ( line: 13 , column: 3 , scope: !17 )
!34 = !DILocation ( line: 14 , column: 10 , scope: !17 )
!35 = !DILocation ( line: 15 , column: 1 , scope: !17 )
!36 = !DILocation ( line: 14 , column: 3 , scope: !17 )
2016-08-16 02:18:26 +08:00