[clang] 6f77029 - [OpenCL] Restrict pointer to member functions.
Anastasia Stulova via cfe-commits
cfe-commits at lists.llvm.org
Tue Jan 5 05:33:28 PST 2021
Author: Anastasia Stulova
Date: 2021-01-05T13:32:18Z
New Revision: 6f770292a000039f265c985623b1550aa50566b0
URL: https://github.com/llvm/llvm-project/commit/6f770292a000039f265c985623b1550aa50566b0
DIFF: https://github.com/llvm/llvm-project/commit/6f770292a000039f265c985623b1550aa50566b0.diff
LOG: [OpenCL] Restrict pointer to member functions.
Pointers to member functions are a special case
of function pointers and therefore have to be
disallowed.
Tags: #clang
Differential Revision: https://reviews.llvm.org/D93958
Added:
clang/test/SemaOpenCLCXX/members.cl
Modified:
clang/lib/Sema/SemaDecl.cpp
Removed:
################################################################################
diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp
index 949df53b40e0..73a6aea4fb7e 100644
--- a/clang/lib/Sema/SemaDecl.cpp
+++ b/clang/lib/Sema/SemaDecl.cpp
@@ -6749,8 +6749,8 @@ static bool diagnoseOpenCLTypes(Scope *S, Sema &Se, Declarator &D,
// OpenCL v1.0 s6.8.a.3: Pointers to functions are not allowed.
QualType NR = R;
- while (NR->isPointerType()) {
- if (NR->isFunctionPointerType()) {
+ while (NR->isPointerType() || NR->isMemberFunctionPointerType()) {
+ if (NR->isFunctionPointerType() || NR->isMemberFunctionPointerType()) {
Se.Diag(D.getIdentifierLoc(), diag::err_opencl_function_pointer);
D.setInvalidType();
return false;
diff --git a/clang/test/SemaOpenCLCXX/members.cl b/clang/test/SemaOpenCLCXX/members.cl
new file mode 100644
index 000000000000..699619ccbe48
--- /dev/null
+++ b/clang/test/SemaOpenCLCXX/members.cl
@@ -0,0 +1,22 @@
+//RUN: %clang_cc1 %s -triple spir -cl-std=clc++ -verify -fsyntax-only
+
+// Check that pointer to member functions are diagnosed
+struct C {
+ void f(int n);
+};
+
+typedef void (C::*p_t)(int);
+
+template <class T> struct remove_reference { typedef T type; };
+template <class T> struct remove_reference<T &> { typedef T type; };
+
+template <typename T>
+void templ_test() {
+ typename remove_reference<T>::type *ptr; //expected-error{{pointers to functions are not allowed}}
+}
+
+void test() {
+ void (C::*p)(int); //expected-error{{pointers to functions are not allowed}}
+ p_t p1; //expected-error{{pointers to functions are not allowed}}
+ templ_test<int (&)()>(); //expected-note{{in instantiation of function template specialization}}
+}
More information about the cfe-commits
mailing list