[PATCH] D56735: [OpenCL] Fix overloading ranking rules to work correctly for address space coversions
Anastasia Stulova via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Tue Jan 15 11:00:30 PST 2019
Anastasia created this revision.
Anastasia added a reviewer: rjmccall.
Herald added a subscriber: yaxunl.
This bug was pointed out in https://reviews.llvm.org/D55850#inline-496966
https://reviews.llvm.org/D56735
Files:
lib/Sema/SemaOverload.cpp
test/SemaOpenCLCXX/address_space_overloading.cl
Index: test/SemaOpenCLCXX/address_space_overloading.cl
===================================================================
--- /dev/null
+++ test/SemaOpenCLCXX/address_space_overloading.cl
@@ -0,0 +1,14 @@
+// RUN: %clang_cc1 %s -verify -pedantic -fsyntax-only -cl-std=c++
+
+// expected-no-diagnostics
+void foo(const __global int *a);
+void foo(const __generic int *a);
+
+void kernel ker() {
+ __global int *a;
+ __generic int *c;
+ __local int *d;
+ foo(a);
+ foo(c);
+ foo(d);
+}
Index: lib/Sema/SemaOverload.cpp
===================================================================
--- lib/Sema/SemaOverload.cpp
+++ lib/Sema/SemaOverload.cpp
@@ -4019,7 +4019,8 @@
// to unwrap. This essentially mimics what
// IsQualificationConversion does, but here we're checking for a
// strict subset of qualifiers.
- if (T1.getCVRQualifiers() == T2.getCVRQualifiers())
+ if (T1.getCVRQualifiers() == T2.getCVRQualifiers() &&
+ T1.getAddressSpace() == T2.getAddressSpace())
// The qualifiers are the same, so this doesn't tell us anything
// about how the sequences rank.
;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D56735.181822.patch
Type: text/x-patch
Size: 1121 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20190115/cbc7e859/attachment.bin>
More information about the cfe-commits
mailing list