blob: 944ded04e2cec653fb64d8d7b73dccc063179d9b [file] [log] [blame]
Arnold Schwaighofer7b315ea2015-07-07 19:26:31 +00001; RUN: llc < %s -mtriple=arm64-apple-ios | FileCheck %s
2
3; CHECK-LABEL: _test:
4; CHECK: fmov.2d v0, #2.00000000
Geoff Berry173b14d2016-02-09 20:47:21 +00005; CHECK: str q0, [sp, #-16]!
Arnold Schwaighofer7b315ea2015-07-07 19:26:31 +00006; CHECK: mov x8, sp
7; CHECK: ldr s0, [x8, w1, sxtw #2]
8; CHECK: str s0, [x0]
Arnold Schwaighofer4bc34b12015-07-07 18:31:55 +00009
10define void @test(float * %p1, i32 %v1) {
11entry:
12 %v2 = extractelement <3 x float> <float 0.000000e+00, float 2.000000e+00, float 0.000000e+00>, i32 %v1
13 store float %v2, float* %p1, align 4
14 ret void
15}
Arnold Schwaighofer3d43f662015-07-07 23:13:18 +000016
17; CHECK-LABEL: _test2
18; CHECK: movi.16b v0, #0x3f
Geoff Berry173b14d2016-02-09 20:47:21 +000019; CHECK: str q0, [sp, #-16]!
Arnold Schwaighofer3d43f662015-07-07 23:13:18 +000020; CHECK: mov x8, sp
21; CHECK: ldr s0, [x8, w1, sxtw #2]
22; CHECK: str s0, [x0]
23
24define void @test2(float * %p1, i32 %v1) {
25entry:
26 %v2 = extractelement <3 x float> <float 0.7470588088035583, float 0.7470588088035583, float 0.7470588088035583>, i32 %v1
27 store float %v2, float* %p1, align 4
28 ret void
29}