1*9880d681SAndroid Build Coastguard Worker; RUN: llc -filetype=obj -o - < %s | llvm-dwarfdump - | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; 3*9880d681SAndroid Build Coastguard Worker; Created using clang -g -O3 from: 4*9880d681SAndroid Build Coastguard Worker; struct S0 { 5*9880d681SAndroid Build Coastguard Worker; short f0; 6*9880d681SAndroid Build Coastguard Worker; int f3; 7*9880d681SAndroid Build Coastguard Worker; } a; 8*9880d681SAndroid Build Coastguard Worker; void fn1(short p1) { 9*9880d681SAndroid Build Coastguard Worker; struct S0 b, c = {3}; 10*9880d681SAndroid Build Coastguard Worker; b.f3 = p1; 11*9880d681SAndroid Build Coastguard Worker; a = b = c; 12*9880d681SAndroid Build Coastguard Worker; } 13*9880d681SAndroid Build Coastguard Worker; 14*9880d681SAndroid Build Coastguard Worker; int main() { return 0; } 15*9880d681SAndroid Build Coastguard Worker; 16*9880d681SAndroid Build Coastguard Worker; This is similar to the bug in test/DebugInfo/ARM/PR26163.ll, except that there is an 17*9880d681SAndroid Build Coastguard Worker; extra non-overlapping range first. Thus, we make sure that the backend actually looks 18*9880d681SAndroid Build Coastguard Worker; at all expressions when determining whether to merge ranges, not just the first one. 19*9880d681SAndroid Build Coastguard Worker; AS in 26163, we expect two ranges (as opposed to one), the first one being zero sized 20*9880d681SAndroid Build Coastguard Worker; 21*9880d681SAndroid Build Coastguard Worker; 22*9880d681SAndroid Build Coastguard Worker; CHECK: 0x00000025: Beginning address offset: 0x0000000000000004 23*9880d681SAndroid Build Coastguard Worker; CHECK: Ending address offset: 0x0000000000000004 24*9880d681SAndroid Build Coastguard Worker; CHECK: Location description: 10 03 55 93 04 25*9880d681SAndroid Build Coastguard Worker; CHECK: Beginning address offset: 0x0000000000000004 26*9880d681SAndroid Build Coastguard Worker; CHECK: Ending address offset: 0x0000000000000014 27*9880d681SAndroid Build Coastguard Worker; CHECK: Location description: 10 03 10 00 28*9880d681SAndroid Build Coastguard Worker 29*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128" 30*9880d681SAndroid Build Coastguard Workertarget triple = "x86_64-apple-macosx10.11.0" 31*9880d681SAndroid Build Coastguard Worker 32*9880d681SAndroid Build Coastguard Worker%struct.S0 = type { i16, i32 } 33*9880d681SAndroid Build Coastguard Worker 34*9880d681SAndroid Build Coastguard Worker@a = common global %struct.S0 zeroinitializer, align 4 35*9880d681SAndroid Build Coastguard Worker 36*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.dbg.declare(metadata, metadata, metadata) 37*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.dbg.value(metadata, i64, metadata, metadata) 38*9880d681SAndroid Build Coastguard Worker 39*9880d681SAndroid Build Coastguard Worker; The attributes are here to force the zero-sized range not to be at the start of 40*9880d681SAndroid Build Coastguard Worker; the function, which has special interpretation in DWARF. The fact that this happens 41*9880d681SAndroid Build Coastguard Worker; at all is probably an LLVM bug. 42*9880d681SAndroid Build Coastguard Workerattributes #0 = { "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" } 43*9880d681SAndroid Build Coastguard Workerdefine void @fn1(i16 signext %p1) #0 !dbg !4 { 44*9880d681SAndroid Build Coastguard Workerentry: 45*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.value(metadata i16 %p1, i64 0, metadata !9, metadata !26), !dbg !27 46*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.declare(metadata %struct.S0* undef, metadata !10, metadata !26), !dbg !28 47*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.declare(metadata %struct.S0* undef, metadata !16, metadata !26), !dbg !29 48*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.value(metadata i32 3, i64 0, metadata !16, metadata !30), !dbg !29 49*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.value(metadata i32 0, i64 0, metadata !16, metadata !31), !dbg !29 50*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.value(metadata i16 %p1, i64 0, metadata !10, metadata !32), !dbg !28 51*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.value(metadata i32 3, i64 0, metadata !10, metadata !30), !dbg !28 52*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.value(metadata i32 0, i64 0, metadata !10, metadata !31), !dbg !28 53*9880d681SAndroid Build Coastguard Worker store i32 3, i32* bitcast (%struct.S0* @a to i32*), align 4, !dbg !33 54*9880d681SAndroid Build Coastguard Worker store i32 0, i32* getelementptr inbounds (%struct.S0, %struct.S0* @a, i64 0, i32 1), align 4, !dbg !33 55*9880d681SAndroid Build Coastguard Worker ret void, !dbg !34 56*9880d681SAndroid Build Coastguard Worker} 57*9880d681SAndroid Build Coastguard Worker 58*9880d681SAndroid Build Coastguard Workerdefine i32 @main() !dbg !17 { 59*9880d681SAndroid Build Coastguard Workerentry: 60*9880d681SAndroid Build Coastguard Worker ret i32 0, !dbg !35 61*9880d681SAndroid Build Coastguard Worker} 62*9880d681SAndroid Build Coastguard Worker 63*9880d681SAndroid Build Coastguard Worker!llvm.dbg.cu = !{!0} 64*9880d681SAndroid Build Coastguard Worker!llvm.module.flags = !{!22, !23, !24} 65*9880d681SAndroid Build Coastguard Worker!llvm.ident = !{!25} 66*9880d681SAndroid Build Coastguard Worker 67*9880d681SAndroid Build Coastguard Worker!0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, producer: "clang version 3.9.0 (https://github.com/llvm-mirror/clang 8f258397c5afd7a708bd95770c718e81d08fb11a) (https://github.com/llvm-mirror/llvm 18481855bdfa1b4a424f81be8525db002671348d)", isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, enums: !2, globals: !20) 68*9880d681SAndroid Build Coastguard Worker!1 = !DIFile(filename: "small.c", directory: "/Users/kfischer/Projects/clangbug") 69*9880d681SAndroid Build Coastguard Worker!2 = !{} 70*9880d681SAndroid Build Coastguard Worker!4 = distinct !DISubprogram(name: "fn1", scope: !1, file: !1, line: 5, type: !5, isLocal: false, isDefinition: true, scopeLine: 5, flags: DIFlagPrototyped, isOptimized: true, unit: !0, variables: !8) 71*9880d681SAndroid Build Coastguard Worker!5 = !DISubroutineType(types: !6) 72*9880d681SAndroid Build Coastguard Worker!6 = !{null, !7} 73*9880d681SAndroid Build Coastguard Worker!7 = !DIBasicType(name: "short", size: 16, align: 16, encoding: DW_ATE_signed) 74*9880d681SAndroid Build Coastguard Worker!8 = !{!9, !10, !16} 75*9880d681SAndroid Build Coastguard Worker!9 = !DILocalVariable(name: "p1", arg: 1, scope: !4, file: !1, line: 5, type: !7) 76*9880d681SAndroid Build Coastguard Worker!10 = !DILocalVariable(name: "b", scope: !4, file: !1, line: 6, type: !11) 77*9880d681SAndroid Build Coastguard Worker!11 = !DICompositeType(tag: DW_TAG_structure_type, name: "S0", file: !1, line: 1, size: 64, align: 32, elements: !12) 78*9880d681SAndroid Build Coastguard Worker!12 = !{!13, !14} 79*9880d681SAndroid Build Coastguard Worker!13 = !DIDerivedType(tag: DW_TAG_member, name: "f0", scope: !11, file: !1, line: 2, baseType: !7, size: 16, align: 16) 80*9880d681SAndroid Build Coastguard Worker!14 = !DIDerivedType(tag: DW_TAG_member, name: "f3", scope: !11, file: !1, line: 3, baseType: !15, size: 32, align: 32, offset: 32) 81*9880d681SAndroid Build Coastguard Worker!15 = !DIBasicType(name: "int", size: 32, align: 32, encoding: DW_ATE_signed) 82*9880d681SAndroid Build Coastguard Worker!16 = !DILocalVariable(name: "c", scope: !4, file: !1, line: 6, type: !11) 83*9880d681SAndroid Build Coastguard Worker!17 = distinct !DISubprogram(name: "main", scope: !1, file: !1, line: 11, type: !18, isLocal: false, isDefinition: true, scopeLine: 11, isOptimized: true, unit: !0, variables: !2) 84*9880d681SAndroid Build Coastguard Worker!18 = !DISubroutineType(types: !19) 85*9880d681SAndroid Build Coastguard Worker!19 = !{!15} 86*9880d681SAndroid Build Coastguard Worker!20 = !{!21} 87*9880d681SAndroid Build Coastguard Worker!21 = !DIGlobalVariable(name: "a", scope: !0, file: !1, line: 4, type: !11, isLocal: false, isDefinition: true, variable: %struct.S0* @a) 88*9880d681SAndroid Build Coastguard Worker!22 = !{i32 2, !"Dwarf Version", i32 2} 89*9880d681SAndroid Build Coastguard Worker!23 = !{i32 2, !"Debug Info Version", i32 3} 90*9880d681SAndroid Build Coastguard Worker!24 = !{i32 1, !"PIC Level", i32 2} 91*9880d681SAndroid Build Coastguard Worker!25 = !{!"clang version 3.9.0 (https://github.com/llvm-mirror/clang 8f258397c5afd7a708bd95770c718e81d08fb11a) (https://github.com/llvm-mirror/llvm 18481855bdfa1b4a424f81be8525db002671348d)"} 92*9880d681SAndroid Build Coastguard Worker!26 = !DIExpression() 93*9880d681SAndroid Build Coastguard Worker!27 = !DILocation(line: 5, column: 16, scope: !4) 94*9880d681SAndroid Build Coastguard Worker!28 = !DILocation(line: 6, column: 13, scope: !4) 95*9880d681SAndroid Build Coastguard Worker!29 = !DILocation(line: 6, column: 16, scope: !4) 96*9880d681SAndroid Build Coastguard Worker!30 = !DIExpression(DW_OP_bit_piece, 0, 32) 97*9880d681SAndroid Build Coastguard Worker!31 = !DIExpression(DW_OP_bit_piece, 32, 32) 98*9880d681SAndroid Build Coastguard Worker!32 = !DIExpression(DW_OP_bit_piece, 32, 16) 99*9880d681SAndroid Build Coastguard Worker!33 = !DILocation(line: 8, column: 9, scope: !4) 100*9880d681SAndroid Build Coastguard Worker!34 = !DILocation(line: 9, column: 1, scope: !4) 101*9880d681SAndroid Build Coastguard Worker!35 = !DILocation(line: 11, column: 14, scope: !17) 102