[PATCH] D51727: [OpenCL] Allow zero assignment and comparisons between queue_t type variables
Sven van Haastregt via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Tue Sep 25 06:04:28 PDT 2018
This revision was automatically updated to reflect the committed changes.
Closed by commit rL342968: [OpenCL] Allow zero assignment and comparisons between queue_t type variables (authored by svenvh, committed by ).
Herald added a subscriber: llvm-commits.
Changed prior to commit:
https://reviews.llvm.org/D51727?vs=164184&id=166860#toc
Repository:
rL LLVM
https://reviews.llvm.org/D51727
Files:
cfe/trunk/lib/Sema/SemaExpr.cpp
cfe/trunk/test/SemaOpenCL/null_queue.cl
Index: cfe/trunk/test/SemaOpenCL/null_queue.cl
===================================================================
--- cfe/trunk/test/SemaOpenCL/null_queue.cl
+++ cfe/trunk/test/SemaOpenCL/null_queue.cl
@@ -1,12 +1,30 @@
// RUN: %clang_cc1 %s -cl-std=CL2.0 -verify -pedantic -fsyntax-only
extern queue_t get_default_queue();
-bool compare() {
- return 1 == get_default_queue() && // expected-error{{invalid operands to binary expression ('int' and 'queue_t')}}
- get_default_queue() == 1; // expected-error{{invalid operands to binary expression ('queue_t' and 'int')}}
-}
+void queue_arg(queue_t); // expected-note {{passing argument to parameter here}}
void init() {
queue_t q1 = 1; // expected-error{{initializing 'queue_t' with an expression of incompatible type 'int'}}
queue_t q = 0;
}
+
+void assign() {
+ queue_t q2, q3;
+ q2 = 5; // expected-error{{assigning to 'queue_t' from incompatible type 'int'}}
+ q3 = 0;
+ q2 = q3 = 0;
+}
+
+bool compare() {
+ queue_t q4, q5;
+ return 1 == get_default_queue() && // expected-error{{invalid operands to binary expression ('int' and 'queue_t')}}
+ get_default_queue() == 1 && // expected-error{{invalid operands to binary expression ('queue_t' and 'int')}}
+ q4 == q5 &&
+ q4 != 0 &&
+ q4 != 0.0f; // expected-error{{invalid operands to binary expression ('queue_t' and 'float')}}
+}
+
+void call() {
+ queue_arg(5); // expected-error {{passing 'int' to parameter of incompatible type 'queue_t'}}
+ queue_arg(0);
+}
Index: cfe/trunk/lib/Sema/SemaExpr.cpp
===================================================================
--- cfe/trunk/lib/Sema/SemaExpr.cpp
+++ cfe/trunk/lib/Sema/SemaExpr.cpp
@@ -8086,6 +8086,13 @@
return Compatible;
}
+ // OpenCL queue_t type assignment.
+ if (LHSType->isQueueT() && RHS.get()->isNullPointerConstant(
+ Context, Expr::NPC_ValueDependentIsNull)) {
+ RHS = ImpCastExprToType(RHS.get(), LHSType, CK_NullToPointer);
+ return Compatible;
+ }
+
// This check seems unnatural, however it is necessary to ensure the proper
// conversion of functions/arrays. If the conversion were done for all
// DeclExpr's (created by ActOnIdExpression), it would mess up the unary
@@ -10423,6 +10430,10 @@
}
if (getLangOpts().OpenCLVersion >= 200) {
+ if (LHSType->isQueueT() && RHSType->isQueueT()) {
+ return computeResultTy();
+ }
+
if (LHSIsNull && RHSType->isQueueT()) {
LHS = ImpCastExprToType(LHS.get(), RHSType, CK_NullToPointer);
return computeResultTy();
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D51727.166860.patch
Type: text/x-patch
Size: 2583 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20180925/117a65b0/attachment.bin>
More information about the cfe-commits
mailing list