diff --git a/clang/lib/Sema/SemaInit.cpp b/clang/lib/Sema/SemaInit.cpp index bc1069609336..85af4bc492ce 100644 --- a/clang/lib/Sema/SemaInit.cpp +++ b/clang/lib/Sema/SemaInit.cpp @@ -1289,7 +1289,16 @@ void InitListChecker::CheckSubElementType(const InitializedEntity &Entity, // FIXME: Better EqualLoc? InitializationKind Kind = InitializationKind::CreateCopy(expr->getBeginLoc(), SourceLocation()); - InitializationSequence Seq(SemaRef, Entity, Kind, expr, + + // Vector elements can be initialized from other vectors in which case + // we need initialization entity with a type of a vector (and not a vector + // element!) initializing multiple vector elements. + auto TmpEntity = + (ElemType->isExtVectorType() && !Entity.getType()->isExtVectorType()) + ? InitializedEntity::InitializeTemporary(ElemType) + : Entity; + + InitializationSequence Seq(SemaRef, TmpEntity, Kind, expr, /*TopLevelOfInitList*/ true); // C++14 [dcl.init.aggr]p13: @@ -1300,8 +1309,7 @@ void InitListChecker::CheckSubElementType(const InitializedEntity &Entity, // assignment-expression. if (Seq || isa(expr)) { if (!VerifyOnly) { - ExprResult Result = - Seq.Perform(SemaRef, Entity, Kind, expr); + ExprResult Result = Seq.Perform(SemaRef, TmpEntity, Kind, expr); if (Result.isInvalid()) hadError = true; diff --git a/clang/test/CodeGenOpenCL/vector_literals_nested.cl b/clang/test/CodeGenOpenCL/vector_literals_nested.cl deleted file mode 100644 index b9013d0482f9..000000000000 --- a/clang/test/CodeGenOpenCL/vector_literals_nested.cl +++ /dev/null @@ -1,23 +0,0 @@ -// RUN: %clang_cc1 %s -emit-llvm -O3 -o - | FileCheck %s - -typedef int int2 __attribute((ext_vector_type(2))); -typedef int int4 __attribute((ext_vector_type(4))); - -__constant const int4 itest1 = (int4)(1, 2, ((int2)(3, 4))); -// CHECK: constant <4 x i32> -__constant const int4 itest2 = (int4)(1, 2, ((int2)(3))); -// CHECK: constant <4 x i32> - -typedef float float2 __attribute((ext_vector_type(2))); -typedef float float4 __attribute((ext_vector_type(4))); - -void ftest1(float4 *p) { - *p = (float4)(1.1f, 1.2f, ((float2)(1.3f, 1.4f))); -// CHECK: store <4 x float> -} - -float4 ftest2(float4 *p) { - *p = (float4)(1.1f, 1.2f, ((float2)(1.3f))); -// CHECK: store <4 x float> -} - diff --git a/clang/test/CodeGenOpenCL/vector_literals_valid.cl b/clang/test/CodeGenOpenCL/vector_literals_valid.cl index bba5b23e23bd..5aa7ae4a4b89 100644 --- a/clang/test/CodeGenOpenCL/vector_literals_valid.cl +++ b/clang/test/CodeGenOpenCL/vector_literals_valid.cl @@ -1,22 +1,65 @@ -// RUN: %clang_cc1 -emit-llvm %s -o %t +// RUN: %clang_cc1 -emit-llvm %s -o - -O0 | FileCheck %s +// RUN: %clang_cc1 -emit-llvm %s -o - -cl-std=clc++ -O0 | FileCheck %s -typedef __attribute__(( ext_vector_type(2) )) int int2; -typedef __attribute__(( ext_vector_type(3) )) int int3; -typedef __attribute__(( ext_vector_type(4) )) int int4; -typedef __attribute__(( ext_vector_type(8) )) int int8; -typedef __attribute__(( ext_vector_type(4) )) float float4; +typedef __attribute__((ext_vector_type(2))) int int2; +typedef __attribute__((ext_vector_type(3))) int int3; +typedef __attribute__((ext_vector_type(4))) int int4; +typedef __attribute__((ext_vector_type(8))) int int8; +typedef __attribute__((ext_vector_type(4))) float float4; + +__constant const int4 c1 = (int4)(1, 2, ((int2)(3))); +// CHECK: constant <4 x i32> + +__constant const int4 c2 = (int4)(1, 2, ((int2)(3, 4))); +// CHECK: constant <4 x i32> void vector_literals_valid() { - int4 a_1_1_1_1 = (int4)(1,2,3,4); - int4 a_2_1_1 = (int4)((int2)(1,2),3,4); - int4 a_1_2_1 = (int4)(1,(int2)(2,3),4); - int4 a_1_1_2 = (int4)(1,2,(int2)(3,4)); - int4 a_2_2 = (int4)((int2)(1,2),(int2)(3,4)); - int4 a_3_1 = (int4)((int3)(1,2,3),4); - int4 a_1_3 = (int4)(1,(int3)(2,3,4)); + //CHECK: insertelement <4 x i32> , i32 %{{.+}}, i32 2 + //CHECK: insertelement <4 x i32> %{{.+}}, i32 %{{.+}}, i32 3 + int4 a_1_1_1_1 = (int4)(1, 2, c1.s2, c2.s3); + + //CHECK: store <2 x i32> , <2 x i32>* + //CHECK: shufflevector <2 x i32> %{{[0-9]+}}, <2 x i32> undef, <4 x i32> + //CHECK: shufflevector <4 x i32> %{{.+}}, <4 x i32> undef, <4 x i32> + //CHECK: insertelement <4 x i32> %{{.+}}, i32 3, i32 2 + //CHECK: insertelement <4 x i32> %{{.+}}, i32 4, i32 3 + int4 a_2_1_1 = (int4)((int2)(1, 2), 3, 4); + + //CHECK: store <2 x i32> , <2 x i32>* + //CHECK: shufflevector <2 x i32> %{{[0-9]+}}, <2 x i32> undef, <4 x i32> + //CHECK: shufflevector <4 x i32> , <4 x i32> %{{.+}}, <4 x i32> + //CHECK: insertelement <4 x i32> %{{.+}}, i32 4, i32 3 + int4 a_1_2_1 = (int4)(1, (int2)(2, 3), 4); + + //CHECK: store <2 x i32> , <2 x i32>* + //CHECK: shufflevector <2 x i32> %{{[0-9]+}}, <2 x i32> undef, <4 x i32> + //CHECK: shufflevector <4 x i32> , <4 x i32> %{{.+}}, <4 x i32> + int4 a_1_1_2 = (int4)(1, 2, (int2)(3, 4)); + + //CHECK: store <2 x i32> , <2 x i32>* + //CHECK: shufflevector <2 x i32> %{{[0-9]+}}, <2 x i32> undef, <4 x i32> + //CHECK: shufflevector <4 x i32> %{{.+}}, <4 x i32> undef, <4 x i32> + //CHECK: shufflevector <4 x i32> %{{.+}}, <4 x i32> , <4 x i32> + int4 a_2_2 = (int4)((int2)(1, 2), (int2)(3)); + + //CHECK: store <4 x i32> , <4 x i32>* + //CHECK: shufflevector <4 x i32> %{{.+}}, <4 x i32> undef, <3 x i32> + //CHECK: shufflevector <3 x i32> %{{.+}}, <3 x i32> undef, <4 x i32> + //CHECK: shufflevector <4 x i32> , <4 x i32> %{{.+}}, <4 x i32> + int4 a_1_3 = (int4)(1, (int3)(2, 3, 4)); + + //CHECK: store <4 x i32> , <4 x i32>* %a int4 a = (int4)(1); - int8 b = (int8)(1,2,a.xy,a); - float4 V2 = (float4) (1); + + //CHECK: load <4 x i32>, <4 x i32>* %a, align 16 + //CHECK: shufflevector <4 x i32> %{{[0-9]+}}, <4 x i32> undef, <2 x i32> + //CHECK: shufflevector <2 x i32> %{{[0-9]+}}, <2 x i32> undef, <8 x i32> + //CHECK: shufflevector <8 x i32> , <8 x i32> %{{.+}}, <8 x i32> + //CHECK: load <4 x i32>, <4 x i32>* %a, align 16 + //CHECK: shufflevector <4 x i32> %{{[0-9]+}}, <4 x i32> undef, <8 x i32> + //CHECK: shufflevector <8 x i32> %{{.+}}, <8 x i32> %{{.+}}, <8 x i32> + int8 b = (int8)(1, 2, a.xy, a); + + //CHECK: store <4 x float> , <4 x float>* %V2 + float4 V2 = (float4)(1); } - - diff --git a/clang/test/SemaCXX/vector.cpp b/clang/test/SemaCXX/vector.cpp index a6a4ceb0e535..40dcd35c1bb6 100644 --- a/clang/test/SemaCXX/vector.cpp +++ b/clang/test/SemaCXX/vector.cpp @@ -334,3 +334,11 @@ void Init() { } } // namespace Templates + +typedef int inte2 __attribute__((__ext_vector_type__(2))); + +void test_vector_literal(inte4 res) { + inte2 a = (inte2)(1, 2); //expected-warning{{expression result unused}} + inte4 b = (inte4)(a, a); //expected-error{{C-style cast from vector 'inte2' (vector of 2 'int' values) to vector 'inte4' (vector of 4 'int' values) of different size}} //expected-warning{{expression result unused}} +} + diff --git a/clang/test/SemaOpenCL/vector_literals_const.cl b/clang/test/SemaOpenCL/vector_literals_const.cl deleted file mode 100644 index ee5ae2002a3c..000000000000 --- a/clang/test/SemaOpenCL/vector_literals_const.cl +++ /dev/null @@ -1,27 +0,0 @@ -// RUN: %clang_cc1 %s -verify -pedantic -fsyntax-only -// expected-no-diagnostics - -typedef int int2 __attribute((ext_vector_type(2))); -typedef int int3 __attribute((ext_vector_type(3))); -typedef int int4 __attribute((ext_vector_type(4))); - -__constant int4 i_1_1_1_1 = (int4)(1,2,3,4); -__constant int4 i_2_1_1 = (int4)((int2)(1,2),3,4); -__constant int4 i_1_2_1 = (int4)(1,(int2)(2,3),4); -__constant int4 i_1_1_2 = (int4)(1,2,(int2)(3,4)); -__constant int4 i_2_2 = (int4)((int2)(1,2),(int2)(3,4)); -__constant int4 i_3_1 = (int4)((int3)(1,2,3),4); -__constant int4 i_1_3 = (int4)(1,(int3)(2,3,4)); - -typedef float float2 __attribute((ext_vector_type(2))); -typedef float float3 __attribute((ext_vector_type(3))); -typedef float float4 __attribute((ext_vector_type(4))); - -__constant float4 f_1_1_1_1 = (float4)(1,2,3,4); -__constant float4 f_2_1_1 = (float4)((float2)(1,2),3,4); -__constant float4 f_1_2_1 = (float4)(1,(float2)(2,3),4); -__constant float4 f_1_1_2 = (float4)(1,2,(float2)(3,4)); -__constant float4 f_2_2 = (float4)((float2)(1,2),(float2)(3,4)); -__constant float4 f_3_1 = (float4)((float3)(1,2,3),4); -__constant float4 f_1_3 = (float4)(1,(float3)(2,3,4)); -