Split the Add, Sub, and Mul instruction opcodes into separate
[oota-llvm.git] / test / CodeGen / X86 / phys_subreg_coalesce.ll
1 ; RUN: llvm-as < %s | llc -mtriple=x86_64-apple-darwin9 -mattr=+sse2 | not grep movl
2
3         %struct.dpoint = type { double, double }
4
5 define %struct.dpoint @midpoint(i64 %p1.0, i64 %p2.0) nounwind readnone {
6 entry:
7         %0 = trunc i64 %p1.0 to i32             ; <i32> [#uses=1]
8         %1 = sitofp i32 %0 to double            ; <double> [#uses=1]
9         %2 = trunc i64 %p2.0 to i32             ; <i32> [#uses=1]
10         %3 = sitofp i32 %2 to double            ; <double> [#uses=1]
11         %4 = fadd double %1, %3         ; <double> [#uses=1]
12         %5 = fmul double %4, 5.000000e-01               ; <double> [#uses=1]
13         %6 = lshr i64 %p1.0, 32         ; <i64> [#uses=1]
14         %7 = trunc i64 %6 to i32                ; <i32> [#uses=1]
15         %8 = sitofp i32 %7 to double            ; <double> [#uses=1]
16         %9 = lshr i64 %p2.0, 32         ; <i64> [#uses=1]
17         %10 = trunc i64 %9 to i32               ; <i32> [#uses=1]
18         %11 = sitofp i32 %10 to double          ; <double> [#uses=1]
19         %12 = fadd double %8, %11               ; <double> [#uses=1]
20         %13 = fmul double %12, 5.000000e-01             ; <double> [#uses=1]
21         %mrv3 = insertvalue %struct.dpoint undef, double %5, 0          ; <%struct.dpoint> [#uses=1]
22         %mrv4 = insertvalue %struct.dpoint %mrv3, double %13, 1         ; <%struct.dpoint> [#uses=1]
23         ret %struct.dpoint %mrv4
24 }