// RUN: %clang_cc1 -fsyntax-only -verify %s typedef __fp16 half4 __attribute__ ((vector_size (8))); typedef float float4 __attribute__ ((vector_size (16))); typedef short short4 __attribute__ ((vector_size (8))); typedef int int4 __attribute__ ((vector_size (16))); half4 hv0, hv1; float4 fv0, fv1; short4 sv0; int4 iv0; void testFP16Vec(int c) { hv0 = hv0 + hv1; hv0 = hv0 - hv1; hv0 = hv0 * hv1; hv0 = hv0 / hv1; hv0 = c ? hv0 : hv1; hv0 += hv1; hv0 -= hv1; hv0 *= hv1; hv0 /= hv1; sv0 = hv0 == hv1; sv0 = hv0 != hv1; sv0 = hv0 < hv1; sv0 = hv0 > hv1; sv0 = hv0 <= hv1; sv0 = hv0 >= hv1; sv0 = hv0 || hv1; // expected-error{{logical expression with vector types 'half4' (vector of 4 '__fp16' values) and 'half4' is only supported in C++}} sv0 = hv0 && hv1; // expected-error{{logical expression with vector types 'half4' (vector of 4 '__fp16' values) and 'half4' is only supported in C++}} // Implicit conversion between half vectors and float vectors are not allowed. hv0 = fv0; // expected-error{{assigning to}} fv0 = hv0; // expected-error{{assigning to}} hv0 = (half4)fv0; // expected-error{{invalid conversion between}} fv0 = (float4)hv0; // expected-error{{invalid conversion between}} hv0 = fv0 + fv1; // expected-error{{assigning to}} fv0 = hv0 + hv1; // expected-error{{assigning to}} hv0 = hv0 + fv1; // expected-error{{cannot convert between vector}} hv0 = c ? hv0 : fv1; // expected-error{{cannot convert between vector}} sv0 = hv0 == fv1; // expected-error{{cannot convert between vector}} sv0 = hv0 < fv1; // expected-error{{cannot convert between vector}} sv0 = hv0 || fv1; // expected-error{{cannot convert between vector}} expected-error{{invalid operands to binary expression}} iv0 = hv0 == hv1; // expected-error{{assigning to}} // FIXME: clang currently disallows using these operators on vectors, which is // allowed by gcc. sv0 = !hv0; // expected-error{{invalid argument type}} hv0++; // expected-error{{cannot increment value of type}} ++hv0; // expected-error{{cannot increment value of type}} } |