r343207 - [OpenCL] Improve extension-version.cl and to_addr_builtin.cl tests
Sven van Haastregt via cfe-commits
cfe-commits at lists.llvm.org
Thu Sep 27 06:20:29 PDT 2018
Author: svenvh
Date: Thu Sep 27 06:20:29 2018
New Revision: 343207
URL: http://llvm.org/viewvc/llvm-project?rev=343207&view=rev
Log:
[OpenCL] Improve extension-version.cl and to_addr_builtin.cl tests
Add cl_khr_depth_images to extension-version.cl.
Extend to_addr_builtin.cl to additionally test the built-in methods
to_private and to_local, and test assignment with to_global to
incorrect types.
Patch by Alistair Davies.
Differential Revision: https://reviews.llvm.org/D52020
Modified:
cfe/trunk/test/SemaOpenCL/extension-version.cl
cfe/trunk/test/SemaOpenCL/to_addr_builtin.cl
Modified: cfe/trunk/test/SemaOpenCL/extension-version.cl
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaOpenCL/extension-version.cl?rev=343207&r1=343206&r2=343207&view=diff
==============================================================================
--- cfe/trunk/test/SemaOpenCL/extension-version.cl (original)
+++ cfe/trunk/test/SemaOpenCL/extension-version.cl Thu Sep 27 06:20:29 2018
@@ -283,6 +283,18 @@
#pragma OPENCL EXTENSION cl_amd_media_ops2: enable
#if (__OPENCL_C_VERSION__ >= 120)
+#ifndef cl_khr_depth_images
+#error "Missing cl_khr_depth_images define"
+#endif
+#else
+#ifdef cl_khr_depth_images
+#error "Incorrect cl_khr_depth_images define"
+#endif
+// expected-warning at +2{{unsupported OpenCL extension 'cl_khr_depth_images' - ignoring}}
+#endif
+#pragma OPENCL EXTENSION cl_khr_depth_images: enable
+
+#if (__OPENCL_C_VERSION__ >= 120)
#ifndef cl_intel_subgroups
#error "Missing cl_intel_subgroups define"
#endif
Modified: cfe/trunk/test/SemaOpenCL/to_addr_builtin.cl
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaOpenCL/to_addr_builtin.cl?rev=343207&r1=343206&r2=343207&view=diff
==============================================================================
--- cfe/trunk/test/SemaOpenCL/to_addr_builtin.cl (original)
+++ cfe/trunk/test/SemaOpenCL/to_addr_builtin.cl Thu Sep 27 06:20:29 2018
@@ -5,6 +5,8 @@ void test(void) {
global int *glob;
local int *loc;
constant int *con;
+ private int *priv;
+ global float *glob_wrong_ty;
typedef constant int const_int_ty;
const_int_ty *con_typedef;
@@ -46,6 +48,72 @@ void test(void) {
// expected-warning at -5{{passing non-generic address space pointer to to_global may cause dynamic conversion affecting performance}}
#endif
+ loc = to_private(glob);
+#if __OPENCL_C_VERSION__ < CL_VERSION_2_0
+ // expected-error at -2{{implicit declaration of function 'to_private' is invalid in OpenCL}}
+ // expected-warning at -3{{incompatible integer to pointer conversion assigning to '__local int *' from 'int'}}
+#else
+ // expected-error at -5{{assigning 'int *' to '__local int *' changes address space of pointer}}
+ // expected-warning at -6{{passing non-generic address space pointer to to_private may cause dynamic conversion affecting performance}}
+#endif
+
+ loc = to_local(glob);
+#if __OPENCL_C_VERSION__ < CL_VERSION_2_0
+ // expected-error at -2{{implicit declaration of function 'to_local' is invalid in OpenCL}}
+ // expected-warning at -3{{incompatible integer to pointer conversion assigning to '__local int *' from 'int'}}
+ // expected-note at -4{{did you mean 'to_global'}}
+ // expected-note at 13{{'to_global' declared here}}
+#else
+ // expected-warning at -7{{passing non-generic address space pointer to to_local may cause dynamic conversion affecting performance}}
+#endif
+
+ priv = to_global(glob);
+#if __OPENCL_C_VERSION__ < CL_VERSION_2_0
+ // expected-warning at -2{{incompatible integer to pointer conversion assigning to 'int *' from 'int'}}
+#else
+ // expected-error at -4{{assigning '__global int *' to 'int *' changes address space of pointer}}
+ // expected-warning at -5{{passing non-generic address space pointer to to_global may cause dynamic conversion affecting performance}}
+#endif
+
+ priv = to_private(glob);
+#if __OPENCL_C_VERSION__ < CL_VERSION_2_0
+ // expected-warning at -2{{incompatible integer to pointer conversion assigning to 'int *' from 'int'}}
+#else
+ // expected-warning at -4{{passing non-generic address space pointer to to_private may cause dynamic conversion affecting performance}}
+#endif
+
+
+ priv = to_local(glob);
+#if __OPENCL_C_VERSION__ < CL_VERSION_2_0
+ // expected-warning at -2{{incompatible integer to pointer conversion assigning to 'int *' from 'int'}}
+#else
+ // expected-error at -4{{assigning '__local int *' to 'int *' changes address space of pointer}}
+ // expected-warning at -5{{passing non-generic address space pointer to to_local may cause dynamic conversion affecting performance}}
+#endif
+
+ glob = to_global(glob);
+#if __OPENCL_C_VERSION__ < CL_VERSION_2_0
+ // expected-warning at -2{{incompatible integer to pointer conversion assigning to '__global int *' from 'int'}}
+#else
+ // expected-warning at -4{{passing non-generic address space pointer to to_global may cause dynamic conversion affecting performance}}
+#endif
+
+ glob = to_private(glob);
+#if __OPENCL_C_VERSION__ < CL_VERSION_2_0
+ // expected-warning at -2{{incompatible integer to pointer conversion assigning to '__global int *' from 'int'}}
+#else
+ // expected-error at -4{{assigning 'int *' to '__global int *' changes address space of pointer}}
+ // expected-warning at -5{{passing non-generic address space pointer to to_private may cause dynamic conversion affecting performance}}
+#endif
+
+ glob = to_local(glob);
+#if __OPENCL_C_VERSION__ < CL_VERSION_2_0
+ // expected-warning at -2{{incompatible integer to pointer conversion assigning to '__global int *' from 'int'}}
+#else
+ // expected-error at -4{{assigning '__local int *' to '__global int *' changes address space of pointer}}
+ // expected-warning at -5{{passing non-generic address space pointer to to_local may cause dynamic conversion affecting performance}}
+#endif
+
global char *glob_c = to_global(loc);
#if __OPENCL_C_VERSION__ < CL_VERSION_2_0
// expected-warning at -2{{incompatible integer to pointer conversion initializing '__global char *' with an expression of type 'int'}}
@@ -54,4 +122,12 @@ void test(void) {
// expected-warning at -5{{passing non-generic address space pointer to to_global may cause dynamic conversion affecting performance}}
#endif
+ glob_wrong_ty = to_global(glob);
+#if __OPENCL_C_VERSION__ < CL_VERSION_2_0
+ // expected-warning at -2{{incompatible integer to pointer conversion assigning to '__global float *' from 'int'}}
+#else
+ // expected-warning at -4{{incompatible pointer types assigning to '__global float *' from '__global int *'}}
+ // expected-warning at -5{{passing non-generic address space pointer to to_global may cause dynamic conversion affecting performance}}
+#endif
+
}
More information about the cfe-commits
mailing list