blob: 2b535ada3072808a86567ae97f74428770708f06 [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:
5;CHECK: vst1.8
Bob Wilson2ed33462009-07-08 20:32:02 +00006 %tmp1 = load <8 x i8>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +00007 call void @llvm.arm.neon.vst1.v8i8(i8* %A, <8 x i8> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +00008 ret void
9}
10
11define void @vst1i16(i16* %A, <4 x i16>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000012;CHECK: vst1i16:
13;CHECK: vst1.16
Bob Wilson02170c02010-04-20 00:17:16 +000014 %tmp0 = bitcast i16* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000015 %tmp1 = load <4 x i16>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000016 call void @llvm.arm.neon.vst1.v4i16(i8* %tmp0, <4 x i16> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000017 ret void
18}
19
20define void @vst1i32(i32* %A, <2 x i32>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000021;CHECK: vst1i32:
22;CHECK: vst1.32
Bob Wilson02170c02010-04-20 00:17:16 +000023 %tmp0 = bitcast i32* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000024 %tmp1 = load <2 x i32>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000025 call void @llvm.arm.neon.vst1.v2i32(i8* %tmp0, <2 x i32> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000026 ret void
27}
28
29define void @vst1f(float* %A, <2 x float>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000030;CHECK: vst1f:
31;CHECK: vst1.32
Bob Wilson02170c02010-04-20 00:17:16 +000032 %tmp0 = bitcast float* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000033 %tmp1 = load <2 x float>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000034 call void @llvm.arm.neon.vst1.v2f32(i8* %tmp0, <2 x float> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000035 ret void
36}
37
38define void @vst1i64(i64* %A, <1 x i64>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000039;CHECK: vst1i64:
40;CHECK: vst1.64
Bob Wilson02170c02010-04-20 00:17:16 +000041 %tmp0 = bitcast i64* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000042 %tmp1 = load <1 x i64>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000043 call void @llvm.arm.neon.vst1.v1i64(i8* %tmp0, <1 x i64> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000044 ret void
45}
46
47define void @vst1Qi8(i8* %A, <16 x i8>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000048;CHECK: vst1Qi8:
49;CHECK: vst1.8
Bob Wilson2ed33462009-07-08 20:32:02 +000050 %tmp1 = load <16 x i8>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000051 call void @llvm.arm.neon.vst1.v16i8(i8* %A, <16 x i8> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000052 ret void
53}
54
55define void @vst1Qi16(i16* %A, <8 x i16>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000056;CHECK: vst1Qi16:
57;CHECK: vst1.16
Bob Wilson02170c02010-04-20 00:17:16 +000058 %tmp0 = bitcast i16* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000059 %tmp1 = load <8 x i16>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000060 call void @llvm.arm.neon.vst1.v8i16(i8* %tmp0, <8 x i16> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000061 ret void
62}
63
64define void @vst1Qi32(i32* %A, <4 x i32>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000065;CHECK: vst1Qi32:
66;CHECK: vst1.32
Bob Wilson02170c02010-04-20 00:17:16 +000067 %tmp0 = bitcast i32* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000068 %tmp1 = load <4 x i32>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000069 call void @llvm.arm.neon.vst1.v4i32(i8* %tmp0, <4 x i32> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000070 ret void
71}
72
73define void @vst1Qf(float* %A, <4 x float>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000074;CHECK: vst1Qf:
75;CHECK: vst1.32
Bob Wilson02170c02010-04-20 00:17:16 +000076 %tmp0 = bitcast float* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000077 %tmp1 = load <4 x float>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000078 call void @llvm.arm.neon.vst1.v4f32(i8* %tmp0, <4 x float> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000079 ret void
80}
81
82define void @vst1Qi64(i64* %A, <2 x i64>* %B) nounwind {
Bob Wilson3765d0f2009-08-05 23:51:20 +000083;CHECK: vst1Qi64:
84;CHECK: vst1.64
Bob Wilson02170c02010-04-20 00:17:16 +000085 %tmp0 = bitcast i64* %A to i8*
Bob Wilson2ed33462009-07-08 20:32:02 +000086 %tmp1 = load <2 x i64>* %B
Bob Wilson7a9ef442010-08-27 17:13:24 +000087 call void @llvm.arm.neon.vst1.v2i64(i8* %tmp0, <2 x i64> %tmp1, i32 1)
Bob Wilson2ed33462009-07-08 20:32:02 +000088 ret void
89}
90
Bob Wilson7a9ef442010-08-27 17:13:24 +000091declare void @llvm.arm.neon.vst1.v8i8(i8*, <8 x i8>, i32) nounwind
92declare void @llvm.arm.neon.vst1.v4i16(i8*, <4 x i16>, i32) nounwind
93declare void @llvm.arm.neon.vst1.v2i32(i8*, <2 x i32>, i32) nounwind
94declare void @llvm.arm.neon.vst1.v2f32(i8*, <2 x float>, i32) nounwind
95declare void @llvm.arm.neon.vst1.v1i64(i8*, <1 x i64>, i32) nounwind
Bob Wilson2ed33462009-07-08 20:32:02 +000096
Bob Wilson7a9ef442010-08-27 17:13:24 +000097declare void @llvm.arm.neon.vst1.v16i8(i8*, <16 x i8>, i32) nounwind
98declare void @llvm.arm.neon.vst1.v8i16(i8*, <8 x i16>, i32) nounwind
99declare void @llvm.arm.neon.vst1.v4i32(i8*, <4 x i32>, i32) nounwind
100declare void @llvm.arm.neon.vst1.v4f32(i8*, <4 x float>, i32) nounwind
101declare void @llvm.arm.neon.vst1.v2i64(i8*, <2 x i64>, i32) nounwind