This revision was automatically updated to reflect the committed changes.
Closed by commit rL281543: [CUDA] Add test checking our ability to take a
function pointer to a… (authored by jlebar).
Changed prior to commit:
https://reviews.llvm.org/D24581?vs=71423&id=71446#toc
Repository:
rL LLVM
https://reviews.llvm.org/D24581
Files:
cfe/trunk/test/SemaCUDA/reference-to-kernel-fn.cu
Index: cfe/trunk/test/SemaCUDA/reference-to-kernel-fn.cu
===================================================================
--- cfe/trunk/test/SemaCUDA/reference-to-kernel-fn.cu
+++ cfe/trunk/test/SemaCUDA/reference-to-kernel-fn.cu
@@ -0,0 +1,31 @@
+// RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify %s
+// RUN: %clang_cc1 -std=c++11 -fcuda-is-device -fsyntax-only -verify -DDEVICE
%s
+
+// Check that we can reference (get a function pointer to) a __global__
+// function from the host side, but not the device side. (We don't yet support
+// device-side kernel launches.)
+
+#include "Inputs/cuda.h"
+
+struct Dummy {};
+
+__global__ void kernel() {}
+// expected-note@-1 {{declared here}}
+#ifdef DEVICE
+// expected-note@-3 {{declared here}}
+#endif
+
+typedef void (*fn_ptr_t)();
+
+__host__ __device__ fn_ptr_t get_ptr_hd() {
+ return kernel;
+#ifdef DEVICE
+ // expected-error@-2 {{reference to __global__ function}}
+#endif
+}
+__host__ fn_ptr_t get_ptr_h() {
+ return kernel;
+}
+__device__ fn_ptr_t get_ptr_d() {
+ return kernel; // expected-error {{reference to __global__ function}}
+}
Index: cfe/trunk/test/SemaCUDA/reference-to-kernel-fn.cu
===================================================================
--- cfe/trunk/test/SemaCUDA/reference-to-kernel-fn.cu
+++ cfe/trunk/test/SemaCUDA/reference-to-kernel-fn.cu
@@ -0,0 +1,31 @@
+// RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify %s
+// RUN: %clang_cc1 -std=c++11 -fcuda-is-device -fsyntax-only -verify -DDEVICE %s
+
+// Check that we can reference (get a function pointer to) a __global__
+// function from the host side, but not the device side. (We don't yet support
+// device-side kernel launches.)
+
+#include "Inputs/cuda.h"
+
+struct Dummy {};
+
+__global__ void kernel() {}
+// expected-note@-1 {{declared here}}
+#ifdef DEVICE
+// expected-note@-3 {{declared here}}
+#endif
+
+typedef void (*fn_ptr_t)();
+
+__host__ __device__ fn_ptr_t get_ptr_hd() {
+ return kernel;
+#ifdef DEVICE
+ // expected-error@-2 {{reference to __global__ function}}
+#endif
+}
+__host__ fn_ptr_t get_ptr_h() {
+ return kernel;
+}
+__device__ fn_ptr_t get_ptr_d() {
+ return kernel; // expected-error {{reference to __global__ function}}
+}
_______________________________________________
cfe-commits mailing list
[email protected]
http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits