diff options
author | Sven van Haastregt <sven.vanhaastregt@arm.com> | 2018-09-25 12:59:34 +0000 |
---|---|---|
committer | Sven van Haastregt <sven.vanhaastregt@arm.com> | 2018-09-25 12:59:34 +0000 |
commit | 0ea28c0e4761c4faa7a96770c013b1969d7a99af (patch) | |
tree | 3351874b66358565798384a720f11af78eb0dde1 | |
parent | 55ad087a4c2ff29ef54f28edeb7b2394046ccbdf (diff) | |
download | bcm5719-llvm-0ea28c0e4761c4faa7a96770c013b1969d7a99af.tar.gz bcm5719-llvm-0ea28c0e4761c4faa7a96770c013b1969d7a99af.zip |
[OpenCL] Allow zero assignment and comparisons between queue_t type variables
This change allows for zero assignment and comparison of queue_t
type variables, and extends null_queue.cl to test this.
Patch by Alistair Davies.
Differential Revision: https://reviews.llvm.org/D51727
llvm-svn: 342968
-rw-r--r-- | clang/lib/Sema/SemaExpr.cpp | 11 | ||||
-rw-r--r-- | clang/test/SemaOpenCL/null_queue.cl | 26 |
2 files changed, 33 insertions, 4 deletions
diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp index 5bf7098dfa2..e89e8a2e68f 100644 --- a/clang/lib/Sema/SemaExpr.cpp +++ b/clang/lib/Sema/SemaExpr.cpp @@ -8086,6 +8086,13 @@ Sema::CheckSingleAssignmentConstraints(QualType LHSType, ExprResult &CallerRHS, 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 @@ QualType Sema::CheckCompareOperands(ExprResult &LHS, ExprResult &RHS, } if (getLangOpts().OpenCLVersion >= 200) { + if (LHSType->isQueueT() && RHSType->isQueueT()) { + return computeResultTy(); + } + if (LHSIsNull && RHSType->isQueueT()) { LHS = ImpCastExprToType(LHS.get(), RHSType, CK_NullToPointer); return computeResultTy(); diff --git a/clang/test/SemaOpenCL/null_queue.cl b/clang/test/SemaOpenCL/null_queue.cl index 518f7138de6..34d1a621f4a 100644 --- a/clang/test/SemaOpenCL/null_queue.cl +++ b/clang/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); +} |