From: Yaxun Liu Date: Mon, 19 Sep 2016 17:11:22 +0000 (+0000) Subject: [OpenCL] Allow half type kernel argument when cl_khr_fp16 is enabled X-Git-Tag: llvmorg-4.0.0-rc1~9386 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=042acb2cf7384a011464551ed489a1a539509d66;p=platform%2Fupstream%2Fllvm.git [OpenCL] Allow half type kernel argument when cl_khr_fp16 is enabled llvm-svn: 281915 --- diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp index f7b6765..3eb0062 100644 --- a/clang/lib/Sema/SemaDecl.cpp +++ b/clang/lib/Sema/SemaDecl.cpp @@ -7526,7 +7526,7 @@ enum OpenCLParamType { RecordKernelParam }; -static OpenCLParamType getOpenCLKernelParameterType(QualType PT) { +static OpenCLParamType getOpenCLKernelParameterType(Sema &S, QualType PT) { if (PT->isPointerType()) { QualType PointeeType = PT->getPointeeType(); if (PointeeType->isPointerType()) @@ -7547,7 +7547,10 @@ static OpenCLParamType getOpenCLKernelParameterType(QualType PT) { if (PT->isEventT()) return InvalidKernelParam; - if (PT->isHalfType()) + // OpenCL extension spec v1.2 s9.5: + // This extension adds support for half scalar and vector types as built-in + // types that can be used for arithmetic operations, conversions etc. + if (!S.getOpenCLOptions().cl_khr_fp16 && PT->isHalfType()) return InvalidKernelParam; if (PT->isRecordType()) @@ -7568,7 +7571,7 @@ static void checkIsValidOpenCLKernelParameter( if (ValidTypes.count(PT.getTypePtr())) return; - switch (getOpenCLKernelParameterType(PT)) { + switch (getOpenCLKernelParameterType(S, PT)) { case PtrPtrKernelParam: // OpenCL v1.2 s6.9.a: // A kernel function argument cannot be declared as a @@ -7595,7 +7598,10 @@ static void checkIsValidOpenCLKernelParameter( // OpenCL v1.2 s6.8 n: // A kernel function argument cannot be declared // of event_t type. - S.Diag(Param->getLocation(), diag::err_bad_kernel_param_type) << PT; + // Do not diagnose half type since it is diagnosed as invalid argument + // type for any function elsewhere. + if (!PT->isHalfType()) + S.Diag(Param->getLocation(), diag::err_bad_kernel_param_type) << PT; D.setInvalidType(); return; @@ -7651,7 +7657,7 @@ static void checkIsValidOpenCLKernelParameter( if (ValidTypes.count(QT.getTypePtr())) continue; - OpenCLParamType ParamType = getOpenCLKernelParameterType(QT); + OpenCLParamType ParamType = getOpenCLKernelParameterType(S, QT); if (ParamType == ValidKernelParam) continue; diff --git a/clang/test/SemaOpenCL/half.cl b/clang/test/SemaOpenCL/half.cl index fe88cf1..e8da3a2 100644 --- a/clang/test/SemaOpenCL/half.cl +++ b/clang/test/SemaOpenCL/half.cl @@ -25,6 +25,9 @@ half half_disabled(half *p, // expected-error{{declaring function return value o return h; } +kernel void half_disabled_kernel(global half *p, + half h); // expected-error{{declaring function parameter of type 'half' is not allowed; did you forget * ?}} + // Exactly the same as above but with the cl_khr_fp16 extension enabled. #pragma OPENCL EXTENSION cl_khr_fp16 : enable constant half a = 1.0h; @@ -48,3 +51,7 @@ half half_enabled(half *p, half h) return h; } + +kernel void half_enabled_kernel(global half *p, + half h); + diff --git a/clang/test/SemaOpenCL/invalid-kernel-parameters.cl b/clang/test/SemaOpenCL/invalid-kernel-parameters.cl index e2e48e8..2433c17 100644 --- a/clang/test/SemaOpenCL/invalid-kernel-parameters.cl +++ b/clang/test/SemaOpenCL/invalid-kernel-parameters.cl @@ -1,5 +1,7 @@ // RUN: %clang_cc1 -fsyntax-only -verify %s -triple spir-unknown-unknown +kernel void half_arg(half x) { } // expected-error{{declaring function parameter of type 'half' is not allowed; did you forget * ?}} + #pragma OPENCL EXTENSION cl_khr_fp16 : enable @@ -11,7 +13,8 @@ kernel void bool_arg(bool x) { } // expected-error{{'bool' cannot be used as the type of a kernel parameter}} -kernel void half_arg(half x) { } // expected-error{{'half' cannot be used as the type of a kernel parameter}} +// half kernel argument is allowed when cl_khr_fp16 is enabled. +kernel void half_arg(half x) { } typedef struct ContainsBool // expected-note{{within field of type 'ContainsBool' declared here}} {