1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s - | FileCheck %s 2*9880d681SAndroid Build Coastguard Workertarget 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*9880d681SAndroid Build Coastguard Workertarget triple = "thumbv7-apple-macosx10.6.7" 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Worker;CHECK: vadd.f32 q4, q8, q8 6*9880d681SAndroid Build Coastguard Worker;CHECK-NEXT: Ltmp1 7*9880d681SAndroid Build Coastguard Worker;CHECK-NEXT: LBB0_1 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Worker;CHECK:@DEBUG_VALUE: x <- %Q4{{$}} 10*9880d681SAndroid Build Coastguard Worker;CHECK-NEXT:@DEBUG_VALUE: y <- %Q4{{$}} 11*9880d681SAndroid Build Coastguard Worker 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Worker@.str = external constant [13 x i8] 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Workerdeclare <4 x float> @test0001(float) nounwind readnone ssp 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Workerdefine i32 @main(i32 %argc, i8** nocapture %argv, i1 %cond) nounwind ssp !dbg !10 { 18*9880d681SAndroid Build Coastguard Workerentry: 19*9880d681SAndroid Build Coastguard Worker br label %for.body9 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Workerfor.body9: ; preds = %for.body9, %entry 22*9880d681SAndroid Build Coastguard Worker %add19 = fadd <4 x float> undef, <float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float 1.000000e+00>, !dbg !39 23*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.value(metadata <4 x float> %add19, i64 0, metadata !27, metadata !DIExpression()), !dbg !39 24*9880d681SAndroid Build Coastguard Worker %add20 = fadd <4 x float> undef, <float 0.000000e+00, float 0.000000e+00, float 0.000000e+00, float 1.000000e+00>, !dbg !39 25*9880d681SAndroid Build Coastguard Worker tail call void @llvm.dbg.value(metadata <4 x float> %add20, i64 0, metadata !28, metadata !DIExpression()), !dbg !39 26*9880d681SAndroid Build Coastguard Worker br i1 %cond, label %for.end54, label %for.body9, !dbg !44 27*9880d681SAndroid Build Coastguard Worker 28*9880d681SAndroid Build Coastguard Workerfor.end54: ; preds = %for.body9 29*9880d681SAndroid Build Coastguard Worker %tmp115 = extractelement <4 x float> %add19, i32 1 30*9880d681SAndroid Build Coastguard Worker %conv6.i75 = fpext float %tmp115 to double, !dbg !45 31*9880d681SAndroid Build Coastguard Worker %call.i82 = tail call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([13 x i8], [13 x i8]* @.str, i32 0, i32 0), double undef, double %conv6.i75, double undef, double undef) nounwind, !dbg !45 32*9880d681SAndroid Build Coastguard Worker %tmp116 = extractelement <4 x float> %add20, i32 1 33*9880d681SAndroid Build Coastguard Worker %conv6.i76 = fpext float %tmp116 to double, !dbg !45 34*9880d681SAndroid Build Coastguard Worker %call.i83 = tail call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([13 x i8], [13 x i8]* @.str, i32 0, i32 0), double undef, double %conv6.i76, double undef, double undef) nounwind, !dbg !45 35*9880d681SAndroid Build Coastguard Worker ret i32 0, !dbg !49 36*9880d681SAndroid Build Coastguard Worker} 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Workerdeclare i32 @printf(i8* nocapture, ...) nounwind 39*9880d681SAndroid Build Coastguard Worker 40*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.dbg.value(metadata, i64, metadata, metadata) nounwind readnone 41*9880d681SAndroid Build Coastguard Worker 42*9880d681SAndroid Build Coastguard Worker!llvm.module.flags = !{!56} 43*9880d681SAndroid Build Coastguard Worker!llvm.dbg.cu = !{!2} 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker!0 = distinct !DISubprogram(name: "test0001", line: 3, isLocal: false, isDefinition: true, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: true, unit: !2, file: !54, scope: null, type: !3, variables: !51) 46*9880d681SAndroid Build Coastguard Worker!1 = !DIFile(filename: "build2.c", directory: "/private/tmp") 47*9880d681SAndroid Build Coastguard Worker!2 = distinct !DICompileUnit(language: DW_LANG_C99, producer: "clang version 3.0 (trunk 129915)", isOptimized: true, emissionKind: FullDebug, file: !54, enums: !{}, retainedTypes: !{}, imports: null) 48*9880d681SAndroid Build Coastguard Worker!3 = !DISubroutineType(types: !4) 49*9880d681SAndroid Build Coastguard Worker!4 = !{!5} 50*9880d681SAndroid Build Coastguard Worker!5 = !DIDerivedType(tag: DW_TAG_typedef, name: "v4f32", line: 14, file: !54, scope: !2, baseType: !6) 51*9880d681SAndroid Build Coastguard Worker!6 = !DICompositeType(tag: DW_TAG_array_type, size: 128, align: 128, file: !54, scope: !2, baseType: !7, elements: !8) 52*9880d681SAndroid Build Coastguard Worker!7 = !DIBasicType(tag: DW_TAG_base_type, name: "float", size: 32, align: 32, encoding: DW_ATE_float) 53*9880d681SAndroid Build Coastguard Worker!8 = !{!9} 54*9880d681SAndroid Build Coastguard Worker!9 = !DISubrange(count: 4) 55*9880d681SAndroid Build Coastguard Worker!10 = distinct !DISubprogram(name: "main", line: 59, isLocal: false, isDefinition: true, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: true, unit: !2, file: !54, scope: null, type: !11, variables: !52) 56*9880d681SAndroid Build Coastguard Worker!11 = !DISubroutineType(types: !12) 57*9880d681SAndroid Build Coastguard Worker!12 = !{!13} 58*9880d681SAndroid Build Coastguard Worker!13 = !DIBasicType(tag: DW_TAG_base_type, name: "int", size: 32, align: 32, encoding: DW_ATE_signed) 59*9880d681SAndroid Build Coastguard Worker!14 = distinct !DISubprogram(name: "printFV", line: 41, isLocal: true, isDefinition: true, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: true, unit: !2, file: !55, scope: null, type: !16, variables: !53) 60*9880d681SAndroid Build Coastguard Worker!15 = !DIFile(filename: "/Volumes/Lalgate/work/llvm/projects/llvm-test/SingleSource/UnitTests/Vector/helpers.h", directory: "/private/tmp") 61*9880d681SAndroid Build Coastguard Worker!16 = !DISubroutineType(types: !17) 62*9880d681SAndroid Build Coastguard Worker!17 = !{null} 63*9880d681SAndroid Build Coastguard Worker!18 = !DILocalVariable(name: "a", line: 3, arg: 1, scope: !0, file: !1, type: !7) 64*9880d681SAndroid Build Coastguard Worker!19 = !DILocalVariable(name: "argc", line: 59, arg: 1, scope: !10, file: !1, type: !13) 65*9880d681SAndroid Build Coastguard Worker!20 = !DILocalVariable(name: "argv", line: 59, arg: 2, scope: !10, file: !1, type: !21) 66*9880d681SAndroid Build Coastguard Worker!21 = !DIDerivedType(tag: DW_TAG_pointer_type, size: 32, align: 32, scope: !2, baseType: !22) 67*9880d681SAndroid Build Coastguard Worker!22 = !DIDerivedType(tag: DW_TAG_pointer_type, size: 32, align: 32, scope: !2, baseType: !23) 68*9880d681SAndroid Build Coastguard Worker!23 = !DIBasicType(tag: DW_TAG_base_type, name: "char", size: 8, align: 8, encoding: DW_ATE_signed_char) 69*9880d681SAndroid Build Coastguard Worker!24 = !DILocalVariable(name: "i", line: 60, scope: !25, file: !1, type: !13) 70*9880d681SAndroid Build Coastguard Worker!25 = distinct !DILexicalBlock(line: 59, column: 33, file: !1, scope: !10) 71*9880d681SAndroid Build Coastguard Worker!26 = !DILocalVariable(name: "j", line: 60, scope: !25, file: !1, type: !13) 72*9880d681SAndroid Build Coastguard Worker!27 = !DILocalVariable(name: "x", line: 61, scope: !25, file: !1, type: !5) 73*9880d681SAndroid Build Coastguard Worker!28 = !DILocalVariable(name: "y", line: 62, scope: !25, file: !1, type: !5) 74*9880d681SAndroid Build Coastguard Worker!29 = !DILocalVariable(name: "z", line: 63, scope: !25, file: !1, type: !5) 75*9880d681SAndroid Build Coastguard Worker!30 = !DILocalVariable(name: "F", line: 41, arg: 1, scope: !14, file: !15, type: !31) 76*9880d681SAndroid Build Coastguard Worker!31 = !DIDerivedType(tag: DW_TAG_pointer_type, size: 32, align: 32, scope: !2, baseType: !32) 77*9880d681SAndroid Build Coastguard Worker!32 = !DIDerivedType(tag: DW_TAG_typedef, name: "FV", line: 25, file: !55, scope: !2, baseType: !33) 78*9880d681SAndroid Build Coastguard Worker!33 = !DICompositeType(tag: DW_TAG_union_type, line: 22, size: 128, align: 128, file: !55, scope: !2, elements: !34) 79*9880d681SAndroid Build Coastguard Worker!34 = !{!35, !37} 80*9880d681SAndroid Build Coastguard Worker!35 = !DIDerivedType(tag: DW_TAG_member, name: "V", line: 23, size: 128, align: 128, file: !55, scope: !15, baseType: !36) 81*9880d681SAndroid Build Coastguard Worker!36 = !DIDerivedType(tag: DW_TAG_typedef, name: "v4sf", line: 3, file: !55, scope: !2, baseType: !6) 82*9880d681SAndroid Build Coastguard Worker!37 = !DIDerivedType(tag: DW_TAG_member, name: "A", line: 24, size: 128, align: 32, file: !55, scope: !15, baseType: !38) 83*9880d681SAndroid Build Coastguard Worker!38 = !DICompositeType(tag: DW_TAG_array_type, size: 128, align: 32, scope: !2, baseType: !7, elements: !8) 84*9880d681SAndroid Build Coastguard Worker!39 = !DILocation(line: 79, column: 7, scope: !40) 85*9880d681SAndroid Build Coastguard Worker!40 = distinct !DILexicalBlock(line: 75, column: 35, file: !1, scope: !41) 86*9880d681SAndroid Build Coastguard Worker!41 = distinct !DILexicalBlock(line: 75, column: 5, file: !1, scope: !42) 87*9880d681SAndroid Build Coastguard Worker!42 = distinct !DILexicalBlock(line: 71, column: 32, file: !1, scope: !43) 88*9880d681SAndroid Build Coastguard Worker!43 = distinct !DILexicalBlock(line: 71, column: 3, file: !1, scope: !25) 89*9880d681SAndroid Build Coastguard Worker!44 = !DILocation(line: 75, column: 5, scope: !42) 90*9880d681SAndroid Build Coastguard Worker!45 = !DILocation(line: 42, column: 2, scope: !46, inlinedAt: !48) 91*9880d681SAndroid Build Coastguard Worker!46 = distinct !DILexicalBlock(line: 42, column: 2, file: !15, scope: !47) 92*9880d681SAndroid Build Coastguard Worker!47 = distinct !DILexicalBlock(line: 41, column: 28, file: !15, scope: !14) 93*9880d681SAndroid Build Coastguard Worker!48 = !DILocation(line: 95, column: 3, scope: !25) 94*9880d681SAndroid Build Coastguard Worker!49 = !DILocation(line: 99, column: 3, scope: !25) 95*9880d681SAndroid Build Coastguard Worker!51 = !{!18} 96*9880d681SAndroid Build Coastguard Worker!52 = !{!19, !20, !24, !26, !27, !28, !29} 97*9880d681SAndroid Build Coastguard Worker!53 = !{!30} 98*9880d681SAndroid Build Coastguard Worker!54 = !DIFile(filename: "build2.c", directory: "/private/tmp") 99*9880d681SAndroid Build Coastguard Worker!55 = !DIFile(filename: "/Volumes/Lalgate/work/llvm/projects/llvm-test/SingleSource/UnitTests/Vector/helpers.h", directory: "/private/tmp") 100*9880d681SAndroid Build Coastguard Worker!56 = !{i32 1, !"Debug Info Version", i32 3} 101