Make these regexes stricter by disallowing any additional characters in the output.
[opencl/llvm.git] / test / DebugInfo / ARM / s-super-register.ll
1 ; RUN: llc < %s - -filetype=obj | llvm-dwarfdump -debug-dump=loc - | FileCheck %s
2 target datalayout = "e-p:32:32:32-i1:8:32-i8:8:32-i16:16:32-i32:32:32-i64:32:32-f32:32:32-f64:32:32-v64:32:64-v128:32:128-a0:0:32-n32"
3 target triple = "thumbv7-apple-macosx10.6.7"
5 ; The S registers on ARM are expressed as pieces of their super-registers in DWARF.
6 ;
7 ; 0x90   DW_OP_regx of super-register
8 ; 0x93   DW_OP_piece
9 ; 0x9d   DW_OP_bit_piece
10 ; CHECK:            Location description: 90 {{.. .. ((93 ..)|(9d .. ..)) $}}
12 define void @_Z3foov() optsize ssp {
13 entry:
14   %call = tail call float @_Z3barv() optsize, !dbg !11
15   tail call void @llvm.dbg.value(metadata !{float %call}, i64 0, metadata !5), !dbg !11
16   %call16 = tail call float @_Z2f2v() optsize, !dbg !12
17   %cmp7 = fcmp olt float %call, %call16, !dbg !12
18   br i1 %cmp7, label %for.body, label %for.end, !dbg !12
20 for.body:                                         ; preds = %entry, %for.body
21   %k.08 = phi float [ %inc, %for.body ], [ %call, %entry ]
22   %call4 = tail call float @_Z2f3f(float %k.08) optsize, !dbg !13
23   %inc = fadd float %k.08, 1.000000e+00, !dbg !14
24   %call1 = tail call float @_Z2f2v() optsize, !dbg !12
25   %cmp = fcmp olt float %inc, %call1, !dbg !12
26   br i1 %cmp, label %for.body, label %for.end, !dbg !12
28 for.end:                                          ; preds = %for.body, %entry
29   ret void, !dbg !15
30 }
32 declare float @_Z3barv() optsize
34 declare float @_Z2f2v() optsize
36 declare float @_Z2f3f(float) optsize
38 declare void @llvm.dbg.value(metadata, i64, metadata) nounwind readnone
40 !llvm.dbg.cu = !{!0}
41 !llvm.module.flags = !{!20}
43 !0 = metadata !{i32 786449, metadata !18, i32 4, metadata !"clang version 3.0 (trunk 130845)", i1 true, metadata !"", i32 0, metadata !19, metadata !19, metadata !16, null,  null, null, i32 1} ; [ DW_TAG_compile_unit ]
44 !1 = metadata !{i32 786478, metadata !18, metadata !2, metadata !"foo", metadata !"foo", metadata !"_Z3foov", i32 5, metadata !3, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 true, void ()* @_Z3foov, null, null, metadata !17, i32 5} ; [ DW_TAG_subprogram ] [line 5] [def] [foo]
45 !2 = metadata !{i32 786473, metadata !18} ; [ DW_TAG_file_type ]
46 !3 = metadata !{i32 786453, metadata !18, metadata !2, metadata !"", i32 0, i64 0, i64 0, i32 0, i32 0, null, metadata !4, i32 0, null, null, null} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]
47 !4 = metadata !{null}
48 !5 = metadata !{i32 786688, metadata !6, metadata !"k", metadata !2, i32 6, metadata !7, i32 0, null} ; [ DW_TAG_auto_variable ]
49 !6 = metadata !{i32 786443, metadata !18, metadata !1, i32 5, i32 12, i32 0} ; [ DW_TAG_lexical_block ]
50 !7 = metadata !{i32 786468, null, metadata !0, metadata !"float", i32 0, i64 32, i64 32, i64 0, i32 0, i32 4} ; [ DW_TAG_base_type ]
51 !8 = metadata !{i32 786688, metadata !9, metadata !"y", metadata !2, i32 8, metadata !7, i32 0, null} ; [ DW_TAG_auto_variable ]
52 !9 = metadata !{i32 786443, metadata !18, metadata !10, i32 7, i32 25, i32 2} ; [ DW_TAG_lexical_block ]
53 !10 = metadata !{i32 786443, metadata !18, metadata !6, i32 7, i32 3, i32 1} ; [ DW_TAG_lexical_block ]
54 !11 = metadata !{i32 6, i32 18, metadata !6, null}
55 !12 = metadata !{i32 7, i32 3, metadata !6, null}
56 !13 = metadata !{i32 8, i32 20, metadata !9, null}
57 !14 = metadata !{i32 7, i32 20, metadata !10, null}
58 !15 = metadata !{i32 10, i32 1, metadata !6, null}
59 !16 = metadata !{metadata !1}
60 !17 = metadata !{metadata !5, metadata !8}
61 !18 = metadata !{metadata !"k.cc", metadata !"/private/tmp"}
62 !19 = metadata !{i32 0}
63 !20 = metadata !{i32 1, metadata !"Debug Info Version", i32 1}