blob: b5a08c148930f940d0e9c3715bdeef73f60afda4 [file] [log] [blame]
Mehdi Amini945a6602015-02-27 18:32:11 +00001; RUN: llc -O0 -fast-isel-abort=1 -verify-machineinstrs -mtriple=arm64-apple-darwin < %s | FileCheck %s
Tim Northover00ed9962014-03-29 10:18:08 +00002
3; Materialize using fmov
Juergen Ributzka6afeffb2014-08-19 20:35:07 +00004define float @fmov_float1() {
5; CHECK-LABEL: fmov_float1
6; CHECK: fmov s0, #1.25000000
7 ret float 1.250000e+00
Tim Northover00ed9962014-03-29 10:18:08 +00008}
9
Juergen Ributzka6afeffb2014-08-19 20:35:07 +000010define float @fmov_float2() {
11; CHECK-LABEL: fmov_float2
12; CHECK: fmov s0, wzr
13 ret float 0.0e+00
14}
15
16define double @fmov_double1() {
17; CHECK-LABEL: fmov_double1
18; CHECK: fmov d0, #1.25000000
19 ret double 1.250000e+00
20}
21
22define double @fmov_double2() {
23; CHECK-LABEL: fmov_double2
24; CHECK: fmov d0, xzr
25 ret double 0.0e+00
Tim Northover00ed9962014-03-29 10:18:08 +000026}
27
28; Materialize from constant pool
Juergen Ributzka6afeffb2014-08-19 20:35:07 +000029define float @cp_float() {
30; CHECK-LABEL: cp_float
31; CHECK: adrp [[REG:x[0-9]+]], {{lCPI[0-9]+_0}}@PAGE
32; CHECK-NEXT: ldr s0, {{\[}}[[REG]], {{lCPI[0-9]+_0}}@PAGEOFF{{\]}}
Tim Northover00ed9962014-03-29 10:18:08 +000033 ret float 0x400921FB60000000
34}
35
Juergen Ributzka6afeffb2014-08-19 20:35:07 +000036define double @cp_double() {
37; CHECK-LABEL: cp_double
38; CHECK: adrp [[REG:x[0-9]+]], {{lCPI[0-9]+_0}}@PAGE
39; CHECK-NEXT: ldr d0, {{\[}}[[REG]], {{lCPI[0-9]+_0}}@PAGEOFF{{\]}}
Tim Northover00ed9962014-03-29 10:18:08 +000040 ret double 0x400921FB54442D18
41}