summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema
diff options
context:
space:
mode:
authorAnton Yartsev <anton.yartsev@gmail.com>2011-03-27 15:36:07 +0000
committerAnton Yartsev <anton.yartsev@gmail.com>2011-03-27 15:36:07 +0000
commit530deb9a3900b3aea4fa0ad2b7f2837b5a22689f (patch)
tree515888b97fd9179fe003a3c8770098d42e5ff2b5 /clang/lib/Sema
parent1f90da127f7f2b882ac8bd25e45a4e7b0b359b20 (diff)
downloadbcm5719-llvm-530deb9a3900b3aea4fa0ad2b7f2837b5a22689f.tar.gz
bcm5719-llvm-530deb9a3900b3aea4fa0ad2b7f2837b5a22689f.zip
AltiVec vector comparison logic now affect only vectors of fundamental AltiVec vector types. It fixes bug 9347.
llvm-svn: 128381
Diffstat (limited to 'clang/lib/Sema')
-rw-r--r--clang/lib/Sema/SemaExpr.cpp10
1 files changed, 6 insertions, 4 deletions
diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp
index b5c67b8fe66..214edf145c0 100644
--- a/clang/lib/Sema/SemaExpr.cpp
+++ b/clang/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<VectorType>()->getVectorKind() == VectorType::AltiVecVector
+ && rType->getAs<VectorType>()->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.
OpenPOWER on IntegriCloud