Fix a regression I recently introduced by removing DwarfRegNum of
[oota-llvm.git] / test / DebugInfo / X86 / subreg.ll
1 ; RUN: llc %s -mtriple=x86_64-pc-linux-gnu -O0 -o - | FileCheck %s
2
3 ; We are testing that a value in a 16 bit register gets reported as
4 ; being in its superregister.
5 ; FIXME: There should be a DW_OP_bit_piece too.
6
7 ; CHECK: .byte   80                      # DW_OP_reg0
8
9 define i16 @f(i16 signext %zzz) nounwind {
10 entry:
11   call void @llvm.dbg.value(metadata !{i16 %zzz}, i64 0, metadata !0)
12   %conv = sext i16 %zzz to i32, !dbg !7
13   %conv1 = trunc i32 %conv to i16
14   ret i16 %conv1
15 }
16
17 declare void @llvm.dbg.value(metadata, i64, metadata) nounwind readnone
18
19 !0 = metadata !{i32 590081, metadata !1, metadata !"zzz", metadata !2, i32 16777219, metadata !6, i32 0} ; [ DW_TAG_arg_variable ]
20 !1 = metadata !{i32 589870, i32 0, metadata !2, metadata !"f", metadata !"f", metadata !"", metadata !2, i32 3, metadata !4, i1 false, i1 true, i32 0, i32 0, i32 0, i32 256, i1 false, i16 (i16)* @f, null, null} ; [ DW_TAG_subprogram ]
21 !2 = metadata !{i32 589865, metadata !"/home/espindola/llvm/test.c", metadata !"/home/espindola/tmpfs/build", metadata !3} ; [ DW_TAG_file_type ]
22 !3 = metadata !{i32 589841, i32 0, i32 12, metadata !"/home/espindola/llvm/test.c", metadata !"/home/espindola/tmpfs/build", metadata !"clang version 3.0 ()", i1 true, i1 false, metadata !"", i32 0} ; [ DW_TAG_compile_unit ]
23 !4 = metadata !{i32 589845, metadata !2, metadata !"", metadata !2, i32 0, i64 0, i64 0, i32 0, i32 0, i32 0, metadata !5, i32 0, i32 0} ; [ DW_TAG_subroutine_type ]
24 !5 = metadata !{null}
25 !6 = metadata !{i32 589860, metadata !3, metadata !"short", null, i32 0, i64 16, i64 16, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ]
26 !7 = metadata !{i32 4, i32 22, metadata !8, null}
27 !8 = metadata !{i32 589835, metadata !1, i32 3, i32 19, metadata !2, i32 0} ; [ DW_TAG_lexical_block ]