diff options
Diffstat (limited to 'llvm/test/CodeGen/AArch64/fpimm.ll')
-rw-r--r-- | llvm/test/CodeGen/AArch64/fpimm.ll | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/llvm/test/CodeGen/AArch64/fpimm.ll b/llvm/test/CodeGen/AArch64/fpimm.ll index d19777c4d27..89cbe2ce8af 100644 --- a/llvm/test/CodeGen/AArch64/fpimm.ll +++ b/llvm/test/CodeGen/AArch64/fpimm.ll @@ -1,39 +1,48 @@ ; RUN: llc -mtriple=aarch64-linux-gnu -verify-machineinstrs < %s | FileCheck %s ; RUN: llc -mtriple=aarch64-apple-darwin -code-model=large -verify-machineinstrs < %s | FileCheck %s --check-prefix=LARGE ; RUN: llc -mtriple=aarch64-apple-darwin -code-model=large -fast-isel -fast-isel-abort=1 -verify-machineinstrs < %s | FileCheck %s --check-prefix=LARGE +; RUN: llc -mtriple=aarch64-none-eabi -code-model=tiny -verify-machineinstrs < %s | FileCheck %s --check-prefix=TINY @varf32 = global float 0.0 @varf64 = global double 0.0 define void @check_float() { ; CHECK-LABEL: check_float: +; TINY-LABEL: check_float: %val = load float, float* @varf32 %newval1 = fadd float %val, 8.5 store volatile float %newval1, float* @varf32 -; CHECK-DAG: fmov [[EIGHT5:s[0-9]+]], #8.5 +; CHECK-DAG: fmov {{s[0-9]+}}, #8.5 +; TINY-DAG: fmov {{s[0-9]+}}, #8.5 %newval2 = fadd float %val, 128.0 store volatile float %newval2, float* @varf32 -; CHECK-DAG: ldr [[HARD:s[0-9]+]], [{{x[0-9]+}}, {{#?}}:lo12:.LCPI0_0 +; CHECK-DAG: ldr {{s[0-9]+}}, [{{x[0-9]+}}, {{#?}}:lo12:.LCPI0_0 +; TINY-DAG: ldr {{s[0-9]+}}, [{{x[0-9]+}}] ; CHECK: ret +; TINY: ret ret void } define void @check_double() { ; CHECK-LABEL: check_double: +; TINY-LABEL: check_double: %val = load double, double* @varf64 %newval1 = fadd double %val, 8.5 store volatile double %newval1, double* @varf64 ; CHECK-DAG: fmov {{d[0-9]+}}, #8.5 +; TINY-DAG: fmov {{d[0-9]+}}, #8.5 %newval2 = fadd double %val, 128.0 store volatile double %newval2, double* @varf64 ; CHECK-DAG: ldr {{d[0-9]+}}, [{{x[0-9]+}}, {{#?}}:lo12:.LCPI1_0 +; TINY-DAG: ldr {{d[0-9]+}}, [{{x[0-9]+}}] ; CHECK: ret +; TINY: ret ret void } @@ -41,6 +50,9 @@ define void @check_double() { ; LARGE: mov [[REG:w[0-9]+]], #4059 ; LARGE-NEXT: movk [[REG]], #16457, lsl #16 ; LARGE-NEXT: fmov s0, [[REG]] +; TINY-LABEL: check_float2 +; TINY: adr x[[REG:[0-9]+]], .LCPI2_0 +; TINY-NEXT: ldr s0, [x[[REG]]] define float @check_float2() { ret float 3.14159274101257324218750 } @@ -51,6 +63,9 @@ define float @check_float2() { ; LARGE-NEXT: movk [[REG]], #8699, lsl #32 ; LARGE-NEXT: movk [[REG]], #16393, lsl #48 ; LARGE-NEXT: fmov d0, [[REG]] +; TINY-LABEL: check_double2 +; TINY: adr x[[REG:[0-9]+]], .LCPI3_0 +; TINY-NEXT: ldr d0, [x[[REG]]] define double @check_double2() { ret double 3.1415926535897931159979634685441851615905761718750 } |