1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=x86_64-apple-darwin %s -o %t.o -filetype=obj -O0 2*9880d681SAndroid Build Coastguard Worker; RUN: llvm-dwarfdump %t.o | FileCheck %s 3*9880d681SAndroid Build Coastguard Worker; 4*9880d681SAndroid Build Coastguard Worker; Test that on x86_64, the 32-bit subregister esi is emitted as 5*9880d681SAndroid Build Coastguard Worker; DW_OP_piece 32 of the 64-bit rsi. 6*9880d681SAndroid Build Coastguard Worker; 7*9880d681SAndroid Build Coastguard Worker; rdar://problem/16015314 8*9880d681SAndroid Build Coastguard Worker; 9*9880d681SAndroid Build Coastguard Worker; CHECK: .debug_info contents: 10*9880d681SAndroid Build Coastguard Worker; CHECK: DW_TAG_variable 11*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: DW_AT_location [DW_FORM_data4] (0x00000000) 12*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: DW_AT_name [DW_FORM_strp]{{.*}} "a" 13*9880d681SAndroid Build Coastguard Worker; CHECK: .debug_loc contents: 14*9880d681SAndroid Build Coastguard Worker; rsi, piece 0x00000004 15*9880d681SAndroid Build Coastguard Worker; CHECK: Location description: 54 93 04 16*9880d681SAndroid Build Coastguard Worker; 17*9880d681SAndroid Build Coastguard Worker; struct bar { 18*9880d681SAndroid Build Coastguard Worker; int a; 19*9880d681SAndroid Build Coastguard Worker; int b; 20*9880d681SAndroid Build Coastguard Worker; }; 21*9880d681SAndroid Build Coastguard Worker; 22*9880d681SAndroid Build Coastguard Worker; void doSomething() __attribute__ ((noinline)); 23*9880d681SAndroid Build Coastguard Worker; 24*9880d681SAndroid Build Coastguard Worker; void doSomething(struct bar *b) 25*9880d681SAndroid Build Coastguard Worker; { 26*9880d681SAndroid Build Coastguard Worker; int a = b->a; 27*9880d681SAndroid Build Coastguard Worker; printf("%d\n", a); // set breakpoint here 28*9880d681SAndroid Build Coastguard Worker; } 29*9880d681SAndroid Build Coastguard Worker; 30*9880d681SAndroid Build Coastguard Worker; int main() 31*9880d681SAndroid Build Coastguard Worker; { 32*9880d681SAndroid Build Coastguard Worker; struct bar myBar = { 3, 4 }; 33*9880d681SAndroid Build Coastguard Worker; doSomething(&myBar); 34*9880d681SAndroid Build Coastguard Worker; return 0; 35*9880d681SAndroid Build Coastguard Worker; } 36*9880d681SAndroid Build Coastguard Worker 37*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128" 38*9880d681SAndroid Build Coastguard Workertarget triple = "x86_64-apple-macosx10.9.0" 39*9880d681SAndroid Build Coastguard Worker 40*9880d681SAndroid Build Coastguard Worker%struct.bar = type { i32, i32 } 41*9880d681SAndroid Build Coastguard Worker 42*9880d681SAndroid Build Coastguard Worker@.str = private unnamed_addr constant [4 x i8] c"%d\0A\00", align 1 43*9880d681SAndroid Build Coastguard Worker@main.myBar = private unnamed_addr constant %struct.bar { i32 3, i32 4 }, align 4 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker; Function Attrs: noinline nounwind ssp uwtable 46*9880d681SAndroid Build Coastguard Workerdefine void @doSomething(%struct.bar* nocapture readonly %b) #0 !dbg !4 { 47*9880d681SAndroid Build Coastguard Workerentry: 48*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.value(metadata %struct.bar* %b, i64 0, metadata !15, metadata !DIExpression()), !dbg !25 49*9880d681SAndroid Build Coastguard Worker %a1 = getelementptr inbounds %struct.bar, %struct.bar* %b, i64 0, i32 0, !dbg !26 50*9880d681SAndroid Build Coastguard Worker %0 = load i32, i32* %a1, align 4, !dbg !26, !tbaa !27 51*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.value(metadata i32 %0, i64 0, metadata !16, metadata !DIExpression()), !dbg !26 52*9880d681SAndroid Build Coastguard Worker %call = tail call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i64 0, i64 0), i32 %0) #4, !dbg !32 53*9880d681SAndroid Build Coastguard Worker ret void, !dbg !33 54*9880d681SAndroid Build Coastguard Worker} 55*9880d681SAndroid Build Coastguard Worker 56*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind readnone 57*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.dbg.declare(metadata, metadata, metadata) #1 58*9880d681SAndroid Build Coastguard Worker 59*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind 60*9880d681SAndroid Build Coastguard Workerdeclare i32 @printf(i8* nocapture readonly, ...) #2 61*9880d681SAndroid Build Coastguard Worker 62*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind ssp uwtable 63*9880d681SAndroid Build Coastguard Workerdefine i32 @main() #3 !dbg !17 { 64*9880d681SAndroid Build Coastguard Workerentry: 65*9880d681SAndroid Build Coastguard Worker %myBar = alloca i64, align 8, !dbg !34 66*9880d681SAndroid Build Coastguard Worker %tmpcast = bitcast i64* %myBar to %struct.bar*, !dbg !34 67*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.declare(metadata %struct.bar* %tmpcast, metadata !21, metadata !DIExpression()), !dbg !34 68*9880d681SAndroid Build Coastguard Worker store i64 17179869187, i64* %myBar, align 8, !dbg !34 69*9880d681SAndroid Build Coastguard Worker call void @doSomething(%struct.bar* %tmpcast), !dbg !35 70*9880d681SAndroid Build Coastguard Worker ret i32 0, !dbg !36 71*9880d681SAndroid Build Coastguard Worker} 72*9880d681SAndroid Build Coastguard Worker 73*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind readnone 74*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.dbg.value(metadata, i64, metadata, metadata) #1 75*9880d681SAndroid Build Coastguard Worker 76*9880d681SAndroid Build Coastguard Workerattributes #0 = { noinline nounwind ssp uwtable } 77*9880d681SAndroid Build Coastguard Workerattributes #1 = { nounwind readnone } 78*9880d681SAndroid Build Coastguard Workerattributes #2 = { nounwind } 79*9880d681SAndroid Build Coastguard Workerattributes #3 = { nounwind ssp uwtable } 80*9880d681SAndroid Build Coastguard Workerattributes #4 = { nounwind } 81*9880d681SAndroid Build Coastguard Worker 82*9880d681SAndroid Build Coastguard Worker!llvm.dbg.cu = !{!0} 83*9880d681SAndroid Build Coastguard Worker!llvm.module.flags = !{!22, !23} 84*9880d681SAndroid Build Coastguard Worker!llvm.ident = !{!24} 85*9880d681SAndroid Build Coastguard Worker 86*9880d681SAndroid Build Coastguard Worker!0 = distinct !DICompileUnit(language: DW_LANG_C99, producer: "clang version 3.5 ", isOptimized: true, emissionKind: FullDebug, file: !1, enums: !2, retainedTypes: !2, globals: !2, imports: !2) 87*9880d681SAndroid Build Coastguard Worker!1 = !DIFile(filename: "subregisters.c", directory: "") 88*9880d681SAndroid Build Coastguard Worker!2 = !{} 89*9880d681SAndroid Build Coastguard Worker!4 = distinct !DISubprogram(name: "doSomething", line: 10, isLocal: false, isDefinition: true, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: true, unit: !0, scopeLine: 11, file: !1, scope: !5, type: !6, variables: !14) 90*9880d681SAndroid Build Coastguard Worker!5 = !DIFile(filename: "subregisters.c", directory: "") 91*9880d681SAndroid Build Coastguard Worker!6 = !DISubroutineType(types: !7) 92*9880d681SAndroid Build Coastguard Worker!7 = !{null, !8} 93*9880d681SAndroid Build Coastguard Worker!8 = !DIDerivedType(tag: DW_TAG_pointer_type, size: 64, align: 64, baseType: !9) 94*9880d681SAndroid Build Coastguard Worker!9 = !DICompositeType(tag: DW_TAG_structure_type, name: "bar", line: 3, size: 64, align: 32, file: !1, elements: !10) 95*9880d681SAndroid Build Coastguard Worker!10 = !{!11, !13} 96*9880d681SAndroid Build Coastguard Worker!11 = !DIDerivedType(tag: DW_TAG_member, name: "a", line: 4, size: 32, align: 32, file: !1, scope: !9, baseType: !12) 97*9880d681SAndroid Build Coastguard Worker!12 = !DIBasicType(tag: DW_TAG_base_type, name: "int", size: 32, align: 32, encoding: DW_ATE_signed) 98*9880d681SAndroid Build Coastguard Worker!13 = !DIDerivedType(tag: DW_TAG_member, name: "b", line: 5, size: 32, align: 32, offset: 32, file: !1, scope: !9, baseType: !12) 99*9880d681SAndroid Build Coastguard Worker!14 = !{!15, !16} 100*9880d681SAndroid Build Coastguard Worker!15 = !DILocalVariable(name: "b", line: 10, arg: 1, scope: !4, file: !5, type: !8) 101*9880d681SAndroid Build Coastguard Worker!16 = !DILocalVariable(name: "a", line: 12, scope: !4, file: !5, type: !12) 102*9880d681SAndroid Build Coastguard Worker!17 = distinct !DISubprogram(name: "main", line: 16, isLocal: false, isDefinition: true, virtualIndex: 6, isOptimized: true, unit: !0, scopeLine: 17, file: !1, scope: !5, type: !18, variables: !20) 103*9880d681SAndroid Build Coastguard Worker!18 = !DISubroutineType(types: !19) 104*9880d681SAndroid Build Coastguard Worker!19 = !{!12} 105*9880d681SAndroid Build Coastguard Worker!20 = !{!21} 106*9880d681SAndroid Build Coastguard Worker!21 = !DILocalVariable(name: "myBar", line: 18, scope: !17, file: !5, type: !9) 107*9880d681SAndroid Build Coastguard Worker!22 = !{i32 2, !"Dwarf Version", i32 2} 108*9880d681SAndroid Build Coastguard Worker!23 = !{i32 1, !"Debug Info Version", i32 3} 109*9880d681SAndroid Build Coastguard Worker!24 = !{!"clang version 3.5 "} 110*9880d681SAndroid Build Coastguard Worker!25 = !DILocation(line: 10, scope: !4) 111*9880d681SAndroid Build Coastguard Worker!26 = !DILocation(line: 12, scope: !4) 112*9880d681SAndroid Build Coastguard Worker!27 = !{!28, !29, i64 0} 113*9880d681SAndroid Build Coastguard Worker!28 = !{!"bar", !29, i64 0, !29, i64 4} 114*9880d681SAndroid Build Coastguard Worker!29 = !{!"int", !30, i64 0} 115*9880d681SAndroid Build Coastguard Worker!30 = !{!"omnipotent char", !31, i64 0} 116*9880d681SAndroid Build Coastguard Worker!31 = !{!"Simple C/C++ TBAA"} 117*9880d681SAndroid Build Coastguard Worker!32 = !DILocation(line: 13, scope: !4) 118*9880d681SAndroid Build Coastguard Worker!33 = !DILocation(line: 14, scope: !4) 119*9880d681SAndroid Build Coastguard Worker!34 = !DILocation(line: 18, scope: !17) 120*9880d681SAndroid Build Coastguard Worker!35 = !DILocation(line: 19, scope: !17) 121*9880d681SAndroid Build Coastguard Worker!36 = !DILocation(line: 20, scope: !17) 122