xref: /aosp_15_r20/external/llvm/test/DebugInfo/X86/subreg.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc %s -mtriple=x86_64-pc-linux-gnu -O0 -o - | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker; We are testing that a value in a 16 bit register gets reported as
4*9880d681SAndroid Build Coastguard Worker; being in its superregister.
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Worker; CHECK: .byte   80                      # super-register DW_OP_reg0
7*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte   147                # DW_OP_piece
8*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte   2                  # 2
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Workerdefine i16 @f(i16 signext %zzz) nounwind !dbg !1 {
11*9880d681SAndroid Build Coastguard Workerentry:
12*9880d681SAndroid Build Coastguard Worker  call void @llvm.dbg.value(metadata i16 %zzz, i64 0, metadata !0, metadata !DIExpression()), !dbg !DILocation(scope: !1)
13*9880d681SAndroid Build Coastguard Worker  %conv = sext i16 %zzz to i32, !dbg !7
14*9880d681SAndroid Build Coastguard Worker  %conv1 = trunc i32 %conv to i16
15*9880d681SAndroid Build Coastguard Worker  ret i16 %conv1
16*9880d681SAndroid Build Coastguard Worker}
17*9880d681SAndroid Build Coastguard Worker
18*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.dbg.value(metadata, i64, metadata, metadata) nounwind readnone
19*9880d681SAndroid Build Coastguard Worker
20*9880d681SAndroid Build Coastguard Worker!llvm.dbg.cu = !{!3}
21*9880d681SAndroid Build Coastguard Worker!llvm.module.flags = !{!11}
22*9880d681SAndroid Build Coastguard Worker!9 = !{!1}
23*9880d681SAndroid Build Coastguard Worker
24*9880d681SAndroid Build Coastguard Worker!0 = !DILocalVariable(name: "zzz", line: 3, arg: 1, scope: !1, file: !2, type: !6)
25*9880d681SAndroid Build Coastguard Worker!1 = distinct !DISubprogram(name: "f", line: 3, isLocal: false, isDefinition: true, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: false, unit: !3, scopeLine: 3, file: !10, scope: !2, type: !4)
26*9880d681SAndroid Build Coastguard Worker!2 = !DIFile(filename: "/home/espindola/llvm/test.c", directory: "/home/espindola/tmpfs/build")
27*9880d681SAndroid Build Coastguard Worker!3 = distinct !DICompileUnit(language: DW_LANG_C99, producer: "clang version 3.0 ()", isOptimized: false, emissionKind: FullDebug, file: !10, enums: !{}, retainedTypes: !{}, imports:  null)
28*9880d681SAndroid Build Coastguard Worker!4 = !DISubroutineType(types: !5)
29*9880d681SAndroid Build Coastguard Worker!5 = !{null}
30*9880d681SAndroid Build Coastguard Worker!6 = !DIBasicType(tag: DW_TAG_base_type, name: "short", size: 16, align: 16, encoding: DW_ATE_signed)
31*9880d681SAndroid Build Coastguard Worker!7 = !DILocation(line: 4, column: 22, scope: !8)
32*9880d681SAndroid Build Coastguard Worker!8 = distinct !DILexicalBlock(line: 3, column: 19, file: !10, scope: !1)
33*9880d681SAndroid Build Coastguard Worker!10 = !DIFile(filename: "/home/espindola/llvm/test.c", directory: "/home/espindola/tmpfs/build")
34*9880d681SAndroid Build Coastguard Worker!11 = !{i32 1, !"Debug Info Version", i32 3}
35