diff options
Diffstat (limited to 'llvm/test/CodeGen/X86/fast-isel-constpool.ll')
-rw-r--r-- | llvm/test/CodeGen/X86/fast-isel-constpool.ll | 36 |
1 files changed, 16 insertions, 20 deletions
diff --git a/llvm/test/CodeGen/X86/fast-isel-constpool.ll b/llvm/test/CodeGen/X86/fast-isel-constpool.ll index 4e6f7c0f9e8..bbbaeb23391 100644 --- a/llvm/test/CodeGen/X86/fast-isel-constpool.ll +++ b/llvm/test/CodeGen/X86/fast-isel-constpool.ll @@ -1,23 +1,19 @@ -; RUN: llc -mtriple=x86_64-apple-darwin -fast-isel -code-model=small < %s | FileCheck %s -; RUN: llc -mtriple=x86_64-apple-darwin -fast-isel -code-model=large < %s | FileCheck %s --check-prefix=LARGE +; RUN: llc < %s -fast-isel | FileCheck %s +; CHECK: LCPI0_0(%rip) -; Make sure fast isel uses rip-relative addressing for the small code model. -define float @constpool_float(float %x) { -; CHECK-LABEL: constpool_float -; CHECK: LCPI0_0(%rip) +; Make sure fast isel uses rip-relative addressing when required. +target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128" +target triple = "x86_64-apple-darwin9.0" -; LARGE-LABEL: constpool_float -; LARGE: movabsq $LCPI0_0, %rax - %1 = fadd float %x, 16.50e+01 - ret float %1 -} - -define double @constpool_double(double %x) nounwind { -; CHECK-LABEL: constpool_double -; CHECK: LCPI1_0(%rip) - -; LARGE-LABEL: constpool_double -; LARGE: movabsq $LCPI1_0, %rax - %1 = fadd double %x, 8.500000e-01 - ret double %1 +define i32 @f0(double %x) nounwind { +entry: + %retval = alloca i32 ; <i32*> [#uses=2] + %x.addr = alloca double ; <double*> [#uses=2] + store double %x, double* %x.addr + %tmp = load double* %x.addr ; <double> [#uses=1] + %cmp = fcmp olt double %tmp, 8.500000e-01 ; <i1> [#uses=1] + %conv = zext i1 %cmp to i32 ; <i32> [#uses=1] + store i32 %conv, i32* %retval + %0 = load i32* %retval ; <i32> [#uses=1] + ret i32 %0 } |