diff options
author | dim <dim@FreeBSD.org> | 2013-12-22 00:07:40 +0000 |
---|---|---|
committer | dim <dim@FreeBSD.org> | 2013-12-22 00:07:40 +0000 |
commit | 952eddef9aff85b1e92626e89baaf7a360e2ac85 (patch) | |
tree | df8df0b0067b381eab470a3b8f28d14a552a6340 /test/SemaOpenCL | |
parent | ea266cad53e3d49771fa38103913d3ec7a166694 (diff) | |
download | FreeBSD-src-952eddef9aff85b1e92626e89baaf7a360e2ac85.zip FreeBSD-src-952eddef9aff85b1e92626e89baaf7a360e2ac85.tar.gz |
Vendor import of clang release_34 branch r197841 (effectively, 3.4 RC3):
https://llvm.org/svn/llvm-project/cfe/branches/release_34@197841
Diffstat (limited to 'test/SemaOpenCL')
-rw-r--r-- | test/SemaOpenCL/endian-attr.cl | 8 | ||||
-rw-r--r-- | test/SemaOpenCL/event_t.cl | 3 | ||||
-rw-r--r-- | test/SemaOpenCL/invalid-kernel-attrs.cl | 4 | ||||
-rw-r--r-- | test/SemaOpenCL/invalid-kernel-parameters.cl | 132 | ||||
-rw-r--r-- | test/SemaOpenCL/invalid-kernel.cl | 10 | ||||
-rw-r--r-- | test/SemaOpenCL/str_literals.cl | 13 | ||||
-rw-r--r-- | test/SemaOpenCL/vector_inc_dec_ops.cl | 19 |
7 files changed, 178 insertions, 11 deletions
diff --git a/test/SemaOpenCL/endian-attr.cl b/test/SemaOpenCL/endian-attr.cl index e851cdf..f776643 100644 --- a/test/SemaOpenCL/endian-attr.cl +++ b/test/SemaOpenCL/endian-attr.cl @@ -1,9 +1,3 @@ // RUN: %clang_cc1 -verify %s -constant long a __attribute__((endian(host))) = 100; - -constant long b __attribute__((endian(device))) = 100; - -constant long c __attribute__((endian(none))) = 100; // expected-warning {{unknown endian 'none'}} - -void func() __attribute__((endian(host))); // expected-warning {{endian attribute only applies to variables}} +constant long a __attribute__((endian(host))) = 100; // expected-warning {{unknown attribute 'endian' ignored}} diff --git a/test/SemaOpenCL/event_t.cl b/test/SemaOpenCL/event_t.cl index 06197d0..5ab5c10 100644 --- a/test/SemaOpenCL/event_t.cl +++ b/test/SemaOpenCL/event_t.cl @@ -8,10 +8,11 @@ constant struct evt_s { void foo(event_t evt); // expected-note {{passing argument to parameter 'evt' here}} -void kernel ker(event_t argevt) { // expected-error {{the event_t type cannot be used to declare a kernel function argument}} +void kernel ker(event_t argevt) { // expected-error {{'event_t' cannot be used as the type of a kernel parameter}} event_t e; constant event_t const_evt; // expected-error {{the event_t type can only be used with __private address space qualifier}} foo(e); foo(0); foo(5); // expected-error {{passing 'int' to parameter of incompatible type 'event_t'}} } + diff --git a/test/SemaOpenCL/invalid-kernel-attrs.cl b/test/SemaOpenCL/invalid-kernel-attrs.cl index d242eaf..668dc2a 100644 --- a/test/SemaOpenCL/invalid-kernel-attrs.cl +++ b/test/SemaOpenCL/invalid-kernel-attrs.cl @@ -1,6 +1,6 @@ // RUN: %clang_cc1 -verify %s -kernel __attribute__((vec_type_hint)) void kernel1() {} //expected-error{{attribute takes one argument}} +kernel __attribute__((vec_type_hint)) void kernel1() {} //expected-error{{'vec_type_hint' attribute takes one argument}} kernel __attribute__((vec_type_hint(not_type))) void kernel2() {} //expected-error{{unknown type name 'not_type'}} @@ -10,7 +10,7 @@ kernel __attribute__((vec_type_hint(bool))) void kernel4() {} //expected-error{{ kernel __attribute__((vec_type_hint(int))) __attribute__((vec_type_hint(float))) void kernel5() {} //expected-warning{{attribute 'vec_type_hint' is already applied with different parameters}} -kernel __attribute__((work_group_size_hint(8,16,32,4))) void kernel6() {} //expected-error{{attribute requires exactly 3 arguments}} +kernel __attribute__((work_group_size_hint(8,16,32,4))) void kernel6() {} //expected-error{{'work_group_size_hint' attribute requires exactly 3 arguments}} kernel __attribute__((work_group_size_hint(1,2,3))) __attribute__((work_group_size_hint(3,2,1))) void kernel7() {} //expected-warning{{attribute 'work_group_size_hint' is already applied with different parameters}} diff --git a/test/SemaOpenCL/invalid-kernel-parameters.cl b/test/SemaOpenCL/invalid-kernel-parameters.cl new file mode 100644 index 0000000..de32eae --- /dev/null +++ b/test/SemaOpenCL/invalid-kernel-parameters.cl @@ -0,0 +1,132 @@ +// RUN: %clang_cc1 -fsyntax-only -verify %s + +#pragma OPENCL EXTENSION cl_khr_fp16 : enable + + +// Disallowed: parameters with type +// bool, half, size_t, ptrdiff_t, intptr_t, and uintptr_t +// or a struct / union with any of these types in them + +// TODO: Ban int types, size_t, ptrdiff_t ... + +kernel void bool_arg(bool x) { } // expected-error{{'bool' cannot be used as the type of a kernel parameter}} + +kernel void half_arg(half x) { } // expected-error{{'half' cannot be used as the type of a kernel parameter}} + +typedef struct ContainsBool // expected-note{{within field of type 'ContainsBool' declared here}} +{ + bool x; // expected-note{{field of illegal type 'bool' declared here}} +} ContainsBool; + +kernel void bool_in_struct_arg(ContainsBool x) { } // expected-error{{'ContainsBool' (aka 'struct ContainsBool') cannot be used as the type of a kernel parameter}} + + + +typedef struct FooImage2D // expected-note{{within field of type 'FooImage2D' declared here}} +{ + image2d_t imageField; // expected-note{{field of illegal type 'image2d_t' declared here}} +} FooImage2D; + +kernel void image_in_struct_arg(FooImage2D arg) { } // expected-error{{struct kernel parameters may not contain pointers}} + +typedef struct Foo // expected-note{{within field of type 'Foo' declared here}} +{ + int* ptrField; // expected-note{{field of illegal pointer type 'int *' declared here}} +} Foo; + +kernel void pointer_in_struct_arg(Foo arg) { } // expected-error{{struct kernel parameters may not contain pointers}} + +typedef union FooUnion // expected-note{{within field of type 'FooUnion' declared here}} +{ + int* ptrField; // expected-note{{field of illegal pointer type 'int *' declared here}} +} FooUnion; + +kernel void pointer_in_union_arg(FooUnion arg) { }// expected-error{{union kernel parameters may not contain pointers}} + +typedef struct NestedPointer // expected-note 2 {{within field of type 'NestedPointer' declared here}} +{ + int x; + struct InnerNestedPointer + { + int* ptrField; // expected-note 3 {{field of illegal pointer type 'int *' declared here}} + } inner; // expected-note 3 {{within field of type 'struct InnerNestedPointer' declared here}} +} NestedPointer; + +kernel void pointer_in_nested_struct_arg(NestedPointer arg) { }// expected-error{{struct kernel parameters may not contain pointers}} + +struct NestedPointerComplex // expected-note{{within field of type 'NestedPointerComplex' declared here}} +{ + int foo; + float bar; + + struct InnerNestedPointerComplex + { + int innerFoo; + int* innerPtrField; // expected-note{{field of illegal pointer type 'int *' declared here}} + } inner; // expected-note{{within field of type 'struct InnerNestedPointerComplex' declared here}} + + float y; + float z[4]; +}; + +kernel void pointer_in_nested_struct_arg_complex(struct NestedPointerComplex arg) { }// expected-error{{struct kernel parameters may not contain pointers}} + +typedef struct NestedBool // expected-note 2 {{within field of type 'NestedBool' declared here}} +{ + int x; + struct InnerNestedBool + { + bool boolField; // expected-note 2 {{field of illegal type 'bool' declared here}} + } inner; // expected-note 2 {{within field of type 'struct InnerNestedBool' declared here}} +} NestedBool; + +kernel void bool_in_nested_struct_arg(NestedBool arg) { } // expected-error{{'NestedBool' (aka 'struct NestedBool') cannot be used as the type of a kernel parameter}} + +// Warning emitted again for argument used in other kernel +kernel void bool_in_nested_struct_arg_again(NestedBool arg) { } // expected-error{{'NestedBool' (aka 'struct NestedBool') cannot be used as the type of a kernel parameter}} + + +// Check for note with a struct not defined inside the struct +typedef struct NestedBool2Inner +{ + bool boolField; // expected-note{{field of illegal type 'bool' declared here}} +} NestedBool2Inner; + +typedef struct NestedBool2 // expected-note{{within field of type 'NestedBool2' declared here}} +{ + int x; + NestedBool2Inner inner; // expected-note{{within field of type 'NestedBool2Inner' (aka 'struct NestedBool2Inner') declared here}} +} NestedBool2; + +kernel void bool_in_nested_struct_2_arg(NestedBool2 arg) { } // expected-error{{'NestedBool2' (aka 'struct NestedBool2') cannot be used as the type of a kernel parameter}} + + +struct InnerInner +{ + int* foo; + bool x; +}; + +struct Valid +{ + float c; + float d; +}; + +struct Inner +{ + struct Valid v; + struct InnerInner a; + struct Valid g; + struct InnerInner b; +}; + +struct AlsoUser // expected-note{{within field of type 'AlsoUser' declared here}} +{ + float x; + struct Valid valid1; + struct Valid valid2; + struct NestedPointer aaaa; // expected-note{{within field of type 'struct NestedPointer' declared here}} +}; + +kernel void pointer_in_nested_struct_arg_2(struct Valid valid, struct NestedPointer arg, struct AlsoUser also) { } // expected-error 2 {{struct kernel parameters may not contain pointers}} diff --git a/test/SemaOpenCL/invalid-kernel.cl b/test/SemaOpenCL/invalid-kernel.cl index fb8ce58..c12bd84 100644 --- a/test/SemaOpenCL/invalid-kernel.cl +++ b/test/SemaOpenCL/invalid-kernel.cl @@ -1,7 +1,15 @@ // RUN: %clang_cc1 -verify %s -kernel void no_ptrptr(global int **i) { } // expected-error{{kernel argument cannot be declared as a pointer to a pointer}} +kernel void no_ptrptr(global int **i) { } // expected-error{{kernel parameter cannot be declared as a pointer to a pointer}} kernel int bar() { // expected-error {{kernel must have void return type}} return 6; } + +kernel void main() { // expected-error {{kernel cannot be called 'main'}} + +} + +int main() { // expected-error {{function cannot be called 'main'}} + return 0; +} diff --git a/test/SemaOpenCL/str_literals.cl b/test/SemaOpenCL/str_literals.cl new file mode 100644 index 0000000..da665c3 --- /dev/null +++ b/test/SemaOpenCL/str_literals.cl @@ -0,0 +1,13 @@ +// RUN: %clang_cc1 %s -verify +// expected-no-diagnostics + +constant char * __constant x = "hello world"; + +void foo(__constant char * a) { + +} + +void bar() { + foo("hello world"); + foo(x); +} diff --git a/test/SemaOpenCL/vector_inc_dec_ops.cl b/test/SemaOpenCL/vector_inc_dec_ops.cl new file mode 100644 index 0000000..c65bbcb --- /dev/null +++ b/test/SemaOpenCL/vector_inc_dec_ops.cl @@ -0,0 +1,19 @@ +// RUN: %clang_cc1 %s -verify -pedantic -fsyntax-only +// expected-no-diagnostics + +typedef __attribute__((ext_vector_type(2))) char char2; +typedef __attribute__((ext_vector_type(4))) unsigned int uint4; +typedef __attribute__((ext_vector_type(8))) long long8; + +void vectorIncrementDecrementOps() +{ + char2 A = (char2)(1); + uint4 B = (uint4)(1); + long8 C = (long8)(1); + + A++; + --A; + B--; + ++B; + C++; +} |