summaryrefslogtreecommitdiff
path: root/include/llvm/IntrinsicsARM.td
diff options
context:
space:
mode:
authorBob Wilson <bob.wilson@apple.com>2009-07-29 16:39:22 +0000
committerBob Wilson <bob.wilson@apple.com>2009-07-29 16:39:22 +0000
commitb7d0c90c449882c8ec697c8989244dba2dc917ae (patch)
treec25f7337ecd0ae0dee2ff100be597a2e38d165ec /include/llvm/IntrinsicsARM.td
parent09b1366f3f310b5648aa8cd72ed16b9f19b4c68d (diff)
downloadllvm-b7d0c90c449882c8ec697c8989244dba2dc917ae.tar.gz
llvm-b7d0c90c449882c8ec697c8989244dba2dc917ae.tar.bz2
llvm-b7d0c90c449882c8ec697c8989244dba2dc917ae.tar.xz
Change Neon VLDn intrinsics to return multiple values instead of really
wide vectors. Likewise, change VSTn intrinsics to take separate arguments for each vector in a multi-vector struct. Adjust tests accordingly. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@77468 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/IntrinsicsARM.td')
-rw-r--r--include/llvm/IntrinsicsARM.td60
1 files changed, 48 insertions, 12 deletions
diff --git a/include/llvm/IntrinsicsARM.td b/include/llvm/IntrinsicsARM.td
index e16797ae70..efe5bff437 100644
--- a/include/llvm/IntrinsicsARM.td
+++ b/include/llvm/IntrinsicsARM.td
@@ -291,20 +291,56 @@ def int_arm_neon_vmovlu : Neon_1Arg_Long_Intrinsic;
let TargetPrefix = "arm" in {
// De-interleaving vector loads from N-element structures.
- def int_arm_neon_vldi : Intrinsic<[llvm_anyint_ty],
- [llvm_ptr_ty, llvm_i32_ty],
- [IntrReadArgMem]>;
- def int_arm_neon_vldf : Intrinsic<[llvm_anyfloat_ty],
- [llvm_ptr_ty, llvm_i32_ty],
- [IntrReadArgMem]>;
+ def int_arm_neon_vld1i : Intrinsic<[llvm_anyint_ty],
+ [llvm_ptr_ty], [IntrReadArgMem]>;
+ def int_arm_neon_vld1f : Intrinsic<[llvm_anyfloat_ty],
+ [llvm_ptr_ty], [IntrReadArgMem]>;
+ def int_arm_neon_vld2i : Intrinsic<[llvm_anyint_ty, LLVMMatchType<0>],
+ [llvm_ptr_ty], [IntrReadArgMem]>;
+ def int_arm_neon_vld2f : Intrinsic<[llvm_anyfloat_ty, LLVMMatchType<0>],
+ [llvm_ptr_ty], [IntrReadArgMem]>;
+ def int_arm_neon_vld3i : Intrinsic<[llvm_anyint_ty, LLVMMatchType<0>,
+ LLVMMatchType<0>],
+ [llvm_ptr_ty], [IntrReadArgMem]>;
+ def int_arm_neon_vld3f : Intrinsic<[llvm_anyfloat_ty, LLVMMatchType<0>,
+ LLVMMatchType<0>],
+ [llvm_ptr_ty], [IntrReadArgMem]>;
+ def int_arm_neon_vld4i : Intrinsic<[llvm_anyint_ty, LLVMMatchType<0>,
+ LLVMMatchType<0>, LLVMMatchType<0>],
+ [llvm_ptr_ty], [IntrReadArgMem]>;
+ def int_arm_neon_vld4f : Intrinsic<[llvm_anyfloat_ty, LLVMMatchType<0>,
+ LLVMMatchType<0>, LLVMMatchType<0>],
+ [llvm_ptr_ty], [IntrReadArgMem]>;
// Interleaving vector stores from N-element structures.
- def int_arm_neon_vsti : Intrinsic<[llvm_void_ty],
- [llvm_ptr_ty, llvm_anyint_ty, llvm_i32_ty],
- [IntrWriteArgMem]>;
- def int_arm_neon_vstf : Intrinsic<[llvm_void_ty],
- [llvm_ptr_ty, llvm_anyfloat_ty,llvm_i32_ty],
- [IntrWriteArgMem]>;
+ def int_arm_neon_vst1i : Intrinsic<[llvm_void_ty],
+ [llvm_ptr_ty, llvm_anyint_ty],
+ [IntrWriteArgMem]>;
+ def int_arm_neon_vst1f : Intrinsic<[llvm_void_ty],
+ [llvm_ptr_ty, llvm_anyfloat_ty],
+ [IntrWriteArgMem]>;
+ def int_arm_neon_vst2i : Intrinsic<[llvm_void_ty],
+ [llvm_ptr_ty, llvm_anyint_ty,
+ LLVMMatchType<0>], [IntrWriteArgMem]>;
+ def int_arm_neon_vst2f : Intrinsic<[llvm_void_ty],
+ [llvm_ptr_ty, llvm_anyfloat_ty,
+ LLVMMatchType<0>], [IntrWriteArgMem]>;
+ def int_arm_neon_vst3i : Intrinsic<[llvm_void_ty],
+ [llvm_ptr_ty, llvm_anyint_ty,
+ LLVMMatchType<0>, LLVMMatchType<0>],
+ [IntrWriteArgMem]>;
+ def int_arm_neon_vst3f : Intrinsic<[llvm_void_ty],
+ [llvm_ptr_ty, llvm_anyfloat_ty,
+ LLVMMatchType<0>, LLVMMatchType<0>],
+ [IntrWriteArgMem]>;
+ def int_arm_neon_vst4i : Intrinsic<[llvm_void_ty],
+ [llvm_ptr_ty, llvm_anyint_ty,
+ LLVMMatchType<0>, LLVMMatchType<0>,
+ LLVMMatchType<0>], [IntrWriteArgMem]>;
+ def int_arm_neon_vst4f : Intrinsic<[llvm_void_ty],
+ [llvm_ptr_ty, llvm_anyfloat_ty,
+ LLVMMatchType<0>, LLVMMatchType<0>,
+ LLVMMatchType<0>], [IntrWriteArgMem]>;
// Vector Table Lookup
def int_arm_neon_vtbl : Intrinsic<[llvm_v8i8_ty],