blob: 70f3a4cfa28c525fd2e7bd653806a2a944cdfe39 [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
39define void @vst1i64(i64* %A, <1 x i64>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000040;CHECK: vst1i64:
41;CHECK: vst1.64
Bob Wilson02170c02010-04-20 00:17:16 +000042 %tmp0 = bitcast i64* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000043 %tmp1 = load <1 x i64>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000044 call void @llvm.arm.neon.vst1.v1i64(i8* %tmp0, <1 x i64> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000045 ret void
46}
47
48define void @vst1Qi8(i8* %A, <16 x i8>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000049;CHECK: vst1Qi8:
Bob Wilson2a6e6162010-09-23 23:42:37 +000050;Check the alignment value. Max for this instruction is 128 bits:
Bob Wilson7d247052010-10-08 06:15:13 +000051;CHECK: vst1.8 {d16, d17}, [r0, :64]
Bob Wilson2ed33462009-07-08 20:32:02 +000052 %tmp1 = load <16 x i8>* %B
Bob Wilson2a6e6162010-09-23 23:42:37 +000053 call void @llvm.arm.neon.vst1.v16i8(i8* %A, <16 x i8> %tmp1, i32 8)
Bob Wilson2ed33462009-07-08 20:32:02 +000054 ret void
55}
56
57define void @vst1Qi16(i16* %A, <8 x i16>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000058;CHECK: vst1Qi16:
Bob Wilson2a6e6162010-09-23 23:42:37 +000059;Check the alignment value. Max for this instruction is 128 bits:
Bob Wilson7d247052010-10-08 06:15:13 +000060;CHECK: vst1.16 {d16, d17}, [r0, :128]
Bob Wilson02170c02010-04-20 00:17:16 +000061 %tmp0 = bitcast i16* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000062 %tmp1 = load <8 x i16>* %B
Bob Wilson2a6e6162010-09-23 23:42:37 +000063 call void @llvm.arm.neon.vst1.v8i16(i8* %tmp0, <8 x i16> %tmp1, i32 32)
Bob Wilson2ed33462009-07-08 20:32:02 +000064 ret void
65}
66
67define void @vst1Qi32(i32* %A, <4 x i32>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000068;CHECK: vst1Qi32:
69;CHECK: vst1.32
Bob Wilson02170c02010-04-20 00:17:16 +000070 %tmp0 = bitcast i32* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000071 %tmp1 = load <4 x i32>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000072 call void @llvm.arm.neon.vst1.v4i32(i8* %tmp0, <4 x i32> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000073 ret void
74}
75
76define void @vst1Qf(float* %A, <4 x float>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000077;CHECK: vst1Qf:
78;CHECK: vst1.32
Bob Wilson02170c02010-04-20 00:17:16 +000079 %tmp0 = bitcast float* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000080 %tmp1 = load <4 x float>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000081 call void @llvm.arm.neon.vst1.v4f32(i8* %tmp0, <4 x float> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000082 ret void
83}
84
85define void @vst1Qi64(i64* %A, <2 x i64>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000086;CHECK: vst1Qi64:
87;CHECK: vst1.64
Bob Wilson02170c02010-04-20 00:17:16 +000088 %tmp0 = bitcast i64* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000089 %tmp1 = load <2 x i64>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000090 call void @llvm.arm.neon.vst1.v2i64(i8* %tmp0, <2 x i64> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000091 ret void
92}
93
Bob Wilson7a9ef442010-08-27 17:13:24 +000094declare void @llvm.arm.neon.vst1.v8i8(i8*, <8 x i8>, i32) nounwind
95declare void @llvm.arm.neon.vst1.v4i16(i8*, <4 x i16>, i32) nounwind
96declare void @llvm.arm.neon.vst1.v2i32(i8*, <2 x i32>, i32) nounwind
97declare void @llvm.arm.neon.vst1.v2f32(i8*, <2 x float>, i32) nounwind
98declare void @llvm.arm.neon.vst1.v1i64(i8*, <1 x i64>, i32) nounwind
Bob Wilson2ed33462009-07-08 20:32:02 +000099
Bob Wilson7a9ef442010-08-27 17:13:24 +0000100declare void @llvm.arm.neon.vst1.v16i8(i8*, <16 x i8>, i32) nounwind
101declare void @llvm.arm.neon.vst1.v8i16(i8*, <8 x i16>, i32) nounwind
102declare void @llvm.arm.neon.vst1.v4i32(i8*, <4 x i32>, i32) nounwind
103declare void @llvm.arm.neon.vst1.v4f32(i8*, <4 x float>, i32) nounwind
104declare void @llvm.arm.neon.vst1.v2i64(i8*, <2 x i64>, i32) nounwind