From: Anton Yartsev Date: Sun, 27 Mar 2011 15:36:07 +0000 (+0000) Subject: AltiVec vector comparison logic now affect only vectors of fundamental AltiVec vector... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=7870b133ac7b03bd53388f51250d009325f43399;p=clang AltiVec vector comparison logic now affect only vectors of fundamental AltiVec vector types. It fixes bug 9347. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@128381 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGExprScalar.cpp b/lib/CodeGen/CGExprScalar.cpp index 27b868974d..c6a5a40d76 100644 --- a/lib/CodeGen/CGExprScalar.cpp +++ b/lib/CodeGen/CGExprScalar.cpp @@ -2119,7 +2119,9 @@ Value *ScalarExprEmitter::EmitCompare(const BinaryOperator *E,unsigned UICmpOpc, // If AltiVec, the comparison results in a numeric type, so we use // intrinsics comparing vectors and giving 0 or 1 as a result - if (LHSTy->isVectorType() && CGF.getContext().getLangOptions().AltiVec) { + if (LHSTy->isVectorType() && + LHSTy->getAs()->getVectorKind() == + VectorType::AltiVecVector) { // constants for mapping CR6 register bits to predicate result enum { CR6_EQ=0, CR6_EQ_REV, CR6_LT, CR6_LT_REV } CR6; diff --git a/lib/Sema/SemaExpr.cpp b/lib/Sema/SemaExpr.cpp index b5c67b8fe6..214edf145c 100644 --- a/lib/Sema/SemaExpr.cpp +++ b/lib/Sema/SemaExpr.cpp @@ -7277,14 +7277,16 @@ QualType Sema::CheckVectorCompareOperands(Expr *&lex, Expr *&rex, if (vType.isNull()) return vType; + QualType lType = lex->getType(); + QualType rType = rex->getType(); + // If AltiVec, the comparison results in a numeric type, i.e. // bool for C++, int for C - if (getLangOptions().AltiVec) + if (lType->getAs()->getVectorKind() == VectorType::AltiVecVector + && rType->getAs()->getVectorKind() == + VectorType::AltiVecVector) return Context.getLogicalOperationType(); - QualType lType = lex->getType(); - QualType rType = rex->getType(); - // For non-floating point types, check for self-comparisons of the form // x == x, x != x, x < x, etc. These always evaluate to a constant, and // often indicate logic errors in the program. diff --git a/test/Sema/vector-ops.c b/test/Sema/vector-ops.c index 20575ec510..ca397375d7 100644 --- a/test/Sema/vector-ops.c +++ b/test/Sema/vector-ops.c @@ -12,6 +12,9 @@ void test1(v2u v2ua, v2s v2sa, v2f v2fa) { (void)(~v2ua); (void)(~v2fa); // expected-error{{invalid argument type 'v2f' to unary}} + // Comparison operators + v2ua = (v2ua==v2sa); + // Arrays int array1[v2ua]; // expected-error{{size of array has non-integer type 'v2u'}} int array2[17];