diff options
| author | Douglas Gregor <dgregor@apple.com> | 2010-08-06 10:14:59 +0000 | 
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2010-08-06 10:14:59 +0000 | 
| commit | 59e8b3bd7bf2c9efc8d9b74e98eee13684cfc75b (patch) | |
| tree | 48d7c964024ab9f0ba907fe6a5be74c0c6b8c60e /clang/lib/AST/ASTContext.cpp | |
| parent | 249179cd732ca82bda2de128ac1eaab6159273e0 (diff) | |
| download | bcm5719-llvm-59e8b3bd7bf2c9efc8d9b74e98eee13684cfc75b.tar.gz bcm5719-llvm-59e8b3bd7bf2c9efc8d9b74e98eee13684cfc75b.zip | |
Introduce implicit conversions between AltiVec vectors and GCC
vectors, from Anton Yartsev!
llvm-svn: 110437
Diffstat (limited to 'clang/lib/AST/ASTContext.cpp')
| -rw-r--r-- | clang/lib/AST/ASTContext.cpp | 27 | 
1 files changed, 23 insertions, 4 deletions
| diff --git a/clang/lib/AST/ASTContext.cpp b/clang/lib/AST/ASTContext.cpp index 43873a4efd7..22e1ebf5697 100644 --- a/clang/lib/AST/ASTContext.cpp +++ b/clang/lib/AST/ASTContext.cpp @@ -1540,10 +1540,7 @@ QualType ASTContext::getVectorType(QualType vecType, unsigned NumElts,    // If the element type isn't canonical, this won't be a canonical type either,    // so fill in the canonical type field.    QualType Canonical; -  if (!vecType.isCanonical() || (AltiVecSpec == VectorType::AltiVec)) { -    // pass VectorType::NotAltiVec for AltiVecSpec to make AltiVec canonical -    // vector type (except 'vector bool ...' and 'vector Pixel') the same as -    // the equivalent GCC vector types +  if (!vecType.isCanonical()) {      Canonical = getVectorType(getCanonicalType(vecType), NumElts,        VectorType::NotAltiVec); @@ -4170,6 +4167,28 @@ static bool areCompatVectorTypes(const VectorType *LHS,           LHS->getNumElements() == RHS->getNumElements();  } +bool ASTContext::areCompatibleVectorTypes(QualType FirstVec, +                                          QualType SecondVec) { +  assert(FirstVec->isVectorType() && "FirstVec should be a vector type"); +  assert(SecondVec->isVectorType() && "SecondVec should be a vector type"); + +  if (hasSameUnqualifiedType(FirstVec, SecondVec)) +    return true; + +  // AltiVec vectors types are identical to equivalent GCC vector types +  const VectorType *First = FirstVec->getAs<VectorType>(); +  const VectorType *Second = SecondVec->getAs<VectorType>(); +  if ((((First->getAltiVecSpecific() == VectorType::AltiVec) && +        (Second->getAltiVecSpecific() == VectorType::NotAltiVec)) || +       ((First->getAltiVecSpecific() == VectorType::NotAltiVec) && +        (Second->getAltiVecSpecific() == VectorType::AltiVec))) && +      hasSameType(First->getElementType(), Second->getElementType()) && +      (First->getNumElements() == Second->getNumElements())) +    return true; + +  return false; +} +  //===----------------------------------------------------------------------===//  // ObjCQualifiedIdTypesAreCompatible - Compatibility testing for qualified id's.  //===----------------------------------------------------------------------===// | 

