xref: /aosp_15_r20/external/llvm/test/DebugInfo/X86/PR26148.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
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