//==--- OpenCLBuiltins.td - OpenCL builtin declarations -------------------===// // // The LLVM Compiler Infrastructure // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // This file contains TableGen definitions for OpenCL builtin function // declarations. In case of an unresolved function name in OpenCL, Clang will // check for a function described in this file when -fdeclare-opencl-builtins // is specified. // //===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===// // Definitions of miscellaneous basic entities. //===----------------------------------------------------------------------===// // Versions of OpenCL class Version { int Version = _Version; } def CL10: Version<100>; def CL11: Version<110>; def CL12: Version<120>; def CL20: Version<200>; // Address spaces // Pointer types need to be assigned an address space. class AddressSpace { string AddrSpace = _AS; } def default_as : AddressSpace<"clang::LangAS::Default">; def private_as : AddressSpace<"clang::LangAS::opencl_private">; def global_as : AddressSpace<"clang::LangAS::opencl_global">; def constant_as : AddressSpace<"clang::LangAS::opencl_constant">; def local_as : AddressSpace<"clang::LangAS::opencl_local">; def generic_as : AddressSpace<"clang::LangAS::opencl_generic">; // Qualified Type. Allow to retrieve one ASTContext QualType. class QualType { // Name of the field or function in a clang::ASTContext // E.g. Name="IntTy" for the int type, and "getIntPtrType()" for an intptr_t string Name = _Name; } // Helper class to store type access qualifiers (volatile, const, ...). class Qualifier { string QualName = _QualName; } //===----------------------------------------------------------------------===// // OpenCL C classes for types //===----------------------------------------------------------------------===// // OpenCL types (int, float, ...) class Type { // Name of the Type string Name = _Name; // QualType associated with this type QualType QTName = _QTName; // Size of the vector (if applicable) int VecWidth = 0; // Is pointer bit IsPointer = 0; // List of qualifiers associated with the type (volatile, ...) list QualList = []; // Address space string AddrSpace = "clang::LangAS::Default"; // Access qualifier. Must be one of ("RO", "WO", "RW"). string AccessQualifier = ""; } // OpenCL vector types (e.g. int2, int3, int16, float8, ...) class VectorType : Type<_Ty.Name, _Ty.QTName> { int VecWidth = _VecWidth; } // OpenCL pointer types (e.g. int*, float*, ...) class PointerType : Type<_Ty.Name, _Ty.QTName> { bit IsPointer = 1; string AddrSpace = _AS.AddrSpace; } // OpenCL image types (e.g. image2d_t, ...) class ImageType : Type<_Ty.Name, _QTName> { let AccessQualifier = _AccessQualifier; } //===----------------------------------------------------------------------===// // OpenCL C class for builtin functions //===----------------------------------------------------------------------===// class Builtin _Signature> { // Name of the builtin function string Name = _Name; // List of types used by the function. The first one is the return type and // the following are the arguments. The list must have at least one element // (the return type). list Signature = _Signature; // OpenCL Extension to which the function belongs (cl_khr_subgroups, ...) string Extension = ""; // OpenCL Version to which the function belongs (CL10, ...) Version Version = CL10; } //===----------------------------------------------------------------------===// // Multiclass definitions //===----------------------------------------------------------------------===// // multiclass BifN: Creates Builtin class instances for OpenCL builtin // functions with N arguments. // _Name : Name of the function // _Signature : Signature of the function (list of the Type used by the // function, the first one being the return type). // _IsVector : List of bit indicating if the type in the _Signature at the // same index is to be a vector in the multiple overloads. The // list must have at least one non-zero value. multiclass Bif0 _Signature, list _IsVector> { def : Builtin<_Name, _Signature>; foreach v = [2, 3, 4, 8, 16] in { def : Builtin<_Name, [!if(_IsVector[0], VectorType<_Signature[0], v>, _Signature[0])]>; } } multiclass Bif1 _Signature, list _IsVector> { def : Builtin<_Name, _Signature>; foreach v = [2, 3, 4, 8, 16] in { def : Builtin<_Name, [!if(_IsVector[0], VectorType<_Signature[0], v>, _Signature[0]), !if(_IsVector[1], VectorType<_Signature[1], v>, _Signature[1])]>; } } multiclass Bif2 _Signature, list _IsVector> { def : Builtin<_Name, _Signature>; foreach v = [2, 3, 4, 8, 16] in { def : Builtin<_Name, [!if(_IsVector[0], VectorType<_Signature[0], v>, _Signature[0]), !if(_IsVector[1], VectorType<_Signature[1], v>, _Signature[1]), !if(_IsVector[2], VectorType<_Signature[2], v>, _Signature[2])]>; } } multiclass Bif3 _Signature, list _IsVector> { def : Builtin<_Name, _Signature>; foreach v = [2, 3, 4, 8, 16] in { def : Builtin<_Name, [!if(_IsVector[0], VectorType<_Signature[0], v>, _Signature[0]), !if(_IsVector[1], VectorType<_Signature[1], v>, _Signature[1]), !if(_IsVector[2], VectorType<_Signature[2], v>, _Signature[2]), !if(_IsVector[3], VectorType<_Signature[3], v>, _Signature[3])]>; } } //===----------------------------------------------------------------------===// // Definitions of OpenCL C types //===----------------------------------------------------------------------===// // OpenCL v1.2 s6.1.1: Built-in Scalar Data Types def bool_t : Type<"bool", QualType<"BoolTy">>; def char_t : Type<"char", QualType<"CharTy">>; def uchar_t : Type<"uchar", QualType<"UnsignedCharTy">>; def short_t : Type<"short", QualType<"ShortTy">>; def ushort_t : Type<"ushort", QualType<"UnsignedShortTy">>; def int_t : Type<"int", QualType<"IntTy">>; def uint_t : Type<"uint", QualType<"UnsignedIntTy">>; def long_t : Type<"long", QualType<"LongTy">>; def ulong_t : Type<"ulong", QualType<"UnsignedLongTy">>; def float_t : Type<"float", QualType<"FloatTy">>; def double_t : Type<"double", QualType<"DoubleTy">>; def half_t : Type<"half", QualType<"HalfTy">>; def size_t : Type<"size_t", QualType<"getSizeType()">>; def ptrdiff_t : Type<"ptrdiff_t", QualType<"getPointerDiffType()">>; def intptr_t : Type<"intptr_t", QualType<"getIntPtrType()">>; def uintptr_t : Type<"uintptr_t", QualType<"getUIntPtrType()">>; def void_t : Type<"void", QualType<"VoidTy">>; // OpenCL v1.2 s6.1.2: Built-in Vector Data Types foreach v = [2, 3, 4, 8, 16] in { def char#v#_t : VectorType; def uchar#v#_t : VectorType; def short#v#_t : VectorType; def ushort#v#_t : VectorType; def "int"#v#_t : VectorType; def uint#v#_t : VectorType; def long#v#_t : VectorType; def ulong#v#_t : VectorType; def float#v#_t : VectorType; def double#v#_t : VectorType; def half#v#_t : VectorType; } // OpenCL v1.2 s6.1.3: Other Built-in Data Types // These definitions with a "null" name are "abstract". They should not // be used in definitions of Builtin functions. def image2d_t : Type<"image2d_t", QualType<"null">>; def image3d_t : Type<"image3d_t", QualType<"null">>; def image2d_array_t : Type<"image2d_array_t", QualType<"null">>; def image1d_t : Type<"image1d_t", QualType<"null">>; def image1d_buffer_t : Type<"image1d_buffer_t", QualType<"null">>; def image1d_array_t : Type<"image1d_array_t", QualType<"null">>; // Unlike the few functions above, the following definitions can be used // in definitions of Builtin functions (they have a QualType with a name). foreach v = ["RO", "WO", "RW"] in { def image2d_#v#_t : ImageType, v>; def image3d_#v#_t : ImageType, v>; def image2d_array#v#_t : ImageType, v>; def image1d_#v#_t : ImageType, v>; def image1d_buffer#v#_t : ImageType, v>; def image1d_array#v#_t : ImageType, v>; } def sampler_t : Type<"sampler_t", QualType<"OCLSamplerTy">>; def event_t : Type<"event_t", QualType<"OCLEventTy">>; //===----------------------------------------------------------------------===// // Definitions of OpenCL builtin functions //===----------------------------------------------------------------------===// // OpenCL v1.2 s6.2.3: Explicit Conversions // Generate the convert_ builtins. foreach RType = [float_t, double_t, char_t, uchar_t, short_t, ushort_t, int_t, uint_t, long_t, ulong_t] in { foreach IType = [float_t, double_t, char_t, uchar_t, short_t, ushort_t, int_t, uint_t, long_t, ulong_t] in { foreach sat = ["", "_sat"] in { foreach rte = ["", "_rte", "_rtz", "_rtp", "_rtn"] in { def : Builtin<"convert_" # RType.Name # sat # rte, [RType, IType]>; foreach v = [2, 3, 4, 8, 16] in { def : Builtin<"convert_" # RType.Name # v # sat # rte, [VectorType, VectorType]>; } } } } } // OpenCL v1.2 s6.12.1: Work-Item Functions def get_work_dim : Builtin<"get_work_dim", [uint_t]>; foreach name = ["get_global_size", "get_global_id", "get_local_size", "get_local_id", "get_num_groups", "get_group_id", "get_global_offset"] in { def : Builtin; } // OpenCL v1.2 s6.12.2: Math Functions foreach name = ["acos", "acosh", "acospi", "asin", "asinh", "asinpi", "atan", "atanh", "atanpi"] in { foreach type = [float_t, double_t, half_t] in { defm : Bif1; } } foreach name = ["atan2", "atan2pi"] in { foreach type = [float_t, double_t, half_t] in { defm : Bif2; } } foreach name = ["fmax", "fmin"] in { foreach type = [float_t, double_t, half_t] in { defm : Bif2; defm : Bif2; } } // OpenCL v1.2 s6.12.14: Built-in Image Read Functions def read_imagef : Builtin<"read_imagef", [float4_t, image2d_RO_t, VectorType]>; def write_imagef : Builtin<"write_imagef", [void_t, image2d_WO_t, VectorType, VectorType]>; // OpenCL v2.0 s9.17.3: Additions to section 6.13.1: Work-Item Functions let Version = CL20 in { let Extension = "cl_khr_subgroups" in { def get_sub_group_size : Builtin<"get_sub_group_size", [uint_t]>; def get_max_sub_group_size : Builtin<"get_max_sub_group_size", [uint_t]>; def get_num_sub_groups : Builtin<"get_num_sub_groups", [uint_t]>; } }