// RUN: %clang_cc1 %s -pedantic -verify -fsyntax-only
typedef int int2 __attribute__((ext_vector_type(2)));
typedef int int3 __attribute__((ext_vector_type(3)));
typedef int int4 __attribute__((ext_vector_type(4)));
struct X {};
__global int g = 0;
__global int *__global g_ptr = &g;
kernel void foo() {
// Testing conversions between vectors and vectors/scalars
long l1;
auto l_to_i2 = reinterpret_cast<int2>(l1);
int2 i2;
auto i2_to_l = reinterpret_cast<long>(i2);
auto i2_to_i = reinterpret_cast<int>(i2); // expected-error{{reinterpret_cast from vector 'int2' (vector of 2 'int' values) to scalar 'int' of different size}}
auto i2_to_i2 = reinterpret_cast<int2>(i2);
// Testing reinterpret_cast with address spaces.
__private short s;
auto s2 = reinterpret_cast<__private short>(s);
auto s3 = reinterpret_cast<decltype(s)>(s);
auto s4 = reinterpret_cast<__global short>(s);
__private X x;
auto x2 = reinterpret_cast<__private X>(x); // expected-error{{reinterpret_cast from '__private X' to '__private X' is not allowed}}
auto ptr = reinterpret_cast<__global int* __private>(g_ptr);
(void)reinterpret_cast<__private int* __private>(g_ptr); // expected-error{{reinterpret_cast from '__global int *' to '__private int *' is not allowed}}
// Only integral types (and pointer/references) can be reinterpret casted to themselves.
// Currently this does not include any opencl types.
reserve_id_t r_id1;
auto r_id2 = reinterpret_cast<reserve_id_t>(r_id1); // expected-error{{reinterpret_cast from 'reserve_id_t' to 'reserve_id_t' is not allowed}}
}