[X86] Use push-pop for materializing small constants under 'minsize'
[oota-llvm.git] / test / CodeGen / X86 / powi.ll
1 ; RUN: llc < %s -mtriple=x86_64-unknown-unknown -mattr=sse2 | FileCheck %s
2 ; Ideally this would compile to 5 multiplies.
3
4 define double @pow_wrapper(double %a) nounwind readonly ssp noredzone {
5 ; CHECK-LABEL: pow_wrapper:
6 ; CHECK:       # BB#0:
7 ; CHECK-NEXT:    movapd %xmm0, %xmm1
8 ; CHECK-NEXT:    mulsd %xmm1, %xmm1
9 ; CHECK-NEXT:    mulsd %xmm1, %xmm0
10 ; CHECK-NEXT:    mulsd %xmm1, %xmm1
11 ; CHECK-NEXT:    mulsd %xmm1, %xmm0
12 ; CHECK-NEXT:    mulsd %xmm1, %xmm1
13 ; CHECK-NEXT:    mulsd %xmm0, %xmm1
14 ; CHECK-NEXT:    movapd %xmm1, %xmm0
15 ; CHECK-NEXT:    retq
16   %ret = tail call double @llvm.powi.f64(double %a, i32 15) nounwind ; <double> [#uses=1]
17   ret double %ret
18 }
19
20 define double @pow_wrapper_optsize(double %a) optsize {
21 ; CHECK-LABEL: pow_wrapper_optsize:
22 ; CHECK:       # BB#0:
23 ; CHECK-NEXT:    movl  $15, %edi
24 ; CHECK-NEXT:    jmp
25   %ret = tail call double @llvm.powi.f64(double %a, i32 15) nounwind ; <double> [#uses=1]
26   ret double %ret
27 }
28
29 define double @pow_wrapper_minsize(double %a) minsize {
30 ; CHECK-LABEL: pow_wrapper_minsize:
31 ; CHECK:       # BB#0:
32 ; CHECK-NEXT:    movl  $128, %edi
33 ; CHECK-NEXT:    jmp
34   %ret = tail call double @llvm.powi.f64(double %a, i32 128) nounwind ; <double> [#uses=1]
35   ret double %ret
36 }
37
38 declare double @llvm.powi.f64(double, i32) nounwind readonly
39