blob: 364d44b7116f8a6b2aea9440a65adb814a9e0049 [file] [log] [blame]
Dan Gohmanfce288f2009-09-09 00:09:15 +00001; RUN: llc < %s -march=arm -mattr=+neon | FileCheck %s
Bob Wilson2ed33462009-07-08 20:32:02 +00002
3define void @vst1i8(i8* %A, <8 x i8>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +00004;CHECK: vst1i8:
Bob Wilson2a6e6162010-09-23 23:42:37 +00005;Check the alignment value. Max for this instruction is 64 bits:
Bob Wilson7d247052010-10-08 06:15:13 +00006;CHECK: vst1.8 {d16}, [r0, :64]
Bob Wilson2ed33462009-07-08 20:32:02 +00007 %tmp1 = load <8 x i8>* %B
Bob Wilson2a6e6162010-09-23 23:42:37 +00008 call void @llvm.arm.neon.vst1.v8i8(i8* %A, <8 x i8> %tmp1, i32 16)
Bob Wilson2ed33462009-07-08 20:32:02 +00009 ret void
10}
11
12define void @vst1i16(i16* %A, <4 x i16>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000013;CHECK: vst1i16:
14;CHECK: vst1.16
Bob Wilson02170c02010-04-20 00:17:16 +000015 %tmp0 = bitcast i16* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000016 %tmp1 = load <4 x i16>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000017 call void @llvm.arm.neon.vst1.v4i16(i8* %tmp0, <4 x i16> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000018 ret void
19}
20
21define void @vst1i32(i32* %A, <2 x i32>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000022;CHECK: vst1i32:
23;CHECK: vst1.32
Bob Wilson02170c02010-04-20 00:17:16 +000024 %tmp0 = bitcast i32* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000025 %tmp1 = load <2 x i32>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000026 call void @llvm.arm.neon.vst1.v2i32(i8* %tmp0, <2 x i32> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000027 ret void
28}
29
30define void @vst1f(float* %A, <2 x float>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000031;CHECK: vst1f:
32;CHECK: vst1.32
Bob Wilson02170c02010-04-20 00:17:16 +000033 %tmp0 = bitcast float* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000034 %tmp1 = load <2 x float>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000035 call void @llvm.arm.neon.vst1.v2f32(i8* %tmp0, <2 x float> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000036 ret void
37}
38
Bob Wilson1c3ef902011-02-07 17:43:21 +000039;Check for a post-increment updating store.
40define void @vst1f_update(float** %ptr, <2 x float>* %B) nounwind {
41;CHECK: vst1f_update:
42;CHECK: vst1.32 {d16}, [r1]!
43 %A = load float** %ptr
44 %tmp0 = bitcast float* %A to i8*
45 %tmp1 = load <2 x float>* %B
46 call void @llvm.arm.neon.vst1.v2f32(i8* %tmp0, <2 x float> %tmp1, i32 1)
47 %tmp2 = getelementptr float* %A, i32 2
48 store float* %tmp2, float** %ptr
49 ret void
50}
51
Bob Wilson2ed33462009-07-08 20:32:02 +000052define void @vst1i64(i64* %A, <1 x i64>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000053;CHECK: vst1i64:
54;CHECK: vst1.64
Bob Wilson02170c02010-04-20 00:17:16 +000055 %tmp0 = bitcast i64* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000056 %tmp1 = load <1 x i64>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000057 call void @llvm.arm.neon.vst1.v1i64(i8* %tmp0, <1 x i64> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000058 ret void
59}
60
61define void @vst1Qi8(i8* %A, <16 x i8>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000062;CHECK: vst1Qi8:
Bob Wilson2a6e6162010-09-23 23:42:37 +000063;Check the alignment value. Max for this instruction is 128 bits:
Bob Wilson7d247052010-10-08 06:15:13 +000064;CHECK: vst1.8 {d16, d17}, [r0, :64]
Bob Wilson2ed33462009-07-08 20:32:02 +000065 %tmp1 = load <16 x i8>* %B
Bob Wilson2a6e6162010-09-23 23:42:37 +000066 call void @llvm.arm.neon.vst1.v16i8(i8* %A, <16 x i8> %tmp1, i32 8)
Bob Wilson2ed33462009-07-08 20:32:02 +000067 ret void
68}
69
70define void @vst1Qi16(i16* %A, <8 x i16>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000071;CHECK: vst1Qi16:
Bob Wilson2a6e6162010-09-23 23:42:37 +000072;Check the alignment value. Max for this instruction is 128 bits:
Bob Wilson7d247052010-10-08 06:15:13 +000073;CHECK: vst1.16 {d16, d17}, [r0, :128]
Bob Wilson02170c02010-04-20 00:17:16 +000074 %tmp0 = bitcast i16* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000075 %tmp1 = load <8 x i16>* %B
Bob Wilson2a6e6162010-09-23 23:42:37 +000076 call void @llvm.arm.neon.vst1.v8i16(i8* %tmp0, <8 x i16> %tmp1, i32 32)
Bob Wilson2ed33462009-07-08 20:32:02 +000077 ret void
78}
79
Bob Wilson1c3ef902011-02-07 17:43:21 +000080;Check for a post-increment updating store with register increment.
81define void @vst1Qi16_update(i16** %ptr, <8 x i16>* %B, i32 %inc) nounwind {
82;CHECK: vst1Qi16_update:
83;CHECK: vst1.16 {d16, d17}, [r1, :64], r2
84 %A = load i16** %ptr
85 %tmp0 = bitcast i16* %A to i8*
86 %tmp1 = load <8 x i16>* %B
87 call void @llvm.arm.neon.vst1.v8i16(i8* %tmp0, <8 x i16> %tmp1, i32 8)
88 %tmp2 = getelementptr i16* %A, i32 %inc
89 store i16* %tmp2, i16** %ptr
90 ret void
91}
92
Bob Wilson2ed33462009-07-08 20:32:02 +000093define void @vst1Qi32(i32* %A, <4 x i32>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000094;CHECK: vst1Qi32:
95;CHECK: vst1.32
Bob Wilson02170c02010-04-20 00:17:16 +000096 %tmp0 = bitcast i32* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000097 %tmp1 = load <4 x i32>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000098 call void @llvm.arm.neon.vst1.v4i32(i8* %tmp0, <4 x i32> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000099 ret void
100}
101
102define void @vst1Qf(float* %A, <4 x float>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +0000103;CHECK: vst1Qf:
104;CHECK: vst1.32
Bob Wilson02170c02010-04-20 00:17:16 +0000105 %tmp0 = bitcast float* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +0000106 %tmp1 = load <4 x float>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +0000107 call void @llvm.arm.neon.vst1.v4f32(i8* %tmp0, <4 x float> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +0000108 ret void
109}
110
111define void @vst1Qi64(i64* %A, <2 x i64>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +0000112;CHECK: vst1Qi64:
113;CHECK: vst1.64
Bob Wilson02170c02010-04-20 00:17:16 +0000114 %tmp0 = bitcast i64* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +0000115 %tmp1 = load <2 x i64>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +0000116 call void @llvm.arm.neon.vst1.v2i64(i8* %tmp0, <2 x i64> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +0000117 ret void
118}
119
Bob Wilson7a9ef442010-08-27 17:13:24 +0000120declare void @llvm.arm.neon.vst1.v8i8(i8*, <8 x i8>, i32) nounwind
121declare void @llvm.arm.neon.vst1.v4i16(i8*, <4 x i16>, i32) nounwind
122declare void @llvm.arm.neon.vst1.v2i32(i8*, <2 x i32>, i32) nounwind
123declare void @llvm.arm.neon.vst1.v2f32(i8*, <2 x float>, i32) nounwind
124declare void @llvm.arm.neon.vst1.v1i64(i8*, <1 x i64>, i32) nounwind
Bob Wilson2ed33462009-07-08 20:32:02 +0000125
Bob Wilson7a9ef442010-08-27 17:13:24 +0000126declare void @llvm.arm.neon.vst1.v16i8(i8*, <16 x i8>, i32) nounwind
127declare void @llvm.arm.neon.vst1.v8i16(i8*, <8 x i16>, i32) nounwind
128declare void @llvm.arm.neon.vst1.v4i32(i8*, <4 x i32>, i32) nounwind
129declare void @llvm.arm.neon.vst1.v4f32(i8*, <4 x float>, i32) nounwind
130declare void @llvm.arm.neon.vst1.v2i64(i8*, <2 x i64>, i32) nounwind