diff options
| author | Anton Yartsev <anton.yartsev@gmail.com> | 2011-03-27 15:36:07 +0000 |
|---|---|---|
| committer | Anton Yartsev <anton.yartsev@gmail.com> | 2011-03-27 15:36:07 +0000 |
| commit | 530deb9a3900b3aea4fa0ad2b7f2837b5a22689f (patch) | |
| tree | 515888b97fd9179fe003a3c8770098d42e5ff2b5 /clang/lib/Sema | |
| parent | 1f90da127f7f2b882ac8bd25e45a4e7b0b359b20 (diff) | |
| download | bcm5719-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.cpp | 10 |
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. |

