[cfe-commits] r107824 - in /cfe/trunk: lib/Sema/SemaInit.cpp test/Sema/opencl-init.c

Nate Begeman natebegeman at mac.com
Wed Jul 7 15:26:56 PDT 2010


Author: sampo
Date: Wed Jul  7 17:26:56 2010
New Revision: 107824

URL: http://llvm.org/viewvc/llvm-project?rev=107824&view=rev
Log:
Fix an issue with opencl init list checking.

Added:
    cfe/trunk/test/Sema/opencl-init.c
Modified:
    cfe/trunk/lib/Sema/SemaInit.cpp

Modified: cfe/trunk/lib/Sema/SemaInit.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaInit.cpp?rev=107824&r1=107823&r2=107824&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaInit.cpp (original)
+++ cfe/trunk/lib/Sema/SemaInit.cpp Wed Jul  7 17:26:56 2010
@@ -877,10 +877,15 @@
                               StructuredList, StructuredIndex);
           ++numEltsInit;
         } else {
+          QualType VecType;
           const VectorType *IVT = IType->getAs<VectorType>();
           unsigned numIElts = IVT->getNumElements();
-          QualType VecType = SemaRef.Context.getExtVectorType(elementType,
-                                                              numIElts);
+          
+          if (IType->isExtVectorType())
+            VecType = SemaRef.Context.getExtVectorType(elementType, numIElts);
+          else
+            VecType = SemaRef.Context.getVectorType(elementType, numIElts,
+                                                    IVT->getAltiVecSpecific());
           CheckSubElementType(ElementEntity, IList, VecType, Index,
                               StructuredList, StructuredIndex);
           numEltsInit += numIElts;

Added: cfe/trunk/test/Sema/opencl-init.c
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/opencl-init.c?rev=107824&view=auto
==============================================================================
--- cfe/trunk/test/Sema/opencl-init.c (added)
+++ cfe/trunk/test/Sema/opencl-init.c Wed Jul  7 17:26:56 2010
@@ -0,0 +1,15 @@
+// RUN: %clang_cc1 %s -x cl -verify -pedantic -fsyntax-only
+
+typedef float float8 __attribute((ext_vector_type(8)));
+
+typedef float float32_t;
+typedef __attribute__(( __vector_size__(16) )) float32_t __neon_float32x4_t;
+typedef struct __simd128_float32_t {
+  __neon_float32x4_t val;
+} float32x4_t;
+
+float8 foo(float8 x) { 
+  float32x4_t lo;
+  float32x4_t hi;
+  return (float8) (lo.val, hi.val);
+}





More information about the cfe-commits mailing list