Dan Gohman | 36a0947 | 2009-09-08 23:54:48 +0000 | [diff] [blame^] | 1 | ; RUN: llc < %s -mtriple=x86_64-apple-darwin8 -mattr=+sse2 |
| 2 | ; RUN: llc < %s -mtriple=x86_64-apple-darwin8 -mattr=+sse2 | not grep movhlps |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 3 | |
Evan Cheng | 1711424 | 2009-05-12 18:35:43 +0000 | [diff] [blame] | 4 | define void @test() nounwind { |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 5 | test.exit: |
Dan Gohman | ae3a0be | 2009-06-04 22:49:04 +0000 | [diff] [blame] | 6 | fmul <4 x float> zeroinitializer, zeroinitializer ; <<4 x float>>:0 [#uses=4] |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 7 | load <4 x float>* null ; <<4 x float>>:1 [#uses=1] |
| 8 | 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] |
Dan Gohman | ae3a0be | 2009-06-04 22:49:04 +0000 | [diff] [blame] | 9 | fmul <4 x float> %0, %2 ; <<4 x float>>:3 [#uses=1] |
| 10 | fsub <4 x float> zeroinitializer, %3 ; <<4 x float>>:4 [#uses=1] |
| 11 | fmul <4 x float> %4, zeroinitializer ; <<4 x float>>:5 [#uses=2] |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 12 | bitcast <4 x float> zeroinitializer to <4 x i32> ; <<4 x i32>>:6 [#uses=1] |
| 13 | and <4 x i32> %6, < i32 2147483647, i32 2147483647, i32 2147483647, i32 2147483647 > ; <<4 x i32>>:7 [#uses=1] |
| 14 | bitcast <4 x i32> %7 to <4 x float> ; <<4 x float>>:8 [#uses=2] |
| 15 | extractelement <4 x float> %8, i32 0 ; <float>:9 [#uses=1] |
| 16 | extractelement <4 x float> %8, i32 1 ; <float>:10 [#uses=2] |
| 17 | br i1 false, label %11, label %19 |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 18 | |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 19 | ; <label>:11 ; preds = %test.exit |
| 20 | br i1 false, label %17, label %12 |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 21 | |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 22 | ; <label>:12 ; preds = %11 |
| 23 | br i1 false, label %19, label %13 |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 24 | |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 25 | ; <label>:13 ; preds = %12 |
Dan Gohman | ae3a0be | 2009-06-04 22:49:04 +0000 | [diff] [blame] | 26 | fsub float -0.000000e+00, 0.000000e+00 ; <float>:14 [#uses=1] |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 27 | %tmp207 = extractelement <4 x float> zeroinitializer, i32 0 ; <float> [#uses=1] |
| 28 | %tmp208 = extractelement <4 x float> zeroinitializer, i32 2 ; <float> [#uses=1] |
Dan Gohman | ae3a0be | 2009-06-04 22:49:04 +0000 | [diff] [blame] | 29 | fsub float -0.000000e+00, %tmp208 ; <float>:15 [#uses=1] |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 30 | %tmp155 = extractelement <4 x float> zeroinitializer, i32 0 ; <float> [#uses=1] |
| 31 | %tmp156 = extractelement <4 x float> zeroinitializer, i32 2 ; <float> [#uses=1] |
Dan Gohman | ae3a0be | 2009-06-04 22:49:04 +0000 | [diff] [blame] | 32 | fsub float -0.000000e+00, %tmp156 ; <float>:16 [#uses=1] |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 33 | br label %19 |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 34 | |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 35 | ; <label>:17 ; preds = %11 |
| 36 | br i1 false, label %19, label %18 |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 37 | |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 38 | ; <label>:18 ; preds = %17 |
| 39 | br label %19 |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 40 | |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 41 | ; <label>:19 ; preds = %18, %17, %13, %12, %test.exit |
| 42 | phi i32 [ 5, %18 ], [ 3, %13 ], [ 1, %test.exit ], [ 2, %12 ], [ 4, %17 ] ; <i32>:20 [#uses=0] |
| 43 | 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 | 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 | 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 | 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 | phi float [ 0.000000e+00, %18 ], [ %10, %13 ], [ %9, %test.exit ], [ %10, %12 ], [ 0.000000e+00, %17 ] ; <float>:25 [#uses=2] |
| 48 | 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 | 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 | insertelement <4 x float> undef, float %27, i32 0 ; <<4 x float>>:28 [#uses=1] |
| 51 | insertelement <4 x float> %28, float %26, i32 1 ; <<4 x float>>:29 [#uses=0] |
| 52 | insertelement <4 x float> undef, float %24, i32 0 ; <<4 x float>>:30 [#uses=1] |
| 53 | insertelement <4 x float> %30, float %23, i32 1 ; <<4 x float>>:31 [#uses=1] |
| 54 | insertelement <4 x float> %31, float %25, i32 2 ; <<4 x float>>:32 [#uses=1] |
| 55 | insertelement <4 x float> %32, float %25, i32 3 ; <<4 x float>>:33 [#uses=1] |
| 56 | fdiv <4 x float> %33, zeroinitializer ; <<4 x float>>:34 [#uses=1] |
Dan Gohman | ae3a0be | 2009-06-04 22:49:04 +0000 | [diff] [blame] | 57 | 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] |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 58 | insertelement <4 x float> undef, float %22, i32 0 ; <<4 x float>>:36 [#uses=1] |
| 59 | insertelement <4 x float> %36, float %21, i32 1 ; <<4 x float>>:37 [#uses=0] |
| 60 | br i1 false, label %foo.exit, label %38 |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 61 | |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 62 | ; <label>:38 ; preds = %19 |
| 63 | extractelement <4 x float> %0, i32 0 ; <float>:39 [#uses=1] |
| 64 | fcmp ogt float %39, 0.000000e+00 ; <i1>:40 [#uses=1] |
| 65 | extractelement <4 x float> %0, i32 2 ; <float>:41 [#uses=1] |
| 66 | extractelement <4 x float> %0, i32 1 ; <float>:42 [#uses=1] |
Dan Gohman | ae3a0be | 2009-06-04 22:49:04 +0000 | [diff] [blame] | 67 | fsub float -0.000000e+00, %42 ; <float>:43 [#uses=2] |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 68 | %tmp189 = extractelement <4 x float> %5, i32 2 ; <float> [#uses=1] |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 69 | br i1 %40, label %44, label %46 |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 70 | |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 71 | ; <label>:44 ; preds = %38 |
Dan Gohman | ae3a0be | 2009-06-04 22:49:04 +0000 | [diff] [blame] | 72 | fsub float -0.000000e+00, %tmp189 ; <float>:45 [#uses=0] |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 73 | br label %foo.exit |
| 74 | |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 75 | ; <label>:46 ; preds = %38 |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 76 | %tmp192 = extractelement <4 x float> %5, i32 1 ; <float> [#uses=1] |
Dan Gohman | ae3a0be | 2009-06-04 22:49:04 +0000 | [diff] [blame] | 77 | fsub float -0.000000e+00, %tmp192 ; <float>:47 [#uses=1] |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 78 | br label %foo.exit |
| 79 | |
Reid Spencer | 2318ec6 | 2007-03-19 18:27:35 +0000 | [diff] [blame] | 80 | foo.exit: ; preds = %46, %44, %19 |
| 81 | phi float [ 0.000000e+00, %44 ], [ %47, %46 ], [ 0.000000e+00, %19 ] ; <float>:48 [#uses=0] |
| 82 | phi float [ %43, %44 ], [ %43, %46 ], [ 0.000000e+00, %19 ] ; <float>:49 [#uses=0] |
| 83 | phi float [ 0.000000e+00, %44 ], [ %41, %46 ], [ 0.000000e+00, %19 ] ; <float>:50 [#uses=0] |
| 84 | 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] |
Evan Cheng | c621469 | 2007-03-02 10:37:19 +0000 | [diff] [blame] | 85 | unreachable |
| 86 | } |