Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / clang / test / SemaOpenCL / arithmetic-conversions.cl
blob3d9f34851e902d824b88b0dede51a4d6074feb44
1 // RUN: %clang_cc1 %s -triple spir-unknown-unknown -verify -pedantic -fsyntax-only -cl-std=CL1.2
3 typedef float float2 __attribute__((ext_vector_type(2)));
4 typedef long long2 __attribute__((ext_vector_type(2)));
5 typedef int int2 __attribute__((ext_vector_type(2)));
7 kernel void foo1(float2 in, global float2 *out) { *out = in + 0.5;} // expected-error {{scalar operand type has greater rank than the type of the vector element. ('float2' (vector of 2 'float' values) and 'double')}}
9 kernel void foo2(float2 in, global float2 *out) { *out = 0.5 + in;} // expected-error {{scalar operand type has greater rank than the type of the vector element. ('double' and 'float2' (vector of 2 'float' values))}}
11 kernel void foo3(float2 in, global float2 *out) { *out = 0.5f + in;}
13 kernel void foo4(long2 in, global long2 *out) { *out = 5 + in;}
15 kernel void foo5(float2 in, global float2 *out) {
16 float* f;
17 *out = f + in; // expected-error{{cannot convert between vector and non-scalar values ('__private float *' and 'float2' (vector of 2 'float' values))}}
20 kernel void foo6(int2 in, global int2 *out) {
21 int* f;
22 *out = f + in; // expected-error{{cannot convert between vector and non-scalar values ('__private int *' and 'int2' (vector of 2 'int' values))}}