mirror of
https://github.com/intel/llvm.git
synced 2026-01-24 17:01:00 +08:00
Fix bug in vector initializer when initializing a vector with another vector.
Add test case. llvm-svn: 129617
This commit is contained in:
@@ -841,6 +841,12 @@ VectorExprEvaluator::VisitInitListExpr(const InitListExpr *E) {
|
||||
// becomes every element of the vector, not just the first.
|
||||
// This is the behavior described in the IBM AltiVec documentation.
|
||||
if (NumInits == 1) {
|
||||
|
||||
// Handle the case where the vector is initialized by a another
|
||||
// vector (OpenCL 6.1.6).
|
||||
if (E->getInit(0)->getType()->isVectorType())
|
||||
return this->Visit(const_cast<Expr*>(E->getInit(0)));
|
||||
|
||||
APValue InitValue;
|
||||
if (EltTy->isIntegerType()) {
|
||||
llvm::APSInt sInt(32);
|
||||
|
||||
12
clang/test/CodeGenOpenCL/2011-04-15-vec-init-from-vec.cl
Normal file
12
clang/test/CodeGenOpenCL/2011-04-15-vec-init-from-vec.cl
Normal file
@@ -0,0 +1,12 @@
|
||||
// RUN: %clang_cc1 %s -emit-llvm -o %t
|
||||
|
||||
typedef __attribute__((ext_vector_type(8))) unsigned char uchar8;
|
||||
typedef __attribute__((ext_vector_type(4))) unsigned long ulong4;
|
||||
typedef __attribute__((ext_vector_type(16))) unsigned char uchar16;
|
||||
|
||||
// OpenCL allows vectors to be initialized by vectors Handle bug in
|
||||
// VisitInitListExpr for this case below.
|
||||
void foo( ulong4 v )
|
||||
{
|
||||
uchar8 val[4] = {{(uchar8){((uchar16)(v.lo)).lo}}};
|
||||
}
|
||||
Reference in New Issue
Block a user