1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-apple-darwin8 -mattr=+sse2 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-apple-darwin8 -mattr=+sse2 | not grep movhlps 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Workerdefine void @test() nounwind { 5*9880d681SAndroid Build Coastguard Workertest.exit: 6*9880d681SAndroid Build Coastguard Worker fmul <4 x float> zeroinitializer, zeroinitializer ; <<4 x float>>:0 [#uses=4] 7*9880d681SAndroid Build Coastguard Worker load <4 x float>, <4 x float>* null ; <<4 x float>>:1 [#uses=1] 8*9880d681SAndroid Build Coastguard Worker shufflevector <4 x float> %1, <4 x float> undef, <4 x i32> < i32 3, i32 3, i32 3, i32 3 > ; <<4 x float>>:2 [#uses=1] 9*9880d681SAndroid Build Coastguard Worker fmul <4 x float> %0, %2 ; <<4 x float>>:3 [#uses=1] 10*9880d681SAndroid Build Coastguard Worker fsub <4 x float> zeroinitializer, %3 ; <<4 x float>>:4 [#uses=1] 11*9880d681SAndroid Build Coastguard Worker fmul <4 x float> %4, zeroinitializer ; <<4 x float>>:5 [#uses=2] 12*9880d681SAndroid Build Coastguard Worker bitcast <4 x float> zeroinitializer to <4 x i32> ; <<4 x i32>>:6 [#uses=1] 13*9880d681SAndroid Build Coastguard Worker and <4 x i32> %6, < i32 2147483647, i32 2147483647, i32 2147483647, i32 2147483647 > ; <<4 x i32>>:7 [#uses=1] 14*9880d681SAndroid Build Coastguard Worker bitcast <4 x i32> %7 to <4 x float> ; <<4 x float>>:8 [#uses=2] 15*9880d681SAndroid Build Coastguard Worker extractelement <4 x float> %8, i32 0 ; <float>:9 [#uses=1] 16*9880d681SAndroid Build Coastguard Worker extractelement <4 x float> %8, i32 1 ; <float>:10 [#uses=2] 17*9880d681SAndroid Build Coastguard Worker br i1 false, label %11, label %19 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Worker; <label>:11 ; preds = %test.exit 20*9880d681SAndroid Build Coastguard Worker br i1 false, label %17, label %12 21*9880d681SAndroid Build Coastguard Worker 22*9880d681SAndroid Build Coastguard Worker; <label>:12 ; preds = %11 23*9880d681SAndroid Build Coastguard Worker br i1 false, label %19, label %13 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Worker; <label>:13 ; preds = %12 26*9880d681SAndroid Build Coastguard Worker fsub float -0.000000e+00, 0.000000e+00 ; <float>:14 [#uses=1] 27*9880d681SAndroid Build Coastguard Worker %tmp207 = extractelement <4 x float> zeroinitializer, i32 0 ; <float> [#uses=1] 28*9880d681SAndroid Build Coastguard Worker %tmp208 = extractelement <4 x float> zeroinitializer, i32 2 ; <float> [#uses=1] 29*9880d681SAndroid Build Coastguard Worker fsub float -0.000000e+00, %tmp208 ; <float>:15 [#uses=1] 30*9880d681SAndroid Build Coastguard Worker %tmp155 = extractelement <4 x float> zeroinitializer, i32 0 ; <float> [#uses=1] 31*9880d681SAndroid Build Coastguard Worker %tmp156 = extractelement <4 x float> zeroinitializer, i32 2 ; <float> [#uses=1] 32*9880d681SAndroid Build Coastguard Worker fsub float -0.000000e+00, %tmp156 ; <float>:16 [#uses=1] 33*9880d681SAndroid Build Coastguard Worker br label %19 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Worker; <label>:17 ; preds = %11 36*9880d681SAndroid Build Coastguard Worker br i1 false, label %19, label %18 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Worker; <label>:18 ; preds = %17 39*9880d681SAndroid Build Coastguard Worker br label %19 40*9880d681SAndroid Build Coastguard Worker 41*9880d681SAndroid Build Coastguard Worker; <label>:19 ; preds = %18, %17, %13, %12, %test.exit 42*9880d681SAndroid Build Coastguard Worker phi i32 [ 5, %18 ], [ 3, %13 ], [ 1, %test.exit ], [ 2, %12 ], [ 4, %17 ] ; <i32>:20 [#uses=0] 43*9880d681SAndroid Build Coastguard Worker phi float [ 0.000000e+00, %18 ], [ %16, %13 ], [ 0.000000e+00, %test.exit ], [ 0.000000e+00, %12 ], [ 0.000000e+00, %17 ] ; <float>:21 [#uses=1] 44*9880d681SAndroid Build Coastguard Worker phi float [ 0.000000e+00, %18 ], [ %tmp155, %13 ], [ 0.000000e+00, %test.exit ], [ 0.000000e+00, %12 ], [ 0.000000e+00, %17 ] ; <float>:22 [#uses=1] 45*9880d681SAndroid Build Coastguard Worker phi float [ 0.000000e+00, %18 ], [ %15, %13 ], [ 0.000000e+00, %test.exit ], [ 0.000000e+00, %12 ], [ 0.000000e+00, %17 ] ; <float>:23 [#uses=1] 46*9880d681SAndroid Build Coastguard Worker phi float [ 0.000000e+00, %18 ], [ %tmp207, %13 ], [ 0.000000e+00, %test.exit ], [ 0.000000e+00, %12 ], [ 0.000000e+00, %17 ] ; <float>:24 [#uses=1] 47*9880d681SAndroid Build Coastguard Worker phi float [ 0.000000e+00, %18 ], [ %10, %13 ], [ %9, %test.exit ], [ %10, %12 ], [ 0.000000e+00, %17 ] ; <float>:25 [#uses=2] 48*9880d681SAndroid Build Coastguard Worker phi float [ 0.000000e+00, %18 ], [ %14, %13 ], [ 0.000000e+00, %test.exit ], [ 0.000000e+00, %12 ], [ 0.000000e+00, %17 ] ; <float>:26 [#uses=1] 49*9880d681SAndroid Build Coastguard Worker phi float [ 0.000000e+00, %18 ], [ 0.000000e+00, %13 ], [ 0.000000e+00, %test.exit ], [ 0.000000e+00, %12 ], [ 0.000000e+00, %17 ] ; <float>:27 [#uses=1] 50*9880d681SAndroid Build Coastguard Worker insertelement <4 x float> undef, float %27, i32 0 ; <<4 x float>>:28 [#uses=1] 51*9880d681SAndroid Build Coastguard Worker insertelement <4 x float> %28, float %26, i32 1 ; <<4 x float>>:29 [#uses=0] 52*9880d681SAndroid Build Coastguard Worker insertelement <4 x float> undef, float %24, i32 0 ; <<4 x float>>:30 [#uses=1] 53*9880d681SAndroid Build Coastguard Worker insertelement <4 x float> %30, float %23, i32 1 ; <<4 x float>>:31 [#uses=1] 54*9880d681SAndroid Build Coastguard Worker insertelement <4 x float> %31, float %25, i32 2 ; <<4 x float>>:32 [#uses=1] 55*9880d681SAndroid Build Coastguard Worker insertelement <4 x float> %32, float %25, i32 3 ; <<4 x float>>:33 [#uses=1] 56*9880d681SAndroid Build Coastguard Worker fdiv <4 x float> %33, zeroinitializer ; <<4 x float>>:34 [#uses=1] 57*9880d681SAndroid Build Coastguard Worker fmul <4 x float> %34, < float 5.000000e-01, float 5.000000e-01, float 5.000000e-01, float 5.000000e-01 > ; <<4 x float>>:35 [#uses=1] 58*9880d681SAndroid Build Coastguard Worker insertelement <4 x float> undef, float %22, i32 0 ; <<4 x float>>:36 [#uses=1] 59*9880d681SAndroid Build Coastguard Worker insertelement <4 x float> %36, float %21, i32 1 ; <<4 x float>>:37 [#uses=0] 60*9880d681SAndroid Build Coastguard Worker br i1 false, label %foo.exit, label %38 61*9880d681SAndroid Build Coastguard Worker 62*9880d681SAndroid Build Coastguard Worker; <label>:38 ; preds = %19 63*9880d681SAndroid Build Coastguard Worker extractelement <4 x float> %0, i32 0 ; <float>:39 [#uses=1] 64*9880d681SAndroid Build Coastguard Worker fcmp ogt float %39, 0.000000e+00 ; <i1>:40 [#uses=1] 65*9880d681SAndroid Build Coastguard Worker extractelement <4 x float> %0, i32 2 ; <float>:41 [#uses=1] 66*9880d681SAndroid Build Coastguard Worker extractelement <4 x float> %0, i32 1 ; <float>:42 [#uses=1] 67*9880d681SAndroid Build Coastguard Worker fsub float -0.000000e+00, %42 ; <float>:43 [#uses=2] 68*9880d681SAndroid Build Coastguard Worker %tmp189 = extractelement <4 x float> %5, i32 2 ; <float> [#uses=1] 69*9880d681SAndroid Build Coastguard Worker br i1 %40, label %44, label %46 70*9880d681SAndroid Build Coastguard Worker 71*9880d681SAndroid Build Coastguard Worker; <label>:44 ; preds = %38 72*9880d681SAndroid Build Coastguard Worker fsub float -0.000000e+00, %tmp189 ; <float>:45 [#uses=0] 73*9880d681SAndroid Build Coastguard Worker br label %foo.exit 74*9880d681SAndroid Build Coastguard Worker 75*9880d681SAndroid Build Coastguard Worker; <label>:46 ; preds = %38 76*9880d681SAndroid Build Coastguard Worker %tmp192 = extractelement <4 x float> %5, i32 1 ; <float> [#uses=1] 77*9880d681SAndroid Build Coastguard Worker fsub float -0.000000e+00, %tmp192 ; <float>:47 [#uses=1] 78*9880d681SAndroid Build Coastguard Worker br label %foo.exit 79*9880d681SAndroid Build Coastguard Worker 80*9880d681SAndroid Build Coastguard Workerfoo.exit: ; preds = %46, %44, %19 81*9880d681SAndroid Build Coastguard Worker phi float [ 0.000000e+00, %44 ], [ %47, %46 ], [ 0.000000e+00, %19 ] ; <float>:48 [#uses=0] 82*9880d681SAndroid Build Coastguard Worker phi float [ %43, %44 ], [ %43, %46 ], [ 0.000000e+00, %19 ] ; <float>:49 [#uses=0] 83*9880d681SAndroid Build Coastguard Worker phi float [ 0.000000e+00, %44 ], [ %41, %46 ], [ 0.000000e+00, %19 ] ; <float>:50 [#uses=0] 84*9880d681SAndroid Build Coastguard Worker shufflevector <4 x float> %35, <4 x float> zeroinitializer, <4 x i32> < i32 0, i32 4, i32 1, i32 5 > ; <<4 x float>>:51 [#uses=0] 85*9880d681SAndroid Build Coastguard Worker unreachable 86*9880d681SAndroid Build Coastguard Worker} 87