From b7d0c90c449882c8ec697c8989244dba2dc917ae Mon Sep 17 00:00:00 2001 From: Bob Wilson Date: Wed, 29 Jul 2009 16:39:22 +0000 Subject: 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 --- include/llvm/IntrinsicsARM.td | 60 ++++++++++++++++++++++++++++++++++--------- 1 file changed, 48 insertions(+), 12 deletions(-) (limited to 'include') diff --git a/include/llvm/IntrinsicsARM.td b/include/llvm/IntrinsicsARM.td index e16797a..efe5bff 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], -- cgit v1.1