[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