]> granicus.if.org Git - clang/commitdiff
[AArch64] Remove q and non-q intrinsic definitions from the NEON scalar reduce
authorChad Rosier <mcrosier@codeaurora.org>
Mon, 9 Dec 2013 22:47:55 +0000 (22:47 +0000)
committerChad Rosier <mcrosier@codeaurora.org>
Mon, 9 Dec 2013 22:47:55 +0000 (22:47 +0000)
pairwise implementation, using an overloaded definition instead.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@196834 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGBuiltin.cpp

index 0a83d99330deb2f4bde03055dcc94474b6f7d505..4a7e490fcea721480dd2f904fa17e5929465c0a4 100644 (file)
@@ -1990,39 +1990,29 @@ static Value *EmitAArch64ScalarBuiltinExpr(CodeGenFunction &CGF,
     Int = Intrinsic::aarch64_neon_vpadd; s = "vpadd";
     break;
   case AArch64::BI__builtin_neon_vpadds_f32:
-    Int = Intrinsic::aarch64_neon_vpfadd; s = "vpfadd";
-    break;
   case AArch64::BI__builtin_neon_vpaddd_f64:
-    Int = Intrinsic::aarch64_neon_vpfaddq; s = "vpfaddq";
-    break;
+    Int = Intrinsic::aarch64_neon_vpfadd;
+    s = "vpfadd"; AcrossVec = true; break;
   // Scalar Reduce Pairwise Floating Point Max
   case AArch64::BI__builtin_neon_vpmaxs_f32:
-    Int = Intrinsic::aarch64_neon_vpmax; s = "vpmax";
-    break;
   case AArch64::BI__builtin_neon_vpmaxqd_f64:
-    Int = Intrinsic::aarch64_neon_vpmaxq; s = "vpmaxq";
-    break;
+    Int = Intrinsic::aarch64_neon_vpmax;
+    s = "vpmax"; AcrossVec = true; break;
   // Scalar Reduce Pairwise Floating Point Min
   case AArch64::BI__builtin_neon_vpmins_f32:
-    Int = Intrinsic::aarch64_neon_vpmin; s = "vpmin";
-    break;
   case AArch64::BI__builtin_neon_vpminqd_f64:
-    Int = Intrinsic::aarch64_neon_vpminq; s = "vpminq";
-    break;
+    Int = Intrinsic::aarch64_neon_vpmin;
+    s = "vpmin"; AcrossVec = true; break;
   // Scalar Reduce Pairwise Floating Point Maxnm
   case AArch64::BI__builtin_neon_vpmaxnms_f32:
-    Int = Intrinsic::aarch64_neon_vpfmaxnm; s = "vpfmaxnm";
-    break;
   case AArch64::BI__builtin_neon_vpmaxnmqd_f64:
-    Int = Intrinsic::aarch64_neon_vpfmaxnmq; s = "vpfmaxnmq";
-    break;
+    Int = Intrinsic::aarch64_neon_vpfmaxnm;
+    s = "vpfmaxnm"; AcrossVec = true; break;
   // Scalar Reduce Pairwise Floating Point Minnm
   case AArch64::BI__builtin_neon_vpminnms_f32:
-    Int = Intrinsic::aarch64_neon_vpfminnm; s = "vpfminnm";
-    break;
   case AArch64::BI__builtin_neon_vpminnmqd_f64:
-    Int = Intrinsic::aarch64_neon_vpfminnmq; s = "vpfminnmq";
-    break;
+    Int = Intrinsic::aarch64_neon_vpfminnm;
+    s = "vpfminnm"; AcrossVec = true; break;
   // The followings are intrinsics with scalar results generated AcrossVec vectors
   case AArch64::BI__builtin_neon_vaddlv_s8:
   case AArch64::BI__builtin_neon_vaddlv_s16: