1*9880d681SAndroid Build Coastguard Worker; RUN: llc -filetype=obj -O0 -relocation-model=pic < %s -mtriple mips-unknown-linux-gnu | llvm-dwarfdump - | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; PR19815 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; Generated using clang -target mips-linux-gnu -g test.c -S -o - -flto|opt -sroa -S 5*9880d681SAndroid Build Coastguard Worker; test.c: 6*9880d681SAndroid Build Coastguard Worker; 7*9880d681SAndroid Build Coastguard Worker; int foo(int x) { 8*9880d681SAndroid Build Coastguard Worker; if (x) 9*9880d681SAndroid Build Coastguard Worker; return 0; 10*9880d681SAndroid Build Coastguard Worker; return 1; 11*9880d681SAndroid Build Coastguard Worker; } 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Worker; CHECK: Address Line Column File ISA Discriminator Flags 14*9880d681SAndroid Build Coastguard Worker; CHECK: ------------------ ------ ------ ------ --- ------------- ------------- 15*9880d681SAndroid Build Coastguard Worker; CHECK: 0x0000000000000000 1 0 1 0 0 is_stmt 16*9880d681SAndroid Build Coastguard Worker; FIXME: The next address probably ought to be 0x0000000000000004 but there's 17*9880d681SAndroid Build Coastguard Worker; a constant initialization before the prologue's end. 18*9880d681SAndroid Build Coastguard Worker; CHECK: 0x0000000000000008 2 0 1 0 0 is_stmt prologue_end 19*9880d681SAndroid Build Coastguard Worker; CHECK: 0x000000000000002c 3 0 1 0 0 is_stmt 20*9880d681SAndroid Build Coastguard Worker; CHECK: 0x000000000000003c 4 0 1 0 0 is_stmt 21*9880d681SAndroid Build Coastguard Worker; CHECK: 0x0000000000000048 5 0 1 0 0 is_stmt 22*9880d681SAndroid Build Coastguard Worker; CHECK: 0x0000000000000058 5 0 1 0 0 is_stmt end_sequence 23*9880d681SAndroid Build Coastguard Worker 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Workertarget datalayout = "E-m:m-p:32:32-i8:8:32-i16:16:32-i64:64-n32-S64" 26*9880d681SAndroid Build Coastguard Workertarget triple = "mips--linux-gnu" 27*9880d681SAndroid Build Coastguard Worker 28*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind 29*9880d681SAndroid Build Coastguard Workerdefine i32 @foo(i32 %x) #0 !dbg !4 { 30*9880d681SAndroid Build Coastguard Workerentry: 31*9880d681SAndroid Build Coastguard Worker call void @llvm.dbg.value(metadata i32 %x, i64 0, metadata !12, metadata !DIExpression()), !dbg !13 32*9880d681SAndroid Build Coastguard Worker %tobool = icmp ne i32 %x, 0, !dbg !14 33*9880d681SAndroid Build Coastguard Worker br i1 %tobool, label %if.then, label %if.end, !dbg !14 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Workerif.then: ; preds = %entry 36*9880d681SAndroid Build Coastguard Worker br label %return, !dbg !16 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Workerif.end: ; preds = %entry 39*9880d681SAndroid Build Coastguard Worker br label %return, !dbg !17 40*9880d681SAndroid Build Coastguard Worker 41*9880d681SAndroid Build Coastguard Workerreturn: ; preds = %if.end, %if.then 42*9880d681SAndroid Build Coastguard Worker %retval.0 = phi i32 [ 0, %if.then ], [ 1, %if.end ] 43*9880d681SAndroid Build Coastguard Worker ret i32 %retval.0, !dbg !18 44*9880d681SAndroid Build Coastguard Worker} 45*9880d681SAndroid Build Coastguard Worker 46*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind readnone 47*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.dbg.declare(metadata, metadata, metadata) #1 48*9880d681SAndroid Build Coastguard Worker 49*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind readnone 50*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.dbg.value(metadata, i64, metadata, metadata) #1 51*9880d681SAndroid Build Coastguard Worker 52*9880d681SAndroid Build Coastguard Workerattributes #0 = { nounwind } 53*9880d681SAndroid Build Coastguard Workerattributes #1 = { nounwind readnone } 54*9880d681SAndroid Build Coastguard Worker 55*9880d681SAndroid Build Coastguard Worker!llvm.dbg.cu = !{!0} 56*9880d681SAndroid Build Coastguard Worker!llvm.module.flags = !{!9, !10} 57*9880d681SAndroid Build Coastguard Worker!llvm.ident = !{!11} 58*9880d681SAndroid Build Coastguard Worker 59*9880d681SAndroid Build Coastguard Worker!0 = distinct !DICompileUnit(language: DW_LANG_C99, producer: "clang version 3.5.0 ", isOptimized: false, emissionKind: FullDebug, file: !1, enums: !2, retainedTypes: !2, globals: !2, imports: !2) 60*9880d681SAndroid Build Coastguard Worker!1 = !DIFile(filename: "test.c", directory: "/tmp") 61*9880d681SAndroid Build Coastguard Worker!2 = !{} 62*9880d681SAndroid Build Coastguard Worker!4 = distinct !DISubprogram(name: "foo", line: 1, isLocal: false, isDefinition: true, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: false, unit: !0, scopeLine: 1, file: !1, scope: !5, type: !6, variables: !2) 63*9880d681SAndroid Build Coastguard Worker!5 = !DIFile(filename: "test.c", directory: "/tmp") 64*9880d681SAndroid Build Coastguard Worker!6 = !DISubroutineType(types: !7) 65*9880d681SAndroid Build Coastguard Worker!7 = !{!8, !8} 66*9880d681SAndroid Build Coastguard Worker!8 = !DIBasicType(tag: DW_TAG_base_type, name: "int", size: 32, align: 32, encoding: DW_ATE_signed) 67*9880d681SAndroid Build Coastguard Worker!9 = !{i32 2, !"Dwarf Version", i32 4} 68*9880d681SAndroid Build Coastguard Worker!10 = !{i32 2, !"Debug Info Version", i32 3} 69*9880d681SAndroid Build Coastguard Worker!11 = !{!"clang version 3.5.0"} 70*9880d681SAndroid Build Coastguard Worker!12 = !DILocalVariable(name: "x", line: 1, arg: 1, scope: !4, file: !5, type: !8) 71*9880d681SAndroid Build Coastguard Worker!13 = !DILocation(line: 1, scope: !4) 72*9880d681SAndroid Build Coastguard Worker!14 = !DILocation(line: 2, scope: !15) 73*9880d681SAndroid Build Coastguard Worker!15 = distinct !DILexicalBlock(line: 2, column: 0, file: !1, scope: !4) 74*9880d681SAndroid Build Coastguard Worker!16 = !DILocation(line: 3, scope: !15) 75*9880d681SAndroid Build Coastguard Worker!17 = !DILocation(line: 4, scope: !4) 76*9880d681SAndroid Build Coastguard Worker!18 = !DILocation(line: 5, scope: !4) 77