17330f729Sjoerg//==--- OpenCLBuiltins.td - OpenCL builtin declarations -------------------===// 27330f729Sjoerg// 37330f729Sjoerg// The LLVM Compiler Infrastructure 47330f729Sjoerg// 57330f729Sjoerg// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 67330f729Sjoerg// See https://llvm.org/LICENSE.txt for license information. 77330f729Sjoerg// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 87330f729Sjoerg// 97330f729Sjoerg//===----------------------------------------------------------------------===// 107330f729Sjoerg// 117330f729Sjoerg// This file contains TableGen definitions for OpenCL builtin function 127330f729Sjoerg// declarations. In case of an unresolved function name in OpenCL, Clang will 137330f729Sjoerg// check for a function described in this file when -fdeclare-opencl-builtins 147330f729Sjoerg// is specified. 157330f729Sjoerg// 167330f729Sjoerg//===----------------------------------------------------------------------===// 177330f729Sjoerg 187330f729Sjoerg//===----------------------------------------------------------------------===// 197330f729Sjoerg// Definitions of miscellaneous basic entities. 207330f729Sjoerg//===----------------------------------------------------------------------===// 217330f729Sjoerg// Versions of OpenCL 227330f729Sjoergclass Version<int _Version> { 237330f729Sjoerg int ID = _Version; 247330f729Sjoerg} 257330f729Sjoergdef CLAll : Version< 0>; 267330f729Sjoergdef CL10 : Version<100>; 277330f729Sjoergdef CL11 : Version<110>; 287330f729Sjoergdef CL12 : Version<120>; 297330f729Sjoergdef CL20 : Version<200>; 307330f729Sjoerg 317330f729Sjoerg// Address spaces 327330f729Sjoerg// Pointer types need to be assigned an address space. 337330f729Sjoergclass AddressSpace<string _AS> { 347330f729Sjoerg string Name = _AS; 357330f729Sjoerg} 367330f729Sjoergdef DefaultAS : AddressSpace<"clang::LangAS::Default">; 377330f729Sjoergdef PrivateAS : AddressSpace<"clang::LangAS::opencl_private">; 387330f729Sjoergdef GlobalAS : AddressSpace<"clang::LangAS::opencl_global">; 397330f729Sjoergdef ConstantAS : AddressSpace<"clang::LangAS::opencl_constant">; 407330f729Sjoergdef LocalAS : AddressSpace<"clang::LangAS::opencl_local">; 417330f729Sjoergdef GenericAS : AddressSpace<"clang::LangAS::opencl_generic">; 427330f729Sjoerg 43*e038c9c4Sjoerg// OpenCL language extension. 44*e038c9c4Sjoergclass AbstractExtension<string _Ext> { 45*e038c9c4Sjoerg // One or more OpenCL extensions, space separated. Each extension must be 46*e038c9c4Sjoerg // a valid extension name for the opencl extension pragma. 47*e038c9c4Sjoerg string ExtName = _Ext; 48*e038c9c4Sjoerg} 49*e038c9c4Sjoerg 50*e038c9c4Sjoerg// Extension associated to a builtin function. 51*e038c9c4Sjoergclass FunctionExtension<string _Ext> : AbstractExtension<_Ext>; 52*e038c9c4Sjoerg 53*e038c9c4Sjoerg// Extension associated to a type. This enables implicit conditionalization of 54*e038c9c4Sjoerg// builtin function overloads containing a type that depends on an extension. 55*e038c9c4Sjoerg// During overload resolution, when a builtin function overload contains a type 56*e038c9c4Sjoerg// with a TypeExtension, those overloads are skipped when the extension is 57*e038c9c4Sjoerg// disabled. 58*e038c9c4Sjoergclass TypeExtension<string _Ext> : AbstractExtension<_Ext>; 59*e038c9c4Sjoerg 60*e038c9c4Sjoerg// TypeExtension definitions. 61*e038c9c4Sjoergdef NoTypeExt : TypeExtension<"">; 62*e038c9c4Sjoergdef Fp16TypeExt : TypeExtension<"cl_khr_fp16">; 63*e038c9c4Sjoergdef Fp64TypeExt : TypeExtension<"cl_khr_fp64">; 64*e038c9c4Sjoerg 65*e038c9c4Sjoerg// FunctionExtension definitions. 66*e038c9c4Sjoergdef FuncExtNone : FunctionExtension<"">; 67*e038c9c4Sjoergdef FuncExtKhrSubgroups : FunctionExtension<"cl_khr_subgroups">; 68*e038c9c4Sjoergdef FuncExtKhrSubgroupExtendedTypes : FunctionExtension<"cl_khr_subgroup_extended_types">; 69*e038c9c4Sjoergdef FuncExtKhrSubgroupNonUniformVote : FunctionExtension<"cl_khr_subgroup_non_uniform_vote">; 70*e038c9c4Sjoergdef FuncExtKhrSubgroupBallot : FunctionExtension<"cl_khr_subgroup_ballot">; 71*e038c9c4Sjoergdef FuncExtKhrSubgroupNonUniformArithmetic: FunctionExtension<"cl_khr_subgroup_non_uniform_arithmetic">; 72*e038c9c4Sjoergdef FuncExtKhrSubgroupShuffle : FunctionExtension<"cl_khr_subgroup_shuffle">; 73*e038c9c4Sjoergdef FuncExtKhrSubgroupShuffleRelative : FunctionExtension<"cl_khr_subgroup_shuffle_relative">; 74*e038c9c4Sjoergdef FuncExtKhrSubgroupClusteredReduce : FunctionExtension<"cl_khr_subgroup_clustered_reduce">; 75*e038c9c4Sjoergdef FuncExtKhrGlobalInt32BaseAtomics : FunctionExtension<"cl_khr_global_int32_base_atomics">; 76*e038c9c4Sjoergdef FuncExtKhrGlobalInt32ExtendedAtomics : FunctionExtension<"cl_khr_global_int32_extended_atomics">; 77*e038c9c4Sjoergdef FuncExtKhrLocalInt32BaseAtomics : FunctionExtension<"cl_khr_local_int32_base_atomics">; 78*e038c9c4Sjoergdef FuncExtKhrLocalInt32ExtendedAtomics : FunctionExtension<"cl_khr_local_int32_extended_atomics">; 79*e038c9c4Sjoergdef FuncExtKhrInt64BaseAtomics : FunctionExtension<"cl_khr_int64_base_atomics">; 80*e038c9c4Sjoergdef FuncExtKhrInt64ExtendedAtomics : FunctionExtension<"cl_khr_int64_extended_atomics">; 81*e038c9c4Sjoergdef FuncExtKhrMipmapImage : FunctionExtension<"cl_khr_mipmap_image">; 82*e038c9c4Sjoergdef FuncExtKhrMipmapImageWrites : FunctionExtension<"cl_khr_mipmap_image_writes">; 83*e038c9c4Sjoergdef FuncExtKhrGlMsaaSharing : FunctionExtension<"cl_khr_gl_msaa_sharing">; 84*e038c9c4Sjoerg 85*e038c9c4Sjoerg// Not a real extension, but a workaround to add C++ for OpenCL specific builtins. 86*e038c9c4Sjoergdef FuncExtOpenCLCxx : FunctionExtension<"__cplusplus">; 87*e038c9c4Sjoerg 88*e038c9c4Sjoerg// Multiple extensions 89*e038c9c4Sjoergdef FuncExtKhrMipmapWritesAndWrite3d : FunctionExtension<"cl_khr_mipmap_image_writes cl_khr_3d_image_writes">; 90*e038c9c4Sjoerg 91*e038c9c4Sjoerg// Arm extensions. 92*e038c9c4Sjoergdef ArmIntegerDotProductInt8 : FunctionExtension<"cl_arm_integer_dot_product_int8">; 93*e038c9c4Sjoergdef ArmIntegerDotProductAccumulateInt8 : FunctionExtension<"cl_arm_integer_dot_product_accumulate_int8">; 94*e038c9c4Sjoergdef ArmIntegerDotProductAccumulateInt16 : FunctionExtension<"cl_arm_integer_dot_product_accumulate_int16">; 95*e038c9c4Sjoergdef ArmIntegerDotProductAccumulateSaturateInt8 : FunctionExtension<"cl_arm_integer_dot_product_accumulate_saturate_int8">; 967330f729Sjoerg 977330f729Sjoerg// Qualified Type. These map to ASTContext::QualType. 98*e038c9c4Sjoergclass QualType<string _TypeExpr, bit _IsAbstract=0> { 99*e038c9c4Sjoerg // Expression to obtain the QualType inside OCL2Qual. 100*e038c9c4Sjoerg // E.g. TypeExpr="Context.IntTy" for the int type. 101*e038c9c4Sjoerg string TypeExpr = _TypeExpr; 1027330f729Sjoerg // Some QualTypes in this file represent an abstract type for which there is 1037330f729Sjoerg // no corresponding AST QualType, e.g. a GenType or an `image2d_t` type 1047330f729Sjoerg // without access qualifiers. 1057330f729Sjoerg bit IsAbstract = _IsAbstract; 1067330f729Sjoerg} 1077330f729Sjoerg 1087330f729Sjoerg// List of integers. 1097330f729Sjoergclass IntList<string _Name, list<int> _List> { 1107330f729Sjoerg string Name = _Name; 1117330f729Sjoerg list<int> List = _List; 1127330f729Sjoerg} 1137330f729Sjoerg 1147330f729Sjoerg//===----------------------------------------------------------------------===// 1157330f729Sjoerg// OpenCL C classes for types 1167330f729Sjoerg//===----------------------------------------------------------------------===// 1177330f729Sjoerg// OpenCL C basic data types (int, float, image2d_t, ...). 1187330f729Sjoerg// Its child classes can represent concrete types (e.g. VectorType) or 1197330f729Sjoerg// abstract types (e.g. GenType). 120*e038c9c4Sjoergclass Type<string _Name, QualType _QTExpr> { 1217330f729Sjoerg // Name of the Type. 1227330f729Sjoerg string Name = _Name; 1237330f729Sjoerg // QualType associated with this type. 124*e038c9c4Sjoerg QualType QTExpr = _QTExpr; 1257330f729Sjoerg // Size of the vector (if applicable). 1267330f729Sjoerg int VecWidth = 1; 1277330f729Sjoerg // Is a pointer. 1287330f729Sjoerg bit IsPointer = 0; 1297330f729Sjoerg // "const" qualifier. 1307330f729Sjoerg bit IsConst = 0; 1317330f729Sjoerg // "volatile" qualifier. 1327330f729Sjoerg bit IsVolatile = 0; 1337330f729Sjoerg // Access qualifier. Must be one of ("RO", "WO", "RW"). 1347330f729Sjoerg string AccessQualifier = ""; 1357330f729Sjoerg // Address space. 1367330f729Sjoerg string AddrSpace = DefaultAS.Name; 137*e038c9c4Sjoerg // Extension that needs to be enabled to expose a builtin that uses this type. 138*e038c9c4Sjoerg TypeExtension Extension = NoTypeExt; 1397330f729Sjoerg} 1407330f729Sjoerg 1417330f729Sjoerg// OpenCL vector types (e.g. int2, int3, int16, float8, ...). 142*e038c9c4Sjoergclass VectorType<Type _Ty, int _VecWidth> : Type<_Ty.Name, _Ty.QTExpr> { 1437330f729Sjoerg let VecWidth = _VecWidth; 1447330f729Sjoerg let AccessQualifier = ""; 1457330f729Sjoerg // Inherited fields 1467330f729Sjoerg let IsPointer = _Ty.IsPointer; 1477330f729Sjoerg let IsConst = _Ty.IsConst; 1487330f729Sjoerg let IsVolatile = _Ty.IsVolatile; 1497330f729Sjoerg let AddrSpace = _Ty.AddrSpace; 150*e038c9c4Sjoerg let Extension = _Ty.Extension; 1517330f729Sjoerg} 1527330f729Sjoerg 1537330f729Sjoerg// OpenCL pointer types (e.g. int*, float*, ...). 1547330f729Sjoergclass PointerType<Type _Ty, AddressSpace _AS = DefaultAS> : 155*e038c9c4Sjoerg Type<_Ty.Name, _Ty.QTExpr> { 1567330f729Sjoerg let AddrSpace = _AS.Name; 1577330f729Sjoerg // Inherited fields 1587330f729Sjoerg let VecWidth = _Ty.VecWidth; 1597330f729Sjoerg let IsPointer = 1; 1607330f729Sjoerg let IsConst = _Ty.IsConst; 1617330f729Sjoerg let IsVolatile = _Ty.IsVolatile; 1627330f729Sjoerg let AccessQualifier = _Ty.AccessQualifier; 163*e038c9c4Sjoerg let Extension = _Ty.Extension; 1647330f729Sjoerg} 1657330f729Sjoerg 1667330f729Sjoerg// OpenCL const types (e.g. const int). 167*e038c9c4Sjoergclass ConstType<Type _Ty> : Type<_Ty.Name, _Ty.QTExpr> { 1687330f729Sjoerg let IsConst = 1; 1697330f729Sjoerg // Inherited fields 1707330f729Sjoerg let VecWidth = _Ty.VecWidth; 1717330f729Sjoerg let IsPointer = _Ty.IsPointer; 1727330f729Sjoerg let IsVolatile = _Ty.IsVolatile; 1737330f729Sjoerg let AccessQualifier = _Ty.AccessQualifier; 1747330f729Sjoerg let AddrSpace = _Ty.AddrSpace; 175*e038c9c4Sjoerg let Extension = _Ty.Extension; 1767330f729Sjoerg} 1777330f729Sjoerg 1787330f729Sjoerg// OpenCL volatile types (e.g. volatile int). 179*e038c9c4Sjoergclass VolatileType<Type _Ty> : Type<_Ty.Name, _Ty.QTExpr> { 1807330f729Sjoerg let IsVolatile = 1; 1817330f729Sjoerg // Inherited fields 1827330f729Sjoerg let VecWidth = _Ty.VecWidth; 1837330f729Sjoerg let IsPointer = _Ty.IsPointer; 1847330f729Sjoerg let IsConst = _Ty.IsConst; 1857330f729Sjoerg let AccessQualifier = _Ty.AccessQualifier; 1867330f729Sjoerg let AddrSpace = _Ty.AddrSpace; 187*e038c9c4Sjoerg let Extension = _Ty.Extension; 1887330f729Sjoerg} 1897330f729Sjoerg 1907330f729Sjoerg// OpenCL image types (e.g. image2d). 1917330f729Sjoergclass ImageType<Type _Ty, string _AccessQualifier> : 192*e038c9c4Sjoerg Type<_Ty.Name, QualType<_Ty.QTExpr.TypeExpr # _AccessQualifier # "Ty", 0>> { 1937330f729Sjoerg let VecWidth = 0; 1947330f729Sjoerg let AccessQualifier = _AccessQualifier; 1957330f729Sjoerg // Inherited fields 1967330f729Sjoerg let IsPointer = _Ty.IsPointer; 1977330f729Sjoerg let IsConst = _Ty.IsConst; 1987330f729Sjoerg let IsVolatile = _Ty.IsVolatile; 1997330f729Sjoerg let AddrSpace = _Ty.AddrSpace; 200*e038c9c4Sjoerg let Extension = _Ty.Extension; 201*e038c9c4Sjoerg} 202*e038c9c4Sjoerg 203*e038c9c4Sjoerg// OpenCL enum type (e.g. memory_scope). 204*e038c9c4Sjoergclass EnumType<string _Name> : 205*e038c9c4Sjoerg Type<_Name, QualType<"getOpenCLEnumType(S, \"" # _Name # "\")", 0>> { 206*e038c9c4Sjoerg} 207*e038c9c4Sjoerg 208*e038c9c4Sjoerg// OpenCL typedef type (e.g. cl_mem_fence_flags). 209*e038c9c4Sjoergclass TypedefType<string _Name> : 210*e038c9c4Sjoerg Type<_Name, QualType<"getOpenCLTypedefType(S, \"" # _Name # "\")", 0>> { 2117330f729Sjoerg} 2127330f729Sjoerg 2137330f729Sjoerg// List of Types. 214*e038c9c4Sjoergclass TypeList<list<Type> _Type> { 2157330f729Sjoerg list<Type> List = _Type; 2167330f729Sjoerg} 2177330f729Sjoerg 2187330f729Sjoerg// A GenericType is an abstract type that defines a set of types as a 2197330f729Sjoerg// combination of Types and vector sizes. 2207330f729Sjoerg// 2217330f729Sjoerg// For example, if TypeList = <int, float> and VectorList = <1, 2, 4>, then it 2227330f729Sjoerg// represents <int, int2, int4, float, float2, float4>. 2237330f729Sjoerg// 2247330f729Sjoerg// Some rules apply when using multiple GenericType arguments in a declaration: 2257330f729Sjoerg// 1. The number of vector sizes must be equal or 1 for all gentypes in a 2267330f729Sjoerg// declaration. 2277330f729Sjoerg// 2. The number of Types must be equal or 1 for all gentypes in a 2287330f729Sjoerg// declaration. 2297330f729Sjoerg// 3. Generic types are combined by iterating over all generic types at once. 2307330f729Sjoerg// For example, for the following GenericTypes 2317330f729Sjoerg// GenT1 = GenericType<half, [1, 2]> and 2327330f729Sjoerg// GenT2 = GenericType<float, int, [1, 2]> 2337330f729Sjoerg// A declaration f(GenT1, GenT2) results in the combinations 2347330f729Sjoerg// f(half, float), f(half2, float2), f(half, int), f(half2, int2) . 2357330f729Sjoerg// 4. "sgentype" from the OpenCL specification is supported by specifying 2367330f729Sjoerg// a single vector size. 2377330f729Sjoerg// For example, for the following GenericTypes 2387330f729Sjoerg// GenT = GenericType<half, int, [1, 2]> and 2397330f729Sjoerg// SGenT = GenericType<half, int, [1]> 2407330f729Sjoerg// A declaration f(GenT, SGenT) results in the combinations 2417330f729Sjoerg// f(half, half), f(half2, half), f(int, int), f(int2, int) . 2427330f729Sjoergclass GenericType<string _Ty, TypeList _TypeList, IntList _VectorList> : 2437330f729Sjoerg Type<_Ty, QualType<"null", 1>> { 2447330f729Sjoerg // Possible element types of the generic type. 2457330f729Sjoerg TypeList TypeList = _TypeList; 2467330f729Sjoerg // Possible vector sizes of the types in the TypeList. 2477330f729Sjoerg IntList VectorList = _VectorList; 2487330f729Sjoerg // The VecWidth field is ignored for GenericTypes. Use VectorList instead. 2497330f729Sjoerg let VecWidth = 0; 2507330f729Sjoerg} 2517330f729Sjoerg 252*e038c9c4Sjoerg// Builtin function attributes. 253*e038c9c4Sjoergdef Attr { 254*e038c9c4Sjoerg list<bit> None = [0, 0, 0]; 255*e038c9c4Sjoerg list<bit> Pure = [1, 0, 0]; 256*e038c9c4Sjoerg list<bit> Const = [0, 1, 0]; 257*e038c9c4Sjoerg list<bit> Convergent = [0, 0, 1]; 258*e038c9c4Sjoerg} 259*e038c9c4Sjoerg 2607330f729Sjoerg//===----------------------------------------------------------------------===// 2617330f729Sjoerg// OpenCL C class for builtin functions 2627330f729Sjoerg//===----------------------------------------------------------------------===// 263*e038c9c4Sjoergclass Builtin<string _Name, list<Type> _Signature, list<bit> _Attributes = Attr.None> { 2647330f729Sjoerg // Name of the builtin function 2657330f729Sjoerg string Name = _Name; 2667330f729Sjoerg // List of types used by the function. The first one is the return type and 2677330f729Sjoerg // the following are the arguments. The list must have at least one element 2687330f729Sjoerg // (the return type). 2697330f729Sjoerg list<Type> Signature = _Signature; 270*e038c9c4Sjoerg // Function attribute __attribute__((pure)) 271*e038c9c4Sjoerg bit IsPure = _Attributes[0]; 272*e038c9c4Sjoerg // Function attribute __attribute__((const)) 273*e038c9c4Sjoerg bit IsConst = _Attributes[1]; 274*e038c9c4Sjoerg // Function attribute __attribute__((convergent)) 275*e038c9c4Sjoerg bit IsConv = _Attributes[2]; 276*e038c9c4Sjoerg // OpenCL extensions to which the function belongs. 277*e038c9c4Sjoerg FunctionExtension Extension = FuncExtNone; 2787330f729Sjoerg // Version of OpenCL from which the function is available (e.g.: CL10). 2797330f729Sjoerg // MinVersion is inclusive. 2807330f729Sjoerg Version MinVersion = CL10; 2817330f729Sjoerg // Version of OpenCL from which the function is not supported anymore. 2827330f729Sjoerg // MaxVersion is exclusive. 2837330f729Sjoerg // CLAll makes the function available for all versions. 2847330f729Sjoerg Version MaxVersion = CLAll; 2857330f729Sjoerg} 2867330f729Sjoerg 2877330f729Sjoerg//===----------------------------------------------------------------------===// 2887330f729Sjoerg// Definitions of OpenCL C types 2897330f729Sjoerg//===----------------------------------------------------------------------===// 2907330f729Sjoerg 2917330f729Sjoerg// OpenCL v1.0/1.2/2.0 s6.1.1: Built-in Scalar Data Types. 292*e038c9c4Sjoergdef Bool : Type<"bool", QualType<"Context.BoolTy">>; 293*e038c9c4Sjoergdef Char : Type<"char", QualType<"Context.CharTy">>; 294*e038c9c4Sjoergdef UChar : Type<"uchar", QualType<"Context.UnsignedCharTy">>; 295*e038c9c4Sjoergdef Short : Type<"short", QualType<"Context.ShortTy">>; 296*e038c9c4Sjoergdef UShort : Type<"ushort", QualType<"Context.UnsignedShortTy">>; 297*e038c9c4Sjoergdef Int : Type<"int", QualType<"Context.IntTy">>; 298*e038c9c4Sjoergdef UInt : Type<"uint", QualType<"Context.UnsignedIntTy">>; 299*e038c9c4Sjoergdef Long : Type<"long", QualType<"Context.LongTy">>; 300*e038c9c4Sjoergdef ULong : Type<"ulong", QualType<"Context.UnsignedLongTy">>; 301*e038c9c4Sjoergdef Float : Type<"float", QualType<"Context.FloatTy">>; 302*e038c9c4Sjoerglet Extension = Fp64TypeExt in { 303*e038c9c4Sjoerg def Double : Type<"double", QualType<"Context.DoubleTy">>; 304*e038c9c4Sjoerg} 305*e038c9c4Sjoerglet Extension = Fp16TypeExt in { 306*e038c9c4Sjoerg def Half : Type<"half", QualType<"Context.HalfTy">>; 307*e038c9c4Sjoerg} 308*e038c9c4Sjoergdef Size : Type<"size_t", QualType<"Context.getSizeType()">>; 309*e038c9c4Sjoergdef PtrDiff : Type<"ptrdiff_t", QualType<"Context.getPointerDiffType()">>; 310*e038c9c4Sjoergdef IntPtr : Type<"intptr_t", QualType<"Context.getIntPtrType()">>; 311*e038c9c4Sjoergdef UIntPtr : Type<"uintptr_t", QualType<"Context.getUIntPtrType()">>; 312*e038c9c4Sjoergdef Void : Type<"void", QualType<"Context.VoidTy">>; 3137330f729Sjoerg 3147330f729Sjoerg// OpenCL v1.0/1.2/2.0 s6.1.2: Built-in Vector Data Types. 3157330f729Sjoerg// Built-in vector data types are created by TableGen's OpenCLBuiltinEmitter. 3167330f729Sjoerg 3177330f729Sjoerg// OpenCL v1.0/1.2/2.0 s6.1.3: Other Built-in Data Types. 3187330f729Sjoerg// The image definitions are "abstract". They should not be used without 3197330f729Sjoerg// specifying an access qualifier (RO/WO/RW). 320*e038c9c4Sjoergdef Image1d : Type<"image1d_t", QualType<"Context.OCLImage1d", 1>>; 321*e038c9c4Sjoergdef Image2d : Type<"image2d_t", QualType<"Context.OCLImage2d", 1>>; 322*e038c9c4Sjoergdef Image3d : Type<"image3d_t", QualType<"Context.OCLImage3d", 1>>; 323*e038c9c4Sjoergdef Image1dArray : Type<"image1d_array_t", QualType<"Context.OCLImage1dArray", 1>>; 324*e038c9c4Sjoergdef Image1dBuffer : Type<"image1d_buffer_t", QualType<"Context.OCLImage1dBuffer", 1>>; 325*e038c9c4Sjoergdef Image2dArray : Type<"image2d_array_t", QualType<"Context.OCLImage2dArray", 1>>; 326*e038c9c4Sjoergdef Image2dDepth : Type<"image2d_depth_t", QualType<"Context.OCLImage2dDepth", 1>>; 327*e038c9c4Sjoergdef Image2dArrayDepth : Type<"image2d_array_depth_t", QualType<"Context.OCLImage2dArrayDepth", 1>>; 328*e038c9c4Sjoergdef Image2dMsaa : Type<"image2d_msaa_t", QualType<"Context.OCLImage2dMSAA", 1>>; 329*e038c9c4Sjoergdef Image2dArrayMsaa : Type<"image2d_array_msaa_t", QualType<"Context.OCLImage2dArrayMSAA", 1>>; 330*e038c9c4Sjoergdef Image2dMsaaDepth : Type<"image2d_msaa_depth_t", QualType<"Context.OCLImage2dMSAADepth", 1>>; 331*e038c9c4Sjoergdef Image2dArrayMsaaDepth : Type<"image2d_array_msaa_depth_t", QualType<"Context.OCLImage2dArrayMSAADepth", 1>>; 3327330f729Sjoerg 333*e038c9c4Sjoergdef Sampler : Type<"sampler_t", QualType<"Context.OCLSamplerTy">>; 334*e038c9c4Sjoergdef ClkEvent : Type<"clk_event_t", QualType<"Context.OCLClkEventTy">>; 335*e038c9c4Sjoergdef Event : Type<"event_t", QualType<"Context.OCLEventTy">>; 336*e038c9c4Sjoergdef Queue : Type<"queue_t", QualType<"Context.OCLQueueTy">>; 337*e038c9c4Sjoergdef ReserveId : Type<"reserve_id_t", QualType<"Context.OCLReserveIDTy">>; 338*e038c9c4Sjoergdef MemFenceFlags : TypedefType<"cl_mem_fence_flags">; 339*e038c9c4Sjoergdef ClkProfilingInfo : TypedefType<"clk_profiling_info">; 340*e038c9c4Sjoergdef NDRange : TypedefType<"ndrange_t">; 341*e038c9c4Sjoerg 342*e038c9c4Sjoerg// OpenCL v2.0 s6.13.11: Atomic integer and floating-point types. 343*e038c9c4Sjoergdef AtomicInt : Type<"atomic_int", QualType<"Context.getAtomicType(Context.IntTy)">>; 344*e038c9c4Sjoergdef AtomicUInt : Type<"atomic_uint", QualType<"Context.getAtomicType(Context.UnsignedIntTy)">>; 345*e038c9c4Sjoergdef AtomicLong : Type<"atomic_long", QualType<"Context.getAtomicType(Context.LongTy)">>; 346*e038c9c4Sjoergdef AtomicULong : Type<"atomic_ulong", QualType<"Context.getAtomicType(Context.UnsignedLongTy)">>; 347*e038c9c4Sjoergdef AtomicFloat : Type<"atomic_float", QualType<"Context.getAtomicType(Context.FloatTy)">>; 348*e038c9c4Sjoergdef AtomicDouble : Type<"atomic_double", QualType<"Context.getAtomicType(Context.DoubleTy)">>; 349*e038c9c4Sjoergdef AtomicIntPtr : Type<"atomic_intptr_t", QualType<"Context.getAtomicType(Context.getIntPtrType())">>; 350*e038c9c4Sjoergdef AtomicUIntPtr : Type<"atomic_uintptr_t", QualType<"Context.getAtomicType(Context.getUIntPtrType())">>; 351*e038c9c4Sjoergdef AtomicSize : Type<"atomic_size_t", QualType<"Context.getAtomicType(Context.getSizeType())">>; 352*e038c9c4Sjoergdef AtomicPtrDiff : Type<"atomic_ptrdiff_t", QualType<"Context.getAtomicType(Context.getPointerDiffType())">>; 353*e038c9c4Sjoerg 354*e038c9c4Sjoergdef AtomicFlag : TypedefType<"atomic_flag">; 355*e038c9c4Sjoergdef MemoryOrder : EnumType<"memory_order">; 356*e038c9c4Sjoergdef MemoryScope : EnumType<"memory_scope">; 3577330f729Sjoerg 3587330f729Sjoerg//===----------------------------------------------------------------------===// 3597330f729Sjoerg// Definitions of OpenCL gentype variants 3607330f729Sjoerg//===----------------------------------------------------------------------===// 3617330f729Sjoerg// The OpenCL specification often uses "gentype" in builtin function 3627330f729Sjoerg// declarations to indicate that a builtin function is available with various 3637330f729Sjoerg// argument and return types. The types represented by "gentype" vary between 3647330f729Sjoerg// different parts of the specification. The following definitions capture 3657330f729Sjoerg// the different type lists for gentypes in different parts of the 3667330f729Sjoerg// specification. 3677330f729Sjoerg 3687330f729Sjoerg// Vector width lists. 3697330f729Sjoergdef VecAndScalar: IntList<"VecAndScalar", [1, 2, 3, 4, 8, 16]>; 3707330f729Sjoergdef VecNoScalar : IntList<"VecNoScalar", [2, 3, 4, 8, 16]>; 3717330f729Sjoergdef Vec1 : IntList<"Vec1", [1]>; 372*e038c9c4Sjoergdef Vec1234 : IntList<"Vec1234", [1, 2, 3, 4]>; 3737330f729Sjoerg 3747330f729Sjoerg// Type lists. 375*e038c9c4Sjoergdef TLAll : TypeList<[Char, UChar, Short, UShort, Int, UInt, Long, ULong, Float, Double, Half]>; 376*e038c9c4Sjoergdef TLFloat : TypeList<[Float, Double, Half]>; 377*e038c9c4Sjoergdef TLSignedInts : TypeList<[Char, Short, Int, Long]>; 378*e038c9c4Sjoergdef TLUnsignedInts : TypeList<[UChar, UShort, UInt, ULong]>; 3797330f729Sjoerg 380*e038c9c4Sjoergdef TLIntLongFloats : TypeList<[Int, UInt, Long, ULong, Float, Double, Half]>; 381*e038c9c4Sjoerg 382*e038c9c4Sjoerg// All unsigned integer types twice, to facilitate unsigned return types for e.g. 383*e038c9c4Sjoerg// uchar abs(char) and 384*e038c9c4Sjoerg// uchar abs(uchar). 385*e038c9c4Sjoergdef TLAllUIntsTwice : TypeList<[UChar, UChar, UShort, UShort, UInt, UInt, ULong, ULong]>; 386*e038c9c4Sjoerg 387*e038c9c4Sjoergdef TLAllInts : TypeList<[Char, UChar, Short, UShort, Int, UInt, Long, ULong]>; 3887330f729Sjoerg 3897330f729Sjoerg// GenType definitions for multiple base types (e.g. all floating point types, 3907330f729Sjoerg// or all integer types). 3917330f729Sjoerg// All types 392*e038c9c4Sjoergdef AGenType1 : GenericType<"AGenType1", TLAll, Vec1>; 3937330f729Sjoergdef AGenTypeN : GenericType<"AGenTypeN", TLAll, VecAndScalar>; 3947330f729Sjoergdef AGenTypeNNoScalar : GenericType<"AGenTypeNNoScalar", TLAll, VecNoScalar>; 3957330f729Sjoerg// All integer 3967330f729Sjoergdef AIGenType1 : GenericType<"AIGenType1", TLAllInts, Vec1>; 3977330f729Sjoergdef AIGenTypeN : GenericType<"AIGenTypeN", TLAllInts, VecAndScalar>; 3987330f729Sjoergdef AIGenTypeNNoScalar : GenericType<"AIGenTypeNNoScalar", TLAllInts, VecNoScalar>; 399*e038c9c4Sjoerg// All integer to unsigned 400*e038c9c4Sjoergdef AI2UGenTypeN : GenericType<"AI2UGenTypeN", TLAllUIntsTwice, VecAndScalar>; 401*e038c9c4Sjoerg// Signed integer 402*e038c9c4Sjoergdef SGenTypeN : GenericType<"SGenTypeN", TLSignedInts, VecAndScalar>; 403*e038c9c4Sjoerg// Unsigned integer 404*e038c9c4Sjoergdef UGenTypeN : GenericType<"UGenTypeN", TLUnsignedInts, VecAndScalar>; 4057330f729Sjoerg// Float 4067330f729Sjoergdef FGenTypeN : GenericType<"FGenTypeN", TLFloat, VecAndScalar>; 407*e038c9c4Sjoerg// (u)int, (u)long, and all floats 408*e038c9c4Sjoergdef IntLongFloatGenType1 : GenericType<"IntLongFloatGenType1", TLIntLongFloats, Vec1>; 409*e038c9c4Sjoerg// (u)char and (u)short 410*e038c9c4Sjoergdef CharShortGenType1 : GenericType<"CharShortGenType1", 411*e038c9c4Sjoerg TypeList<[Char, UChar, Short, UShort]>, Vec1>; 4127330f729Sjoerg 4137330f729Sjoerg// GenType definitions for every single base type (e.g. fp32 only). 4147330f729Sjoerg// Names are like: GenTypeFloatVecAndScalar. 4157330f729Sjoergforeach Type = [Char, UChar, Short, UShort, 4167330f729Sjoerg Int, UInt, Long, ULong, 4177330f729Sjoerg Float, Double, Half] in { 4187330f729Sjoerg foreach VecSizes = [VecAndScalar, VecNoScalar] in { 4197330f729Sjoerg def "GenType" # Type # VecSizes : 4207330f729Sjoerg GenericType<"GenType" # Type # VecSizes, 421*e038c9c4Sjoerg TypeList<[Type]>, VecSizes>; 4227330f729Sjoerg } 4237330f729Sjoerg} 4247330f729Sjoerg 425*e038c9c4Sjoerg// GenType definitions for vec1234. 426*e038c9c4Sjoergforeach Type = [Float, Double, Half] in { 427*e038c9c4Sjoerg def "GenType" # Type # Vec1234 : 428*e038c9c4Sjoerg GenericType<"GenType" # Type # Vec1234, 429*e038c9c4Sjoerg TypeList<[Type]>, Vec1234>; 430*e038c9c4Sjoerg} 431*e038c9c4Sjoerg 4327330f729Sjoerg 4337330f729Sjoerg//===----------------------------------------------------------------------===// 4347330f729Sjoerg// Definitions of OpenCL builtin functions 4357330f729Sjoerg//===----------------------------------------------------------------------===// 4367330f729Sjoerg//-------------------------------------------------------------------- 4377330f729Sjoerg// OpenCL v1.1/1.2/2.0 s6.2.3 - Explicit conversions. 4387330f729Sjoerg// OpenCL v2.0 Extensions s5.1.1 and s6.1.1 - Conversions. 4397330f729Sjoerg 4407330f729Sjoerg// Generate the convert_* builtins functions. 4417330f729Sjoergforeach RType = [Float, Double, Half, Char, UChar, Short, 4427330f729Sjoerg UShort, Int, UInt, Long, ULong] in { 4437330f729Sjoerg foreach IType = [Float, Double, Half, Char, UChar, Short, 4447330f729Sjoerg UShort, Int, UInt, Long, ULong] in { 445*e038c9c4Sjoerg // Conversions to integer type have a sat and non-sat variant. 446*e038c9c4Sjoerg foreach sat = !cond(!eq(RType.Name, "float") : [""], 447*e038c9c4Sjoerg !eq(RType.Name, "double") : [""], 448*e038c9c4Sjoerg !eq(RType.Name, "half") : [""], 449*e038c9c4Sjoerg 1 : ["", "_sat"]) in { 4507330f729Sjoerg foreach rnd = ["", "_rte", "_rtn", "_rtp", "_rtz"] in { 451*e038c9c4Sjoerg def : Builtin<"convert_" # RType.Name # sat # rnd, [RType, IType], 452*e038c9c4Sjoerg Attr.Const>; 4537330f729Sjoerg foreach v = [2, 3, 4, 8, 16] in { 4547330f729Sjoerg def : Builtin<"convert_" # RType.Name # v # sat # rnd, 455*e038c9c4Sjoerg [VectorType<RType, v>, VectorType<IType, v>], 456*e038c9c4Sjoerg Attr.Const>; 4577330f729Sjoerg } 4587330f729Sjoerg } 4597330f729Sjoerg } 4607330f729Sjoerg } 4617330f729Sjoerg} 4627330f729Sjoerg 4637330f729Sjoerg//-------------------------------------------------------------------- 4647330f729Sjoerg// OpenCL v1.1 s6.11.1, v1.2 s6.12.1, v2.0 s6.13.1 - Work-item Functions 4657330f729Sjoerg// --- Table 7 --- 466*e038c9c4Sjoergdef : Builtin<"get_work_dim", [UInt], Attr.Const>; 4677330f729Sjoergforeach name = ["get_global_size", "get_global_id", "get_local_size", 4687330f729Sjoerg "get_local_id", "get_num_groups", "get_group_id", 4697330f729Sjoerg "get_global_offset"] in { 470*e038c9c4Sjoerg def : Builtin<name, [Size, UInt], Attr.Const>; 4717330f729Sjoerg} 4727330f729Sjoerg 4737330f729Sjoerglet MinVersion = CL20 in { 4747330f729Sjoerg def : Builtin<"get_enqueued_local_size", [Size, UInt]>; 4757330f729Sjoerg foreach name = ["get_global_linear_id", "get_local_linear_id"] in { 4767330f729Sjoerg def : Builtin<name, [Size]>; 4777330f729Sjoerg } 4787330f729Sjoerg} 4797330f729Sjoerg 480*e038c9c4Sjoerg 481*e038c9c4Sjoerg//-------------------------------------------------------------------- 482*e038c9c4Sjoerg// OpenCL v1.1 s6.11.2, v1.2 s6.12.2, v2.0 s6.13.2 - Math functions 483*e038c9c4Sjoerg// OpenCL Extension v2.0 s5.1.2 and s6.1.2 - Math Functions 484*e038c9c4Sjoerg// --- Table 8 --- 485*e038c9c4Sjoerg// --- 1 argument --- 486*e038c9c4Sjoergforeach name = ["acos", "acosh", "acospi", 487*e038c9c4Sjoerg "asin", "asinh", "asinpi", 488*e038c9c4Sjoerg "atan", "atanh", "atanpi", 489*e038c9c4Sjoerg "cbrt", "ceil", 490*e038c9c4Sjoerg "cos", "cosh", "cospi", 491*e038c9c4Sjoerg "erfc", "erf", 492*e038c9c4Sjoerg "exp", "exp2", "exp10", "expm1", 493*e038c9c4Sjoerg "fabs", "floor", 494*e038c9c4Sjoerg "log", "log2", "log10", "log1p", "logb", 495*e038c9c4Sjoerg "rint", "round", "rsqrt", 496*e038c9c4Sjoerg "sin", "sinh", "sinpi", 497*e038c9c4Sjoerg "sqrt", 498*e038c9c4Sjoerg "tan", "tanh", "tanpi", 499*e038c9c4Sjoerg "tgamma", "trunc", 500*e038c9c4Sjoerg "lgamma"] in { 501*e038c9c4Sjoerg def : Builtin<name, [FGenTypeN, FGenTypeN], Attr.Const>; 502*e038c9c4Sjoerg} 503*e038c9c4Sjoergforeach name = ["nan"] in { 504*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecAndScalar, GenTypeUIntVecAndScalar], Attr.Const>; 505*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVecAndScalar, GenTypeULongVecAndScalar], Attr.Const>; 506*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVecAndScalar, GenTypeUShortVecAndScalar], Attr.Const>; 507*e038c9c4Sjoerg} 508*e038c9c4Sjoerg 509*e038c9c4Sjoerg// --- 2 arguments --- 510*e038c9c4Sjoergforeach name = ["atan2", "atan2pi", "copysign", "fdim", "fmod", "hypot", 511*e038c9c4Sjoerg "maxmag", "minmag", "nextafter", "pow", "powr", 512*e038c9c4Sjoerg "remainder"] in { 513*e038c9c4Sjoerg def : Builtin<name, [FGenTypeN, FGenTypeN, FGenTypeN], Attr.Const>; 514*e038c9c4Sjoerg} 515*e038c9c4Sjoergforeach name = ["fmax", "fmin"] in { 516*e038c9c4Sjoerg def : Builtin<name, [FGenTypeN, FGenTypeN, FGenTypeN], Attr.Const>; 517*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecNoScalar, GenTypeFloatVecNoScalar, Float], Attr.Const>; 518*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVecNoScalar, GenTypeDoubleVecNoScalar, Double], Attr.Const>; 519*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVecNoScalar, GenTypeHalfVecNoScalar, Half], Attr.Const>; 520*e038c9c4Sjoerg} 521*e038c9c4Sjoergforeach name = ["ilogb"] in { 522*e038c9c4Sjoerg def : Builtin<name, [GenTypeIntVecAndScalar, GenTypeFloatVecAndScalar], Attr.Const>; 523*e038c9c4Sjoerg def : Builtin<name, [GenTypeIntVecAndScalar, GenTypeDoubleVecAndScalar], Attr.Const>; 524*e038c9c4Sjoerg def : Builtin<name, [GenTypeIntVecAndScalar, GenTypeHalfVecAndScalar], Attr.Const>; 525*e038c9c4Sjoerg} 526*e038c9c4Sjoergforeach name = ["ldexp"] in { 527*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecAndScalar, GenTypeFloatVecAndScalar, GenTypeIntVecAndScalar], Attr.Const>; 528*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecNoScalar, GenTypeFloatVecNoScalar, Int], Attr.Const>; 529*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVecAndScalar, GenTypeDoubleVecAndScalar, GenTypeIntVecAndScalar], Attr.Const>; 530*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVecNoScalar, GenTypeDoubleVecNoScalar, Int], Attr.Const>; 531*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVecAndScalar, GenTypeHalfVecAndScalar, GenTypeIntVecAndScalar], Attr.Const>; 532*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVecNoScalar, GenTypeHalfVecNoScalar, Int], Attr.Const>; 533*e038c9c4Sjoerg} 534*e038c9c4Sjoergforeach name = ["pown", "rootn"] in { 535*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecAndScalar, GenTypeFloatVecAndScalar, GenTypeIntVecAndScalar], Attr.Const>; 536*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVecAndScalar, GenTypeDoubleVecAndScalar, GenTypeIntVecAndScalar], Attr.Const>; 537*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVecAndScalar, GenTypeHalfVecAndScalar, GenTypeIntVecAndScalar], Attr.Const>; 538*e038c9c4Sjoerg} 539*e038c9c4Sjoerg 540*e038c9c4Sjoerg// --- 3 arguments --- 541*e038c9c4Sjoergforeach name = ["fma", "mad"] in { 542*e038c9c4Sjoerg def : Builtin<name, [FGenTypeN, FGenTypeN, FGenTypeN, FGenTypeN], Attr.Const>; 543*e038c9c4Sjoerg} 544*e038c9c4Sjoerg 545*e038c9c4Sjoerg// --- Version dependent --- 546*e038c9c4Sjoerglet MaxVersion = CL20 in { 547*e038c9c4Sjoerg foreach AS = [GlobalAS, LocalAS, PrivateAS] in { 548*e038c9c4Sjoerg foreach name = ["fract", "modf", "sincos"] in { 549*e038c9c4Sjoerg def : Builtin<name, [FGenTypeN, FGenTypeN, PointerType<FGenTypeN, AS>]>; 550*e038c9c4Sjoerg } 551*e038c9c4Sjoerg foreach name = ["frexp", "lgamma_r"] in { 552*e038c9c4Sjoerg foreach Type = [GenTypeFloatVecAndScalar, GenTypeDoubleVecAndScalar, GenTypeHalfVecAndScalar] in { 553*e038c9c4Sjoerg def : Builtin<name, [Type, Type, PointerType<GenTypeIntVecAndScalar, AS>]>; 554*e038c9c4Sjoerg } 555*e038c9c4Sjoerg } 556*e038c9c4Sjoerg foreach name = ["remquo"] in { 557*e038c9c4Sjoerg foreach Type = [GenTypeFloatVecAndScalar, GenTypeDoubleVecAndScalar, GenTypeHalfVecAndScalar] in { 558*e038c9c4Sjoerg def : Builtin<name, [Type, Type, Type, PointerType<GenTypeIntVecAndScalar, AS>]>; 559*e038c9c4Sjoerg } 560*e038c9c4Sjoerg } 561*e038c9c4Sjoerg } 562*e038c9c4Sjoerg} 563*e038c9c4Sjoerglet MinVersion = CL20 in { 564*e038c9c4Sjoerg foreach name = ["fract", "modf", "sincos"] in { 565*e038c9c4Sjoerg def : Builtin<name, [FGenTypeN, FGenTypeN, PointerType<FGenTypeN, GenericAS>]>; 566*e038c9c4Sjoerg } 567*e038c9c4Sjoerg foreach name = ["frexp", "lgamma_r"] in { 568*e038c9c4Sjoerg foreach Type = [GenTypeFloatVecAndScalar, GenTypeDoubleVecAndScalar, GenTypeHalfVecAndScalar] in { 569*e038c9c4Sjoerg def : Builtin<name, [Type, Type, PointerType<GenTypeIntVecAndScalar, GenericAS>]>; 570*e038c9c4Sjoerg } } 571*e038c9c4Sjoerg foreach name = ["remquo"] in { 572*e038c9c4Sjoerg foreach Type = [GenTypeFloatVecAndScalar, GenTypeDoubleVecAndScalar, GenTypeHalfVecAndScalar] in { 573*e038c9c4Sjoerg def : Builtin<name, [Type, Type, Type, PointerType<GenTypeIntVecAndScalar, GenericAS>]>; 574*e038c9c4Sjoerg } 575*e038c9c4Sjoerg } 576*e038c9c4Sjoerg} 577*e038c9c4Sjoerg 578*e038c9c4Sjoerg// --- Table 9 --- 579*e038c9c4Sjoergforeach name = ["half_cos", 580*e038c9c4Sjoerg "half_exp", "half_exp2", "half_exp10", 581*e038c9c4Sjoerg "half_log", "half_log2", "half_log10", 582*e038c9c4Sjoerg "half_recip", "half_rsqrt", 583*e038c9c4Sjoerg "half_sin", "half_sqrt", "half_tan", 584*e038c9c4Sjoerg "native_cos", 585*e038c9c4Sjoerg "native_exp", "native_exp2", "native_exp10", 586*e038c9c4Sjoerg "native_log", "native_log2", "native_log10", 587*e038c9c4Sjoerg "native_recip", "native_rsqrt", 588*e038c9c4Sjoerg "native_sin", "native_sqrt", "native_tan"] in { 589*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecAndScalar, GenTypeFloatVecAndScalar], Attr.Const>; 590*e038c9c4Sjoerg} 591*e038c9c4Sjoergforeach name = ["half_divide", "half_powr", 592*e038c9c4Sjoerg "native_divide", "native_powr"] in { 593*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecAndScalar, GenTypeFloatVecAndScalar, GenTypeFloatVecAndScalar], Attr.Const>; 594*e038c9c4Sjoerg} 595*e038c9c4Sjoerg 596*e038c9c4Sjoerg//-------------------------------------------------------------------- 597*e038c9c4Sjoerg// OpenCL v1.1 s6.11.3, v1.2 s6.12.3, v2.0 s6.13.3 - Integer Functions 598*e038c9c4Sjoerg// --- Table 10 --- 599*e038c9c4Sjoerg// --- 1 argument --- 600*e038c9c4Sjoergforeach name = ["abs"] in { 601*e038c9c4Sjoerg def : Builtin<name, [AI2UGenTypeN, AIGenTypeN], Attr.Const>; 602*e038c9c4Sjoerg} 603*e038c9c4Sjoergdef : Builtin<"clz", [AIGenTypeN, AIGenTypeN], Attr.Const>; 604*e038c9c4Sjoerglet MinVersion = CL12 in { 605*e038c9c4Sjoerg def : Builtin<"popcount", [AIGenTypeN, AIGenTypeN], Attr.Const>; 606*e038c9c4Sjoerg} 607*e038c9c4Sjoerglet MinVersion = CL20 in { 608*e038c9c4Sjoerg foreach name = ["ctz"] in { 609*e038c9c4Sjoerg def : Builtin<name, [AIGenTypeN, AIGenTypeN]>; 610*e038c9c4Sjoerg } 611*e038c9c4Sjoerg} 612*e038c9c4Sjoerg 613*e038c9c4Sjoerg// --- 2 arguments --- 614*e038c9c4Sjoergforeach name = ["abs_diff"] in { 615*e038c9c4Sjoerg def : Builtin<name, [AI2UGenTypeN, AIGenTypeN, AIGenTypeN], Attr.Const>; 616*e038c9c4Sjoerg} 617*e038c9c4Sjoergforeach name = ["add_sat", "hadd", "rhadd", "mul_hi", "rotate", "sub_sat"] in { 618*e038c9c4Sjoerg def : Builtin<name, [AIGenTypeN, AIGenTypeN, AIGenTypeN], Attr.Const>; 619*e038c9c4Sjoerg} 620*e038c9c4Sjoergforeach name = ["max", "min"] in { 621*e038c9c4Sjoerg def : Builtin<name, [AIGenTypeN, AIGenTypeN, AIGenTypeN], Attr.Const>; 622*e038c9c4Sjoerg def : Builtin<name, [AIGenTypeNNoScalar, AIGenTypeNNoScalar, AIGenType1], Attr.Const>; 623*e038c9c4Sjoerg} 624*e038c9c4Sjoergforeach name = ["upsample"] in { 625*e038c9c4Sjoerg def : Builtin<name, [GenTypeShortVecAndScalar, GenTypeCharVecAndScalar, GenTypeUCharVecAndScalar], Attr.Const>; 626*e038c9c4Sjoerg def : Builtin<name, [GenTypeUShortVecAndScalar, GenTypeUCharVecAndScalar, GenTypeUCharVecAndScalar], Attr.Const>; 627*e038c9c4Sjoerg def : Builtin<name, [GenTypeIntVecAndScalar, GenTypeShortVecAndScalar, GenTypeUShortVecAndScalar], Attr.Const>; 628*e038c9c4Sjoerg def : Builtin<name, [GenTypeUIntVecAndScalar, GenTypeUShortVecAndScalar, GenTypeUShortVecAndScalar], Attr.Const>; 629*e038c9c4Sjoerg def : Builtin<name, [GenTypeLongVecAndScalar, GenTypeIntVecAndScalar, GenTypeUIntVecAndScalar], Attr.Const>; 630*e038c9c4Sjoerg def : Builtin<name, [GenTypeULongVecAndScalar, GenTypeUIntVecAndScalar, GenTypeUIntVecAndScalar], Attr.Const>; 631*e038c9c4Sjoerg} 632*e038c9c4Sjoerg 633*e038c9c4Sjoerg// --- 3 arguments --- 634*e038c9c4Sjoergforeach name = ["clamp"] in { 635*e038c9c4Sjoerg def : Builtin<name, [AIGenTypeN, AIGenTypeN, AIGenTypeN, AIGenTypeN], Attr.Const>; 636*e038c9c4Sjoerg def : Builtin<name, [AIGenTypeNNoScalar, AIGenTypeNNoScalar, AIGenType1, AIGenType1], Attr.Const>; 637*e038c9c4Sjoerg} 638*e038c9c4Sjoergforeach name = ["mad_hi", "mad_sat"] in { 639*e038c9c4Sjoerg def : Builtin<name, [AIGenTypeN, AIGenTypeN, AIGenTypeN, AIGenTypeN], Attr.Const>; 640*e038c9c4Sjoerg} 641*e038c9c4Sjoerg 642*e038c9c4Sjoerg// --- Table 11 --- 643*e038c9c4Sjoergforeach name = ["mad24"] in { 644*e038c9c4Sjoerg def : Builtin<name, [GenTypeIntVecAndScalar, GenTypeIntVecAndScalar, GenTypeIntVecAndScalar, GenTypeIntVecAndScalar], Attr.Const>; 645*e038c9c4Sjoerg def : Builtin<name, [GenTypeUIntVecAndScalar, GenTypeUIntVecAndScalar, GenTypeUIntVecAndScalar, GenTypeUIntVecAndScalar], Attr.Const>; 646*e038c9c4Sjoerg} 647*e038c9c4Sjoergforeach name = ["mul24"] in { 648*e038c9c4Sjoerg def : Builtin<name, [GenTypeIntVecAndScalar, GenTypeIntVecAndScalar, GenTypeIntVecAndScalar], Attr.Const>; 649*e038c9c4Sjoerg def : Builtin<name, [GenTypeUIntVecAndScalar, GenTypeUIntVecAndScalar, GenTypeUIntVecAndScalar], Attr.Const>; 650*e038c9c4Sjoerg} 651*e038c9c4Sjoerg 652*e038c9c4Sjoerg//-------------------------------------------------------------------- 653*e038c9c4Sjoerg// OpenCL v1.1 s6.11.4, v1.2 s6.12.4, v2.0 s6.13.4 - Common Functions 654*e038c9c4Sjoerg// OpenCL Extension v2.0 s5.1.3 and s6.1.3 - Common Functions 655*e038c9c4Sjoerg// --- Table 12 --- 656*e038c9c4Sjoerg// --- 1 argument --- 657*e038c9c4Sjoergforeach name = ["degrees", "radians", "sign"] in { 658*e038c9c4Sjoerg def : Builtin<name, [FGenTypeN, FGenTypeN], Attr.Const>; 659*e038c9c4Sjoerg} 660*e038c9c4Sjoerg 661*e038c9c4Sjoerg// --- 2 arguments --- 662*e038c9c4Sjoergforeach name = ["max", "min"] in { 663*e038c9c4Sjoerg def : Builtin<name, [FGenTypeN, FGenTypeN, FGenTypeN], Attr.Const>; 664*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecNoScalar, GenTypeFloatVecNoScalar, Float], Attr.Const>; 665*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVecNoScalar, GenTypeDoubleVecNoScalar, Double], Attr.Const>; 666*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVecNoScalar, GenTypeHalfVecNoScalar, Half], Attr.Const>; 667*e038c9c4Sjoerg} 668*e038c9c4Sjoergforeach name = ["step"] in { 669*e038c9c4Sjoerg def : Builtin<name, [FGenTypeN, FGenTypeN, FGenTypeN], Attr.Const>; 670*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecNoScalar, Float, GenTypeFloatVecNoScalar], Attr.Const>; 671*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVecNoScalar, Double, GenTypeDoubleVecNoScalar], Attr.Const>; 672*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVecNoScalar, Half, GenTypeHalfVecNoScalar], Attr.Const>; 673*e038c9c4Sjoerg} 674*e038c9c4Sjoerg 675*e038c9c4Sjoerg// --- 3 arguments --- 676*e038c9c4Sjoergforeach name = ["clamp"] in { 677*e038c9c4Sjoerg def : Builtin<name, [FGenTypeN, FGenTypeN, FGenTypeN, FGenTypeN], Attr.Const>; 678*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecNoScalar, GenTypeFloatVecNoScalar, Float, Float], Attr.Const>; 679*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVecNoScalar, GenTypeDoubleVecNoScalar, Double, Double], Attr.Const>; 680*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVecNoScalar, GenTypeHalfVecNoScalar, Half, Half], Attr.Const>; 681*e038c9c4Sjoerg} 682*e038c9c4Sjoergforeach name = ["mix"] in { 683*e038c9c4Sjoerg def : Builtin<name, [FGenTypeN, FGenTypeN, FGenTypeN, FGenTypeN], Attr.Const>; 684*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecNoScalar, GenTypeFloatVecNoScalar, GenTypeFloatVecNoScalar, Float], Attr.Const>; 685*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVecNoScalar, GenTypeDoubleVecNoScalar, GenTypeDoubleVecNoScalar, Double], Attr.Const>; 686*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVecNoScalar, GenTypeHalfVecNoScalar, GenTypeHalfVecNoScalar, Half], Attr.Const>; 687*e038c9c4Sjoerg} 688*e038c9c4Sjoergforeach name = ["smoothstep"] in { 689*e038c9c4Sjoerg def : Builtin<name, [FGenTypeN, FGenTypeN, FGenTypeN, FGenTypeN], Attr.Const>; 690*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecNoScalar, Float, Float, GenTypeFloatVecNoScalar], Attr.Const>; 691*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVecNoScalar, Double, Double, GenTypeDoubleVecNoScalar], Attr.Const>; 692*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVecNoScalar, Half, Half, GenTypeHalfVecNoScalar], Attr.Const>; 693*e038c9c4Sjoerg} 694*e038c9c4Sjoerg 695*e038c9c4Sjoerg 696*e038c9c4Sjoerg//-------------------------------------------------------------------- 697*e038c9c4Sjoerg// OpenCL v1.1 s6.11.5, v1.2 s6.12.5, v2.0 s6.13.5 - Geometric Functions 698*e038c9c4Sjoerg// OpenCL Extension v2.0 s5.1.4 and s6.1.4 - Geometric Functions 699*e038c9c4Sjoerg// --- Table 13 --- 700*e038c9c4Sjoerg// --- 1 argument --- 701*e038c9c4Sjoergforeach name = ["length"] in { 702*e038c9c4Sjoerg def : Builtin<name, [Float, GenTypeFloatVec1234], Attr.Const>; 703*e038c9c4Sjoerg def : Builtin<name, [Double, GenTypeDoubleVec1234], Attr.Const>; 704*e038c9c4Sjoerg def : Builtin<name, [Half, GenTypeHalfVec1234], Attr.Const>; 705*e038c9c4Sjoerg} 706*e038c9c4Sjoergforeach name = ["normalize"] in { 707*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVec1234, GenTypeFloatVec1234], Attr.Const>; 708*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVec1234, GenTypeDoubleVec1234], Attr.Const>; 709*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVec1234, GenTypeHalfVec1234], Attr.Const>; 710*e038c9c4Sjoerg} 711*e038c9c4Sjoergforeach name = ["fast_length"] in { 712*e038c9c4Sjoerg def : Builtin<name, [Float, GenTypeFloatVec1234], Attr.Const>; 713*e038c9c4Sjoerg} 714*e038c9c4Sjoergforeach name = ["fast_normalize"] in { 715*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVec1234, GenTypeFloatVec1234], Attr.Const>; 716*e038c9c4Sjoerg} 717*e038c9c4Sjoerg 718*e038c9c4Sjoerg// --- 2 arguments --- 719*e038c9c4Sjoergforeach name = ["cross"] in { 720*e038c9c4Sjoerg foreach VSize = [3, 4] in { 721*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, VSize>, VectorType<Float, VSize>, VectorType<Float, VSize>], Attr.Const>; 722*e038c9c4Sjoerg def : Builtin<name, [VectorType<Double, VSize>, VectorType<Double, VSize>, VectorType<Double, VSize>], Attr.Const>; 723*e038c9c4Sjoerg def : Builtin<name, [VectorType<Half, VSize>, VectorType<Half, VSize>, VectorType<Half, VSize>], Attr.Const>; 724*e038c9c4Sjoerg } 725*e038c9c4Sjoerg} 726*e038c9c4Sjoergforeach name = ["dot", "distance"] in { 727*e038c9c4Sjoerg def : Builtin<name, [Float, GenTypeFloatVec1234, GenTypeFloatVec1234], Attr.Const>; 728*e038c9c4Sjoerg def : Builtin<name, [Double, GenTypeDoubleVec1234, GenTypeDoubleVec1234], Attr.Const>; 729*e038c9c4Sjoerg def : Builtin<name, [Half, GenTypeHalfVec1234, GenTypeHalfVec1234], Attr.Const>; 730*e038c9c4Sjoerg} 731*e038c9c4Sjoergforeach name = ["fast_distance"] in { 732*e038c9c4Sjoerg def : Builtin<name, [Float, GenTypeFloatVec1234, GenTypeFloatVec1234], Attr.Const>; 733*e038c9c4Sjoerg} 734*e038c9c4Sjoerg 735*e038c9c4Sjoerg 736*e038c9c4Sjoerg//-------------------------------------------------------------------- 737*e038c9c4Sjoerg// OpenCL v1.1 s6.11.6, v1.2 s6.12.6, v2.0 s6.13.6 - Relational Functions 738*e038c9c4Sjoerg// OpenCL Extension v2.0 s5.1.5 and s6.1.5 - Relational Functions 739*e038c9c4Sjoerg// --- Table 14 --- 740*e038c9c4Sjoerg// --- 1 argument --- 741*e038c9c4Sjoergforeach name = ["isfinite", "isinf", "isnan", "isnormal", "signbit"] in { 742*e038c9c4Sjoerg def : Builtin<name, [GenTypeIntVecAndScalar, GenTypeFloatVecAndScalar], Attr.Const>; 743*e038c9c4Sjoerg def : Builtin<name, [Int, Double], Attr.Const>; 744*e038c9c4Sjoerg def : Builtin<name, [GenTypeLongVecNoScalar, GenTypeDoubleVecNoScalar], Attr.Const>; 745*e038c9c4Sjoerg def : Builtin<name, [Int, Half], Attr.Const>; 746*e038c9c4Sjoerg def : Builtin<name, [GenTypeShortVecNoScalar, GenTypeHalfVecNoScalar], Attr.Const>; 747*e038c9c4Sjoerg} 748*e038c9c4Sjoergforeach name = ["any", "all"] in { 749*e038c9c4Sjoerg def : Builtin<name, [Int, SGenTypeN], Attr.Const>; 750*e038c9c4Sjoerg} 751*e038c9c4Sjoerg 752*e038c9c4Sjoerg// --- 2 arguments --- 753*e038c9c4Sjoergforeach name = ["isequal", "isnotequal", "isgreater", "isgreaterequal", 754*e038c9c4Sjoerg "isless", "islessequal", "islessgreater", "isordered", 755*e038c9c4Sjoerg "isunordered"] in { 756*e038c9c4Sjoerg def : Builtin<name, [GenTypeIntVecAndScalar, GenTypeFloatVecAndScalar, GenTypeFloatVecAndScalar], Attr.Const>; 757*e038c9c4Sjoerg def : Builtin<name, [Int, Double, Double], Attr.Const>; 758*e038c9c4Sjoerg def : Builtin<name, [GenTypeLongVecNoScalar, GenTypeDoubleVecNoScalar, GenTypeDoubleVecNoScalar], Attr.Const>; 759*e038c9c4Sjoerg def : Builtin<name, [Int, Half, Half], Attr.Const>; 760*e038c9c4Sjoerg def : Builtin<name, [GenTypeShortVecNoScalar, GenTypeHalfVecNoScalar, GenTypeHalfVecNoScalar], Attr.Const>; 761*e038c9c4Sjoerg} 762*e038c9c4Sjoerg 763*e038c9c4Sjoerg// --- 3 arguments --- 764*e038c9c4Sjoergforeach name = ["bitselect"] in { 765*e038c9c4Sjoerg def : Builtin<name, [AGenTypeN, AGenTypeN, AGenTypeN, AGenTypeN], Attr.Const>; 766*e038c9c4Sjoerg} 767*e038c9c4Sjoergforeach name = ["select"] in { 768*e038c9c4Sjoerg def : Builtin<name, [SGenTypeN, SGenTypeN, SGenTypeN, SGenTypeN], Attr.Const>; 769*e038c9c4Sjoerg def : Builtin<name, [SGenTypeN, SGenTypeN, SGenTypeN, UGenTypeN], Attr.Const>; 770*e038c9c4Sjoerg def : Builtin<name, [UGenTypeN, UGenTypeN, UGenTypeN, UGenTypeN], Attr.Const>; 771*e038c9c4Sjoerg def : Builtin<name, [UGenTypeN, UGenTypeN, UGenTypeN, SGenTypeN], Attr.Const>; 772*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecAndScalar, GenTypeFloatVecAndScalar, GenTypeFloatVecAndScalar, GenTypeIntVecAndScalar], Attr.Const>; 773*e038c9c4Sjoerg def : Builtin<name, [GenTypeFloatVecAndScalar, GenTypeFloatVecAndScalar, GenTypeFloatVecAndScalar, GenTypeUIntVecAndScalar], Attr.Const>; 774*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVecAndScalar, GenTypeDoubleVecAndScalar, GenTypeDoubleVecAndScalar, GenTypeLongVecAndScalar], Attr.Const>; 775*e038c9c4Sjoerg def : Builtin<name, [GenTypeDoubleVecAndScalar, GenTypeDoubleVecAndScalar, GenTypeDoubleVecAndScalar, GenTypeULongVecAndScalar], Attr.Const>; 776*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVecAndScalar, GenTypeHalfVecAndScalar, GenTypeHalfVecAndScalar, GenTypeShortVecAndScalar], Attr.Const>; 777*e038c9c4Sjoerg def : Builtin<name, [GenTypeHalfVecAndScalar, GenTypeHalfVecAndScalar, GenTypeHalfVecAndScalar, GenTypeUShortVecAndScalar], Attr.Const>; 778*e038c9c4Sjoerg} 779*e038c9c4Sjoerg 780*e038c9c4Sjoerg 7817330f729Sjoerg//-------------------------------------------------------------------- 7827330f729Sjoerg// OpenCL v1.1 s6.11.7, v1.2 s6.12.7, v2.0 s6.13.7 - Vector Data Load and Store Functions 783*e038c9c4Sjoerg// OpenCL Extension v1.1 s9.3.6 and s9.6.6, v1.2 s9.5.6, v2.0 s5.1.6 and s6.1.6 - Vector Data Load and Store Functions 7847330f729Sjoerg// --- Table 15 --- 7857330f729Sjoerg// Variants for OpenCL versions below 2.0, using pointers to the global, local 7867330f729Sjoerg// and private address spaces. 7877330f729Sjoerglet MaxVersion = CL20 in { 7887330f729Sjoerg foreach AS = [GlobalAS, LocalAS, PrivateAS] in { 7897330f729Sjoerg foreach VSize = [2, 3, 4, 8, 16] in { 7907330f729Sjoerg foreach name = ["vload" # VSize] in { 7917330f729Sjoerg def : Builtin<name, [VectorType<Char, VSize>, Size, PointerType<ConstType<Char>, AS>]>; 7927330f729Sjoerg def : Builtin<name, [VectorType<UChar, VSize>, Size, PointerType<ConstType<UChar>, AS>]>; 7937330f729Sjoerg def : Builtin<name, [VectorType<Short, VSize>, Size, PointerType<ConstType<Short>, AS>]>; 7947330f729Sjoerg def : Builtin<name, [VectorType<UShort, VSize>, Size, PointerType<ConstType<UShort>, AS>]>; 7957330f729Sjoerg def : Builtin<name, [VectorType<Int, VSize>, Size, PointerType<ConstType<Int>, AS>]>; 7967330f729Sjoerg def : Builtin<name, [VectorType<UInt, VSize>, Size, PointerType<ConstType<UInt>, AS>]>; 7977330f729Sjoerg def : Builtin<name, [VectorType<Long, VSize>, Size, PointerType<ConstType<Long>, AS>]>; 7987330f729Sjoerg def : Builtin<name, [VectorType<ULong, VSize>, Size, PointerType<ConstType<ULong>, AS>]>; 7997330f729Sjoerg def : Builtin<name, [VectorType<Float, VSize>, Size, PointerType<ConstType<Float>, AS>]>; 8007330f729Sjoerg def : Builtin<name, [VectorType<Double, VSize>, Size, PointerType<ConstType<Double>, AS>]>; 8017330f729Sjoerg def : Builtin<name, [VectorType<Half, VSize>, Size, PointerType<ConstType<Half>, AS>]>; 8027330f729Sjoerg } 8037330f729Sjoerg foreach name = ["vstore" # VSize] in { 804*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Char, VSize>, Size, PointerType<Char, AS>]>; 805*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<UChar, VSize>, Size, PointerType<UChar, AS>]>; 806*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Short, VSize>, Size, PointerType<Short, AS>]>; 807*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<UShort, VSize>, Size, PointerType<UShort, AS>]>; 808*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Int, VSize>, Size, PointerType<Int, AS>]>; 809*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<UInt, VSize>, Size, PointerType<UInt, AS>]>; 810*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Long, VSize>, Size, PointerType<Long, AS>]>; 811*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<ULong, VSize>, Size, PointerType<ULong, AS>]>; 812*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Float, VSize>, Size, PointerType<Float, AS>]>; 813*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Double, VSize>, Size, PointerType<Double, AS>]>; 814*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Half, VSize>, Size, PointerType<Half, AS>]>; 8157330f729Sjoerg } 8167330f729Sjoerg foreach name = ["vloada_half" # VSize] in { 8177330f729Sjoerg def : Builtin<name, [VectorType<Float, VSize>, Size, PointerType<ConstType<Half>, AS>]>; 8187330f729Sjoerg } 8197330f729Sjoerg foreach rnd = ["", "_rte", "_rtz", "_rtp", "_rtn"] in { 8207330f729Sjoerg foreach name = ["vstorea_half" # VSize # rnd] in { 8217330f729Sjoerg def : Builtin<name, [Void, VectorType<Float, VSize>, Size, PointerType<Half, AS>]>; 8227330f729Sjoerg def : Builtin<name, [Void, VectorType<Double, VSize>, Size, PointerType<Half, AS>]>; 8237330f729Sjoerg } 8247330f729Sjoerg } 8257330f729Sjoerg } 8267330f729Sjoerg } 8277330f729Sjoerg} 8287330f729Sjoerg// Variants for OpenCL versions above 2.0, using pointers to the generic 8297330f729Sjoerg// address space. 8307330f729Sjoerglet MinVersion = CL20 in { 8317330f729Sjoerg foreach VSize = [2, 3, 4, 8, 16] in { 8327330f729Sjoerg foreach name = ["vload" # VSize] in { 8337330f729Sjoerg def : Builtin<name, [VectorType<Char, VSize>, Size, PointerType<ConstType<Char>, GenericAS>]>; 8347330f729Sjoerg def : Builtin<name, [VectorType<UChar, VSize>, Size, PointerType<ConstType<UChar>, GenericAS>]>; 8357330f729Sjoerg def : Builtin<name, [VectorType<Short, VSize>, Size, PointerType<ConstType<Short>, GenericAS>]>; 8367330f729Sjoerg def : Builtin<name, [VectorType<UShort, VSize>, Size, PointerType<ConstType<UShort>, GenericAS>]>; 8377330f729Sjoerg def : Builtin<name, [VectorType<Int, VSize>, Size, PointerType<ConstType<Int>, GenericAS>]>; 8387330f729Sjoerg def : Builtin<name, [VectorType<UInt, VSize>, Size, PointerType<ConstType<UInt>, GenericAS>]>; 8397330f729Sjoerg def : Builtin<name, [VectorType<Long, VSize>, Size, PointerType<ConstType<Long>, GenericAS>]>; 8407330f729Sjoerg def : Builtin<name, [VectorType<ULong, VSize>, Size, PointerType<ConstType<ULong>, GenericAS>]>; 8417330f729Sjoerg def : Builtin<name, [VectorType<Float, VSize>, Size, PointerType<ConstType<Float>, GenericAS>]>; 8427330f729Sjoerg def : Builtin<name, [VectorType<Double, VSize>, Size, PointerType<ConstType<Double>, GenericAS>]>; 8437330f729Sjoerg def : Builtin<name, [VectorType<Half, VSize>, Size, PointerType<ConstType<Half>, GenericAS>]>; 8447330f729Sjoerg } 8457330f729Sjoerg foreach name = ["vstore" # VSize] in { 846*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Char, VSize>, Size, PointerType<Char, GenericAS>]>; 847*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<UChar, VSize>, Size, PointerType<UChar, GenericAS>]>; 848*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Short, VSize>, Size, PointerType<Short, GenericAS>]>; 849*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<UShort, VSize>, Size, PointerType<UShort, GenericAS>]>; 850*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Int, VSize>, Size, PointerType<Int, GenericAS>]>; 851*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<UInt, VSize>, Size, PointerType<UInt, GenericAS>]>; 852*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Long, VSize>, Size, PointerType<Long, GenericAS>]>; 853*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<ULong, VSize>, Size, PointerType<ULong, GenericAS>]>; 854*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Float, VSize>, Size, PointerType<Float, GenericAS>]>; 855*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Double, VSize>, Size, PointerType<Double, GenericAS>]>; 856*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Half, VSize>, Size, PointerType<Half, GenericAS>]>; 8577330f729Sjoerg } 8587330f729Sjoerg foreach name = ["vloada_half" # VSize] in { 8597330f729Sjoerg def : Builtin<name, [VectorType<Float, VSize>, Size, PointerType<ConstType<Half>, GenericAS>]>; 8607330f729Sjoerg } 8617330f729Sjoerg foreach rnd = ["", "_rte", "_rtz", "_rtp", "_rtn"] in { 8627330f729Sjoerg foreach name = ["vstorea_half" # VSize # rnd] in { 8637330f729Sjoerg def : Builtin<name, [Void, VectorType<Float, VSize>, Size, PointerType<Half, GenericAS>]>; 8647330f729Sjoerg def : Builtin<name, [Void, VectorType<Double, VSize>, Size, PointerType<Half, GenericAS>]>; 8657330f729Sjoerg } 8667330f729Sjoerg } 8677330f729Sjoerg } 8687330f729Sjoerg} 8697330f729Sjoerg// Variants using pointers to the constant address space. 8707330f729Sjoergforeach VSize = [2, 3, 4, 8, 16] in { 8717330f729Sjoerg foreach name = ["vload" # VSize] in { 8727330f729Sjoerg def : Builtin<name, [VectorType<Char, VSize>, Size, PointerType<ConstType<Char>, ConstantAS>]>; 8737330f729Sjoerg def : Builtin<name, [VectorType<UChar, VSize>, Size, PointerType<ConstType<UChar>, ConstantAS>]>; 8747330f729Sjoerg def : Builtin<name, [VectorType<Short, VSize>, Size, PointerType<ConstType<Short>, ConstantAS>]>; 8757330f729Sjoerg def : Builtin<name, [VectorType<UShort, VSize>, Size, PointerType<ConstType<UShort>, ConstantAS>]>; 8767330f729Sjoerg def : Builtin<name, [VectorType<Int, VSize>, Size, PointerType<ConstType<Int>, ConstantAS>]>; 8777330f729Sjoerg def : Builtin<name, [VectorType<UInt, VSize>, Size, PointerType<ConstType<UInt>, ConstantAS>]>; 8787330f729Sjoerg def : Builtin<name, [VectorType<Long, VSize>, Size, PointerType<ConstType<Long>, ConstantAS>]>; 8797330f729Sjoerg def : Builtin<name, [VectorType<ULong, VSize>, Size, PointerType<ConstType<ULong>, ConstantAS>]>; 8807330f729Sjoerg def : Builtin<name, [VectorType<Float, VSize>, Size, PointerType<ConstType<Float>, ConstantAS>]>; 8817330f729Sjoerg def : Builtin<name, [VectorType<Double, VSize>, Size, PointerType<ConstType<Double>, ConstantAS>]>; 8827330f729Sjoerg def : Builtin<name, [VectorType<Half, VSize>, Size, PointerType<ConstType<Half>, ConstantAS>]>; 8837330f729Sjoerg } 8847330f729Sjoerg foreach name = ["vloada_half" # VSize] in { 8857330f729Sjoerg def : Builtin<name, [VectorType<Float, VSize>, Size, PointerType<ConstType<Half>, ConstantAS>]>; 8867330f729Sjoerg } 887*e038c9c4Sjoerg} 888*e038c9c4Sjoerglet MaxVersion = CL20 in { 889*e038c9c4Sjoerg foreach AS = [GlobalAS, LocalAS, PrivateAS] in { 890*e038c9c4Sjoerg def : Builtin<"vload_half", [Float, Size, PointerType<ConstType<Half>, AS>]>; 891*e038c9c4Sjoerg def : Builtin<"vloada_half", [Float, Size, PointerType<ConstType<Half>, AS>]>; 892*e038c9c4Sjoerg foreach VSize = [2, 3, 4, 8, 16] in { 893*e038c9c4Sjoerg foreach name = ["vload_half" # VSize] in { 894*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, VSize>, Size, PointerType<ConstType<Half>, AS>]>; 895*e038c9c4Sjoerg } 896*e038c9c4Sjoerg } 8977330f729Sjoerg foreach rnd = ["", "_rte", "_rtz", "_rtp", "_rtn"] in { 898*e038c9c4Sjoerg foreach name = ["vstore_half" # rnd, "vstorea_half" # rnd] in { 899*e038c9c4Sjoerg def : Builtin<name, [Void, Float, Size, PointerType<Half, AS>]>; 900*e038c9c4Sjoerg def : Builtin<name, [Void, Double, Size, PointerType<Half, AS>]>; 901*e038c9c4Sjoerg } 902*e038c9c4Sjoerg foreach VSize = [2, 3, 4, 8, 16] in { 903*e038c9c4Sjoerg foreach name = ["vstore_half" # VSize # rnd] in { 904*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Float, VSize>, Size, PointerType<Half, AS>]>; 905*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Double, VSize>, Size, PointerType<Half, AS>]>; 9067330f729Sjoerg } 9077330f729Sjoerg } 9087330f729Sjoerg } 909*e038c9c4Sjoerg } 910*e038c9c4Sjoerg} 911*e038c9c4Sjoerglet MinVersion = CL20 in { 912*e038c9c4Sjoerg foreach AS = [GenericAS] in { 913*e038c9c4Sjoerg def : Builtin<"vload_half", [Float, Size, PointerType<ConstType<Half>, AS>]>; 914*e038c9c4Sjoerg def : Builtin<"vloada_half", [Float, Size, PointerType<ConstType<Half>, AS>]>; 915*e038c9c4Sjoerg foreach VSize = [2, 3, 4, 8, 16] in { 916*e038c9c4Sjoerg foreach name = ["vload_half" # VSize] in { 917*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, VSize>, Size, PointerType<ConstType<Half>, AS>]>; 918*e038c9c4Sjoerg } 919*e038c9c4Sjoerg } 920*e038c9c4Sjoerg foreach rnd = ["", "_rte", "_rtz", "_rtp", "_rtn"] in { 921*e038c9c4Sjoerg foreach name = ["vstore_half" # rnd, "vstorea_half" # rnd] in { 922*e038c9c4Sjoerg def : Builtin<name, [Void, Float, Size, PointerType<Half, AS>]>; 923*e038c9c4Sjoerg def : Builtin<name, [Void, Double, Size, PointerType<Half, AS>]>; 924*e038c9c4Sjoerg } 925*e038c9c4Sjoerg foreach VSize = [2, 3, 4, 8, 16] in { 926*e038c9c4Sjoerg foreach name = ["vstore_half" # VSize # rnd] in { 927*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Float, VSize>, Size, PointerType<Half, AS>]>; 928*e038c9c4Sjoerg def : Builtin<name, [Void, VectorType<Double, VSize>, Size, PointerType<Half, AS>]>; 929*e038c9c4Sjoerg } 930*e038c9c4Sjoerg } 931*e038c9c4Sjoerg } 932*e038c9c4Sjoerg } 933*e038c9c4Sjoerg} 934*e038c9c4Sjoerg 935*e038c9c4Sjoergforeach AS = [ConstantAS] in { 936*e038c9c4Sjoerg def : Builtin<"vload_half", [Float, Size, PointerType<ConstType<Half>, AS>]>; 937*e038c9c4Sjoerg def : Builtin<"vloada_half", [Float, Size, PointerType<ConstType<Half>, AS>]>; 938*e038c9c4Sjoerg foreach VSize = [2, 3, 4, 8, 16] in { 939*e038c9c4Sjoerg foreach name = ["vload_half" # VSize] in { 940*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, VSize>, Size, PointerType<ConstType<Half>, AS>]>; 941*e038c9c4Sjoerg } 942*e038c9c4Sjoerg } 943*e038c9c4Sjoerg} 944*e038c9c4Sjoerg 945*e038c9c4Sjoerg// OpenCL v3.0 s6.15.8 - Synchronization Functions. 946*e038c9c4Sjoergdef : Builtin<"barrier", [Void, MemFenceFlags], Attr.Convergent>; 947*e038c9c4Sjoerglet MinVersion = CL20 in { 948*e038c9c4Sjoerg def : Builtin<"work_group_barrier", [Void, MemFenceFlags], Attr.Convergent>; 949*e038c9c4Sjoerg def : Builtin<"work_group_barrier", [Void, MemFenceFlags, MemoryScope], Attr.Convergent>; 950*e038c9c4Sjoerg} 951*e038c9c4Sjoerg 952*e038c9c4Sjoerg// OpenCL v3.0 s6.15.9 - Legacy Explicit Memory Fence Functions. 953*e038c9c4Sjoergdef : Builtin<"mem_fence", [Void, MemFenceFlags]>; 954*e038c9c4Sjoergdef : Builtin<"read_mem_fence", [Void, MemFenceFlags]>; 955*e038c9c4Sjoergdef : Builtin<"write_mem_fence", [Void, MemFenceFlags]>; 956*e038c9c4Sjoerg 957*e038c9c4Sjoerg// OpenCL v3.0 s6.15.10 - Address Space Qualifier Functions. 958*e038c9c4Sjoerg// to_global, to_local, to_private are declared in Builtins.def. 959*e038c9c4Sjoerg 960*e038c9c4Sjoerglet MinVersion = CL20 in { 961*e038c9c4Sjoerg // The OpenCL 3.0 specification defines these with a "gentype" argument indicating any builtin 962*e038c9c4Sjoerg // type or user-defined type, which cannot be represented currently. Hence we slightly diverge 963*e038c9c4Sjoerg // by providing only the following overloads with a void pointer. 964*e038c9c4Sjoerg def : Builtin<"get_fence", [MemFenceFlags, PointerType<Void, GenericAS>]>; 965*e038c9c4Sjoerg def : Builtin<"get_fence", [MemFenceFlags, PointerType<ConstType<Void>, GenericAS>]>; 966*e038c9c4Sjoerg} 9677330f729Sjoerg 9687330f729Sjoerg//-------------------------------------------------------------------- 9697330f729Sjoerg// OpenCL v1.1 s6.11.10, v1.2 s6.12.10, v2.0 s6.13.10: Async Copies from Global to Local Memory, Local to Global Memory, and Prefetch 9707330f729Sjoerg// OpenCL Extension v2.0 s5.1.7 and s6.1.7: Async Copies from Global to Local Memory, Local to Global Memory, and Prefetch 9717330f729Sjoerg// --- Table 18 --- 9727330f729Sjoergforeach name = ["async_work_group_copy"] in { 9737330f729Sjoerg def : Builtin<name, [Event, PointerType<AGenTypeN, LocalAS>, PointerType<ConstType<AGenTypeN>, GlobalAS>, Size, Event]>; 9747330f729Sjoerg def : Builtin<name, [Event, PointerType<AGenTypeN, GlobalAS>, PointerType<ConstType<AGenTypeN>, LocalAS>, Size, Event]>; 9757330f729Sjoerg} 9767330f729Sjoergforeach name = ["async_work_group_strided_copy"] in { 9777330f729Sjoerg def : Builtin<name, [Event, PointerType<AGenTypeN, LocalAS>, PointerType<ConstType<AGenTypeN>, GlobalAS>, Size, Size, Event]>; 9787330f729Sjoerg def : Builtin<name, [Event, PointerType<AGenTypeN, GlobalAS>, PointerType<ConstType<AGenTypeN>, LocalAS>, Size, Size, Event]>; 9797330f729Sjoerg} 9807330f729Sjoergforeach name = ["wait_group_events"] in { 9817330f729Sjoerg def : Builtin<name, [Void, Int, PointerType<Event, GenericAS>]>; 9827330f729Sjoerg} 9837330f729Sjoergforeach name = ["prefetch"] in { 9847330f729Sjoerg def : Builtin<name, [Void, PointerType<ConstType<AGenTypeN>, GlobalAS>, Size]>; 9857330f729Sjoerg} 9867330f729Sjoerg 9877330f729Sjoerg//-------------------------------------------------------------------- 9887330f729Sjoerg// OpenCL v2.0 s6.13.11 - Atomics Functions. 9897330f729Sjoerg// Functions that use memory_order and cl_mem_fence_flags enums are not 9907330f729Sjoerg// declared here as the TableGen backend does not handle enums. 9917330f729Sjoerg 992*e038c9c4Sjoerg// OpenCL v1.0 s9.5, s9.6, s9.7 - Atomic Functions for 32-bit integers 9937330f729Sjoerg// --- Table 9.1 --- 994*e038c9c4Sjoerglet Extension = FuncExtKhrGlobalInt32BaseAtomics in { 9957330f729Sjoerg foreach Type = [Int, UInt] in { 9967330f729Sjoerg foreach name = ["atom_add", "atom_sub", "atom_xchg"] in { 9977330f729Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, GlobalAS>, Type]>; 9987330f729Sjoerg } 9997330f729Sjoerg foreach name = ["atom_inc", "atom_dec"] in { 10007330f729Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, GlobalAS>]>; 10017330f729Sjoerg } 10027330f729Sjoerg foreach name = ["atom_cmpxchg"] in { 10037330f729Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, GlobalAS>, Type, Type]>; 10047330f729Sjoerg } 10057330f729Sjoerg } 1006*e038c9c4Sjoerg} 1007*e038c9c4Sjoerg// --- Table 9.3 --- 1008*e038c9c4Sjoerglet Extension = FuncExtKhrLocalInt32BaseAtomics in { 1009*e038c9c4Sjoerg foreach Type = [Int, UInt] in { 1010*e038c9c4Sjoerg foreach name = ["atom_add", "atom_sub", "atom_xchg"] in { 1011*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, LocalAS>, Type]>; 1012*e038c9c4Sjoerg } 1013*e038c9c4Sjoerg foreach name = ["atom_inc", "atom_dec"] in { 1014*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, LocalAS>]>; 1015*e038c9c4Sjoerg } 1016*e038c9c4Sjoerg foreach name = ["atom_cmpxchg"] in { 1017*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, LocalAS>, Type, Type]>; 1018*e038c9c4Sjoerg } 1019*e038c9c4Sjoerg } 1020*e038c9c4Sjoerg} 1021*e038c9c4Sjoerg// --- Table 9.5 --- 1022*e038c9c4Sjoerglet Extension = FuncExtKhrInt64BaseAtomics in { 1023*e038c9c4Sjoerg foreach AS = [GlobalAS, LocalAS] in { 1024*e038c9c4Sjoerg foreach Type = [Long, ULong] in { 1025*e038c9c4Sjoerg foreach name = ["atom_add", "atom_sub", "atom_xchg"] in { 1026*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, AS>, Type]>; 1027*e038c9c4Sjoerg } 1028*e038c9c4Sjoerg foreach name = ["atom_inc", "atom_dec"] in { 1029*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, AS>]>; 1030*e038c9c4Sjoerg } 1031*e038c9c4Sjoerg foreach name = ["atom_cmpxchg"] in { 1032*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, AS>, Type, Type]>; 1033*e038c9c4Sjoerg } 1034*e038c9c4Sjoerg } 1035*e038c9c4Sjoerg } 1036*e038c9c4Sjoerg} 1037*e038c9c4Sjoerg// --- Table 9.2 --- 1038*e038c9c4Sjoerglet Extension = FuncExtKhrGlobalInt32ExtendedAtomics in { 1039*e038c9c4Sjoerg foreach Type = [Int, UInt] in { 1040*e038c9c4Sjoerg foreach name = ["atom_min", "atom_max", "atom_and", 1041*e038c9c4Sjoerg "atom_or", "atom_xor"] in { 1042*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, GlobalAS>, Type]>; 1043*e038c9c4Sjoerg } 1044*e038c9c4Sjoerg } 1045*e038c9c4Sjoerg} 1046*e038c9c4Sjoerg// --- Table 9.4 --- 1047*e038c9c4Sjoerglet Extension = FuncExtKhrLocalInt32ExtendedAtomics in { 1048*e038c9c4Sjoerg foreach Type = [Int, UInt] in { 1049*e038c9c4Sjoerg foreach name = ["atom_min", "atom_max", "atom_and", 1050*e038c9c4Sjoerg "atom_or", "atom_xor"] in { 1051*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, LocalAS>, Type]>; 1052*e038c9c4Sjoerg } 1053*e038c9c4Sjoerg } 1054*e038c9c4Sjoerg} 1055*e038c9c4Sjoerg// --- Table 9.6 --- 1056*e038c9c4Sjoerglet Extension = FuncExtKhrInt64ExtendedAtomics in { 1057*e038c9c4Sjoerg foreach AS = [GlobalAS, LocalAS] in { 1058*e038c9c4Sjoerg foreach Type = [Long, ULong] in { 1059*e038c9c4Sjoerg foreach name = ["atom_min", "atom_max", "atom_and", 1060*e038c9c4Sjoerg "atom_or", "atom_xor"] in { 1061*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, AS>, Type]>; 1062*e038c9c4Sjoerg } 1063*e038c9c4Sjoerg } 1064*e038c9c4Sjoerg } 1065*e038c9c4Sjoerg} 1066*e038c9c4Sjoerg// OpenCL v1.1 s6.11.1, v1.2 s6.12.11 - Atomic Functions 1067*e038c9c4Sjoergforeach AS = [GlobalAS, LocalAS] in { 1068*e038c9c4Sjoerg def : Builtin<"atomic_xchg", [Float, PointerType<VolatileType<Float>, AS>, Float]>; 1069*e038c9c4Sjoerg foreach Type = [Int, UInt] in { 1070*e038c9c4Sjoerg foreach name = ["atomic_add", "atomic_sub", "atomic_xchg", 1071*e038c9c4Sjoerg "atomic_min", "atomic_max", "atomic_and", 1072*e038c9c4Sjoerg "atomic_or", "atomic_xor"] in { 1073*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, AS>, Type]>; 1074*e038c9c4Sjoerg } 1075*e038c9c4Sjoerg foreach name = ["atomic_inc", "atomic_dec"] in { 1076*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, AS>]>; 1077*e038c9c4Sjoerg } 1078*e038c9c4Sjoerg foreach name = ["atomic_cmpxchg"] in { 1079*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, AS>, Type, Type]>; 1080*e038c9c4Sjoerg } 1081*e038c9c4Sjoerg } 10827330f729Sjoerg} 10837330f729Sjoerg 1084*e038c9c4Sjoerglet Extension = FuncExtOpenCLCxx in { 1085*e038c9c4Sjoerg foreach Type = [Int, UInt] in { 1086*e038c9c4Sjoerg foreach name = ["atomic_add", "atomic_sub", "atomic_xchg", 1087*e038c9c4Sjoerg "atomic_min", "atomic_max", "atomic_and", 1088*e038c9c4Sjoerg "atomic_or", "atomic_xor"] in { 1089*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, GenericAS>, Type]>; 1090*e038c9c4Sjoerg } 1091*e038c9c4Sjoerg foreach name = ["atomic_inc", "atomic_dec"] in { 1092*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, GenericAS>]>; 1093*e038c9c4Sjoerg } 1094*e038c9c4Sjoerg foreach name = ["atomic_cmpxchg"] in { 1095*e038c9c4Sjoerg def : Builtin<name, [Type, PointerType<VolatileType<Type>, GenericAS>, Type, Type]>; 1096*e038c9c4Sjoerg } 1097*e038c9c4Sjoerg } 10987330f729Sjoerg} 10997330f729Sjoerg 1100*e038c9c4Sjoerg// OpenCL v2.0 s6.13.11 - Atomic Functions. 1101*e038c9c4Sjoerglet MinVersion = CL20 in { 1102*e038c9c4Sjoerg def : Builtin<"atomic_work_item_fence", [Void, MemFenceFlags, MemoryOrder, MemoryScope]>; 1103*e038c9c4Sjoerg 1104*e038c9c4Sjoerg foreach TypePair = [[AtomicInt, Int], [AtomicUInt, UInt], 1105*e038c9c4Sjoerg [AtomicLong, Long], [AtomicULong, ULong], 1106*e038c9c4Sjoerg [AtomicFloat, Float], [AtomicDouble, Double]] in { 1107*e038c9c4Sjoerg def : Builtin<"atomic_init", 1108*e038c9c4Sjoerg [Void, PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[1]]>; 1109*e038c9c4Sjoerg def : Builtin<"atomic_store", 1110*e038c9c4Sjoerg [Void, PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[1]]>; 1111*e038c9c4Sjoerg def : Builtin<"atomic_store_explicit", 1112*e038c9c4Sjoerg [Void, PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[1], MemoryOrder]>; 1113*e038c9c4Sjoerg def : Builtin<"atomic_store_explicit", 1114*e038c9c4Sjoerg [Void, PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[1], MemoryOrder, MemoryScope]>; 1115*e038c9c4Sjoerg def : Builtin<"atomic_load", 1116*e038c9c4Sjoerg [TypePair[1], PointerType<VolatileType<TypePair[0]>, GenericAS>]>; 1117*e038c9c4Sjoerg def : Builtin<"atomic_load_explicit", 1118*e038c9c4Sjoerg [TypePair[1], PointerType<VolatileType<TypePair[0]>, GenericAS>, MemoryOrder]>; 1119*e038c9c4Sjoerg def : Builtin<"atomic_load_explicit", 1120*e038c9c4Sjoerg [TypePair[1], PointerType<VolatileType<TypePair[0]>, GenericAS>, MemoryOrder, MemoryScope]>; 1121*e038c9c4Sjoerg def : Builtin<"atomic_exchange", 1122*e038c9c4Sjoerg [TypePair[1], PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[1]]>; 1123*e038c9c4Sjoerg def : Builtin<"atomic_exchange_explicit", 1124*e038c9c4Sjoerg [TypePair[1], PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[1], MemoryOrder]>; 1125*e038c9c4Sjoerg def : Builtin<"atomic_exchange_explicit", 1126*e038c9c4Sjoerg [TypePair[1], PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[1], MemoryOrder, MemoryScope]>; 1127*e038c9c4Sjoerg foreach Variant = ["weak", "strong"] in { 1128*e038c9c4Sjoerg def : Builtin<"atomic_compare_exchange_" # Variant, 1129*e038c9c4Sjoerg [Bool, PointerType<VolatileType<TypePair[0]>, GenericAS>, 1130*e038c9c4Sjoerg PointerType<TypePair[1], GenericAS>, TypePair[1]]>; 1131*e038c9c4Sjoerg def : Builtin<"atomic_compare_exchange_" # Variant # "_explicit", 1132*e038c9c4Sjoerg [Bool, PointerType<VolatileType<TypePair[0]>, GenericAS>, 1133*e038c9c4Sjoerg PointerType<TypePair[1], GenericAS>, TypePair[1], MemoryOrder, MemoryOrder]>; 1134*e038c9c4Sjoerg def : Builtin<"atomic_compare_exchange_" # Variant # "_explicit", 1135*e038c9c4Sjoerg [Bool, PointerType<VolatileType<TypePair[0]>, GenericAS>, 1136*e038c9c4Sjoerg PointerType<TypePair[1], GenericAS>, TypePair[1], MemoryOrder, MemoryOrder, MemoryScope]>; 1137*e038c9c4Sjoerg } 11387330f729Sjoerg } 11397330f729Sjoerg 1140*e038c9c4Sjoerg foreach TypePair = [[AtomicInt, Int, Int], [AtomicUInt, UInt, UInt], 1141*e038c9c4Sjoerg [AtomicLong, Long, Long], [AtomicULong, ULong, ULong], 1142*e038c9c4Sjoerg [AtomicUIntPtr, UIntPtr, PtrDiff]] in { 1143*e038c9c4Sjoerg foreach ModOp = ["add", "sub"] in { 1144*e038c9c4Sjoerg def : Builtin<"atomic_fetch_" # ModOp, 1145*e038c9c4Sjoerg [TypePair[1], PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[2]]>; 1146*e038c9c4Sjoerg def : Builtin<"atomic_fetch_" # ModOp # "_explicit", 1147*e038c9c4Sjoerg [TypePair[1], PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[2], MemoryOrder]>; 1148*e038c9c4Sjoerg def : Builtin<"atomic_fetch_" # ModOp # "_explicit", 1149*e038c9c4Sjoerg [TypePair[1], PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[2], MemoryOrder, MemoryScope]>; 1150*e038c9c4Sjoerg } 1151*e038c9c4Sjoerg } 1152*e038c9c4Sjoerg foreach TypePair = [[AtomicInt, Int, Int], [AtomicUInt, UInt, UInt], 1153*e038c9c4Sjoerg [AtomicLong, Long, Long], [AtomicULong, ULong, ULong]] in { 1154*e038c9c4Sjoerg foreach ModOp = ["or", "xor", "and", "min", "max"] in { 1155*e038c9c4Sjoerg def : Builtin<"atomic_fetch_" # ModOp, 1156*e038c9c4Sjoerg [TypePair[1], PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[2]]>; 1157*e038c9c4Sjoerg def : Builtin<"atomic_fetch_" # ModOp # "_explicit", 1158*e038c9c4Sjoerg [TypePair[1], PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[2], MemoryOrder]>; 1159*e038c9c4Sjoerg def : Builtin<"atomic_fetch_" # ModOp # "_explicit", 1160*e038c9c4Sjoerg [TypePair[1], PointerType<VolatileType<TypePair[0]>, GenericAS>, TypePair[2], MemoryOrder, MemoryScope]>; 1161*e038c9c4Sjoerg } 1162*e038c9c4Sjoerg } 1163*e038c9c4Sjoerg 1164*e038c9c4Sjoerg def : Builtin<"atomic_flag_clear", 1165*e038c9c4Sjoerg [Void, PointerType<VolatileType<AtomicFlag>, GenericAS>]>; 1166*e038c9c4Sjoerg def : Builtin<"atomic_flag_clear_explicit", 1167*e038c9c4Sjoerg [Void, PointerType<VolatileType<AtomicFlag>, GenericAS>, MemoryOrder]>; 1168*e038c9c4Sjoerg def : Builtin<"atomic_flag_clear_explicit", 1169*e038c9c4Sjoerg [Void, PointerType<VolatileType<AtomicFlag>, GenericAS>, MemoryOrder, MemoryScope]>; 1170*e038c9c4Sjoerg 1171*e038c9c4Sjoerg def : Builtin<"atomic_flag_test_and_set", 1172*e038c9c4Sjoerg [Bool, PointerType<VolatileType<AtomicFlag>, GenericAS>]>; 1173*e038c9c4Sjoerg def : Builtin<"atomic_flag_test_and_set_explicit", 1174*e038c9c4Sjoerg [Bool, PointerType<VolatileType<AtomicFlag>, GenericAS>, MemoryOrder]>; 1175*e038c9c4Sjoerg def : Builtin<"atomic_flag_test_and_set_explicit", 1176*e038c9c4Sjoerg [Bool, PointerType<VolatileType<AtomicFlag>, GenericAS>, MemoryOrder, MemoryScope]>; 1177*e038c9c4Sjoerg} 1178*e038c9c4Sjoerg 1179*e038c9c4Sjoerg//-------------------------------------------------------------------- 1180*e038c9c4Sjoerg// OpenCL v1.1 s6.11.12, v1.2 s6.12.12, v2.0 s6.13.12 - Miscellaneous Vector Functions 1181*e038c9c4Sjoerg// --- Table 19 --- 1182*e038c9c4Sjoergforeach VSize1 = [2, 4, 8, 16] in { 1183*e038c9c4Sjoerg foreach VSize2 = [2, 4, 8, 16] in { 1184*e038c9c4Sjoerg foreach VecAndMaskType = [[Char, UChar], [UChar, UChar], 1185*e038c9c4Sjoerg [Short, UShort], [UShort, UShort], 1186*e038c9c4Sjoerg [Int, UInt], [UInt, UInt], 1187*e038c9c4Sjoerg [Long, ULong], [ULong, ULong], 1188*e038c9c4Sjoerg [Float, UInt], [Double, ULong], [Half, UShort]] in { 1189*e038c9c4Sjoerg def : Builtin<"shuffle", [VectorType<VecAndMaskType[0], VSize1>, 1190*e038c9c4Sjoerg VectorType<VecAndMaskType[0], VSize2>, 1191*e038c9c4Sjoerg VectorType<VecAndMaskType[1], VSize1>], 1192*e038c9c4Sjoerg Attr.Const>; 1193*e038c9c4Sjoerg } 1194*e038c9c4Sjoerg } 1195*e038c9c4Sjoerg} 1196*e038c9c4Sjoergforeach VSize1 = [2, 4, 8, 16] in { 1197*e038c9c4Sjoerg foreach VSize2 = [2, 4, 8, 16] in { 1198*e038c9c4Sjoerg foreach VecAndMaskType = [[Char, UChar], [UChar, UChar], 1199*e038c9c4Sjoerg [Short, UShort], [UShort, UShort], 1200*e038c9c4Sjoerg [Int, UInt], [UInt, UInt], 1201*e038c9c4Sjoerg [Long, ULong], [ULong, ULong], 1202*e038c9c4Sjoerg [Float, UInt], [Double, ULong], [Half, UShort]] in { 1203*e038c9c4Sjoerg def : Builtin<"shuffle2", [VectorType<VecAndMaskType[0], VSize1>, 1204*e038c9c4Sjoerg VectorType<VecAndMaskType[0], VSize2>, 1205*e038c9c4Sjoerg VectorType<VecAndMaskType[0], VSize2>, 1206*e038c9c4Sjoerg VectorType<VecAndMaskType[1], VSize1>], 1207*e038c9c4Sjoerg Attr.Const>; 1208*e038c9c4Sjoerg } 1209*e038c9c4Sjoerg } 12107330f729Sjoerg} 12117330f729Sjoerg 12127330f729Sjoerg//-------------------------------------------------------------------- 12137330f729Sjoerg// OpenCL v1.1 s6.11.3, v1.2 s6.12.14, v2.0 s6.13.14: Image Read and Write Functions 12147330f729Sjoerg// OpenCL Extension v2.0 s5.1.8 and s6.1.8: Image Read and Write Functions 12157330f729Sjoerg// --- Table 22: Image Read Functions with Samplers --- 12167330f729Sjoergforeach imgTy = [Image1d] in { 12177330f729Sjoerg foreach coordTy = [Int, Float] in { 1218*e038c9c4Sjoerg def : Builtin<"read_imagef", [VectorType<Float, 4>, ImageType<imgTy, "RO">, Sampler, coordTy], Attr.Pure>; 1219*e038c9c4Sjoerg def : Builtin<"read_imagei", [VectorType<Int, 4>, ImageType<imgTy, "RO">, Sampler, coordTy], Attr.Pure>; 1220*e038c9c4Sjoerg def : Builtin<"read_imageui", [VectorType<UInt, 4>, ImageType<imgTy, "RO">, Sampler, coordTy], Attr.Pure>; 12217330f729Sjoerg } 12227330f729Sjoerg} 12237330f729Sjoergforeach imgTy = [Image2d, Image1dArray] in { 12247330f729Sjoerg foreach coordTy = [Int, Float] in { 1225*e038c9c4Sjoerg def : Builtin<"read_imagef", [VectorType<Float, 4>, ImageType<imgTy, "RO">, Sampler, VectorType<coordTy, 2>], Attr.Pure>; 1226*e038c9c4Sjoerg def : Builtin<"read_imagei", [VectorType<Int, 4>, ImageType<imgTy, "RO">, Sampler, VectorType<coordTy, 2>], Attr.Pure>; 1227*e038c9c4Sjoerg def : Builtin<"read_imageui", [VectorType<UInt, 4>, ImageType<imgTy, "RO">, Sampler, VectorType<coordTy, 2>], Attr.Pure>; 12287330f729Sjoerg } 12297330f729Sjoerg} 12307330f729Sjoergforeach imgTy = [Image3d, Image2dArray] in { 12317330f729Sjoerg foreach coordTy = [Int, Float] in { 1232*e038c9c4Sjoerg def : Builtin<"read_imagef", [VectorType<Float, 4>, ImageType<imgTy, "RO">, Sampler, VectorType<coordTy, 4>], Attr.Pure>; 1233*e038c9c4Sjoerg def : Builtin<"read_imagei", [VectorType<Int, 4>, ImageType<imgTy, "RO">, Sampler, VectorType<coordTy, 4>], Attr.Pure>; 1234*e038c9c4Sjoerg def : Builtin<"read_imageui", [VectorType<UInt, 4>, ImageType<imgTy, "RO">, Sampler, VectorType<coordTy, 4>], Attr.Pure>; 12357330f729Sjoerg } 12367330f729Sjoerg} 12377330f729Sjoergforeach coordTy = [Int, Float] in { 1238*e038c9c4Sjoerg def : Builtin<"read_imagef", [Float, ImageType<Image2dDepth, "RO">, Sampler, VectorType<coordTy, 2>], Attr.Pure>; 1239*e038c9c4Sjoerg def : Builtin<"read_imagef", [Float, ImageType<Image2dArrayDepth, "RO">, Sampler, VectorType<coordTy, 4>], Attr.Pure>; 12407330f729Sjoerg} 12417330f729Sjoerg 12427330f729Sjoerg// --- Table 23: Sampler-less Read Functions --- 1243*e038c9c4Sjoerglet MinVersion = CL12 in { 12447330f729Sjoerg foreach aQual = ["RO", "RW"] in { 12457330f729Sjoerg foreach imgTy = [Image2d, Image1dArray] in { 1246*e038c9c4Sjoerg def : Builtin<"read_imagef", [VectorType<Float, 4>, ImageType<imgTy, aQual>, VectorType<Int, 2>], Attr.Pure>; 1247*e038c9c4Sjoerg def : Builtin<"read_imagei", [VectorType<Int, 4>, ImageType<imgTy, aQual>, VectorType<Int, 2>], Attr.Pure>; 1248*e038c9c4Sjoerg def : Builtin<"read_imageui", [VectorType<UInt, 4>, ImageType<imgTy, aQual>, VectorType<Int, 2>], Attr.Pure>; 12497330f729Sjoerg } 12507330f729Sjoerg foreach imgTy = [Image3d, Image2dArray] in { 1251*e038c9c4Sjoerg def : Builtin<"read_imagef", [VectorType<Float, 4>, ImageType<imgTy, aQual>, VectorType<Int, 4>], Attr.Pure>; 1252*e038c9c4Sjoerg def : Builtin<"read_imagei", [VectorType<Int, 4>, ImageType<imgTy, aQual>, VectorType<Int, 4>], Attr.Pure>; 1253*e038c9c4Sjoerg def : Builtin<"read_imageui", [VectorType<UInt, 4>, ImageType<imgTy, aQual>, VectorType<Int, 4>], Attr.Pure>; 12547330f729Sjoerg } 12557330f729Sjoerg foreach imgTy = [Image1d, Image1dBuffer] in { 1256*e038c9c4Sjoerg def : Builtin<"read_imagef", [VectorType<Float, 4>, ImageType<imgTy, aQual>, Int], Attr.Pure>; 1257*e038c9c4Sjoerg def : Builtin<"read_imagei", [VectorType<Int, 4>, ImageType<imgTy, aQual>, Int], Attr.Pure>; 1258*e038c9c4Sjoerg def : Builtin<"read_imageui", [VectorType<UInt, 4>, ImageType<imgTy, aQual>, Int], Attr.Pure>; 12597330f729Sjoerg } 1260*e038c9c4Sjoerg def : Builtin<"read_imagef", [Float, ImageType<Image2dDepth, aQual>, VectorType<Int, 2>], Attr.Pure>; 1261*e038c9c4Sjoerg def : Builtin<"read_imagef", [Float, ImageType<Image2dArrayDepth, aQual>, VectorType<Int, 4>], Attr.Pure>; 1262*e038c9c4Sjoerg } 12637330f729Sjoerg} 12647330f729Sjoerg 12657330f729Sjoerg// --- Table 24: Image Write Functions --- 12667330f729Sjoergforeach aQual = ["WO", "RW"] in { 12677330f729Sjoerg foreach imgTy = [Image2d] in { 12687330f729Sjoerg def : Builtin<"write_imagef", [Void, ImageType<imgTy, aQual>, VectorType<Int, 2>, VectorType<Float, 4>]>; 12697330f729Sjoerg def : Builtin<"write_imagei", [Void, ImageType<imgTy, aQual>, VectorType<Int, 2>, VectorType<Int, 4>]>; 12707330f729Sjoerg def : Builtin<"write_imageui", [Void, ImageType<imgTy, aQual>, VectorType<Int, 2>, VectorType<UInt, 4>]>; 12717330f729Sjoerg } 12727330f729Sjoerg foreach imgTy = [Image2dArray] in { 12737330f729Sjoerg def : Builtin<"write_imagef", [Void, ImageType<imgTy, aQual>, VectorType<Int, 4>, VectorType<Float, 4>]>; 12747330f729Sjoerg def : Builtin<"write_imagei", [Void, ImageType<imgTy, aQual>, VectorType<Int, 4>, VectorType<Int, 4>]>; 12757330f729Sjoerg def : Builtin<"write_imageui", [Void, ImageType<imgTy, aQual>, VectorType<Int, 4>, VectorType<UInt, 4>]>; 12767330f729Sjoerg } 12777330f729Sjoerg foreach imgTy = [Image1d, Image1dBuffer] in { 12787330f729Sjoerg def : Builtin<"write_imagef", [Void, ImageType<imgTy, aQual>, Int, VectorType<Float, 4>]>; 12797330f729Sjoerg def : Builtin<"write_imagei", [Void, ImageType<imgTy, aQual>, Int, VectorType<Int, 4>]>; 12807330f729Sjoerg def : Builtin<"write_imageui", [Void, ImageType<imgTy, aQual>, Int, VectorType<UInt, 4>]>; 12817330f729Sjoerg } 12827330f729Sjoerg foreach imgTy = [Image1dArray] in { 12837330f729Sjoerg def : Builtin<"write_imagef", [Void, ImageType<imgTy, aQual>, VectorType<Int, 2>, VectorType<Float, 4>]>; 12847330f729Sjoerg def : Builtin<"write_imagei", [Void, ImageType<imgTy, aQual>, VectorType<Int, 2>, VectorType<Int, 4>]>; 12857330f729Sjoerg def : Builtin<"write_imageui", [Void, ImageType<imgTy, aQual>, VectorType<Int, 2>, VectorType<UInt, 4>]>; 12867330f729Sjoerg } 12877330f729Sjoerg foreach imgTy = [Image3d] in { 12887330f729Sjoerg def : Builtin<"write_imagef", [Void, ImageType<imgTy, aQual>, VectorType<Int, 4>, VectorType<Float, 4>]>; 12897330f729Sjoerg def : Builtin<"write_imagei", [Void, ImageType<imgTy, aQual>, VectorType<Int, 4>, VectorType<Int, 4>]>; 12907330f729Sjoerg def : Builtin<"write_imageui", [Void, ImageType<imgTy, aQual>, VectorType<Int, 4>, VectorType<UInt, 4>]>; 12917330f729Sjoerg } 12927330f729Sjoerg def : Builtin<"write_imagef", [Void, ImageType<Image2dDepth, aQual>, VectorType<Int, 2>, Float]>; 12937330f729Sjoerg def : Builtin<"write_imagef", [Void, ImageType<Image2dArrayDepth, aQual>, VectorType<Int, 4>, Float]>; 12947330f729Sjoerg} 12957330f729Sjoerg 12967330f729Sjoerg// --- Table 25: Image Query Functions --- 12977330f729Sjoergforeach aQual = ["RO", "WO", "RW"] in { 12987330f729Sjoerg foreach imgTy = [Image1d, Image1dBuffer, Image2d, Image3d, 12997330f729Sjoerg Image1dArray, Image2dArray, Image2dDepth, 13007330f729Sjoerg Image2dArrayDepth] in { 13017330f729Sjoerg foreach name = ["get_image_width", "get_image_channel_data_type", 13027330f729Sjoerg "get_image_channel_order"] in { 1303*e038c9c4Sjoerg def : Builtin<name, [Int, ImageType<imgTy, aQual>], Attr.Const>; 13047330f729Sjoerg } 13057330f729Sjoerg } 13067330f729Sjoerg foreach imgTy = [Image2d, Image3d, Image2dArray, Image2dDepth, 13077330f729Sjoerg Image2dArrayDepth] in { 1308*e038c9c4Sjoerg def : Builtin<"get_image_height", [Int, ImageType<imgTy, aQual>], Attr.Const>; 13097330f729Sjoerg } 1310*e038c9c4Sjoerg def : Builtin<"get_image_depth", [Int, ImageType<Image3d, aQual>], Attr.Const>; 13117330f729Sjoerg foreach imgTy = [Image2d, Image2dArray, Image2dDepth, 13127330f729Sjoerg Image2dArrayDepth] in { 1313*e038c9c4Sjoerg def : Builtin<"get_image_dim", [VectorType<Int, 2>, ImageType<imgTy, aQual>], Attr.Const>; 13147330f729Sjoerg } 1315*e038c9c4Sjoerg def : Builtin<"get_image_dim", [VectorType<Int, 4>, ImageType<Image3d, aQual>], Attr.Const>; 13167330f729Sjoerg foreach imgTy = [Image1dArray, Image2dArray, Image2dArrayDepth] in { 1317*e038c9c4Sjoerg def : Builtin<"get_image_array_size", [Size, ImageType<imgTy, aQual>], Attr.Const>; 13187330f729Sjoerg } 13197330f729Sjoerg} 13207330f729Sjoerg 13217330f729Sjoerg// OpenCL extension v2.0 s5.1.9: Built-in Image Read Functions 13227330f729Sjoerg// --- Table 8 --- 13237330f729Sjoergforeach aQual = ["RO"] in { 13247330f729Sjoerg foreach name = ["read_imageh"] in { 13257330f729Sjoerg foreach coordTy = [Int, Float] in { 13267330f729Sjoerg foreach imgTy = [Image2d, Image1dArray] in { 1327*e038c9c4Sjoerg def : Builtin<name, [VectorType<Half, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<coordTy, 2>], Attr.Pure>; 13287330f729Sjoerg } 13297330f729Sjoerg foreach imgTy = [Image3d, Image2dArray] in { 1330*e038c9c4Sjoerg def : Builtin<name, [VectorType<Half, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<coordTy, 4>], Attr.Pure>; 13317330f729Sjoerg } 13327330f729Sjoerg foreach imgTy = [Image1d] in { 1333*e038c9c4Sjoerg def : Builtin<name, [VectorType<Half, 4>, ImageType<imgTy, aQual>, Sampler, coordTy], Attr.Pure>; 13347330f729Sjoerg } 13357330f729Sjoerg } 13367330f729Sjoerg } 13377330f729Sjoerg} 13387330f729Sjoerg// OpenCL extension v2.0 s5.1.10: Built-in Image Sampler-less Read Functions 13397330f729Sjoerg// --- Table 9 --- 1340*e038c9c4Sjoerglet MinVersion = CL12 in { 13417330f729Sjoerg foreach aQual = ["RO", "RW"] in { 13427330f729Sjoerg foreach name = ["read_imageh"] in { 13437330f729Sjoerg foreach imgTy = [Image2d, Image1dArray] in { 1344*e038c9c4Sjoerg def : Builtin<name, [VectorType<Half, 4>, ImageType<imgTy, aQual>, VectorType<Int, 2>], Attr.Pure>; 13457330f729Sjoerg } 13467330f729Sjoerg foreach imgTy = [Image3d, Image2dArray] in { 1347*e038c9c4Sjoerg def : Builtin<name, [VectorType<Half, 4>, ImageType<imgTy, aQual>, VectorType<Int, 4>], Attr.Pure>; 13487330f729Sjoerg } 13497330f729Sjoerg foreach imgTy = [Image1d, Image1dBuffer] in { 1350*e038c9c4Sjoerg def : Builtin<name, [VectorType<Half, 4>, ImageType<imgTy, aQual>, Int], Attr.Pure>; 1351*e038c9c4Sjoerg } 13527330f729Sjoerg } 13537330f729Sjoerg } 13547330f729Sjoerg} 13557330f729Sjoerg// OpenCL extension v2.0 s5.1.11: Built-in Image Write Functions 13567330f729Sjoerg// --- Table 10 --- 13577330f729Sjoergforeach aQual = ["WO", "RW"] in { 13587330f729Sjoerg foreach name = ["write_imageh"] in { 13597330f729Sjoerg def : Builtin<name, [Void, ImageType<Image2d, aQual>, VectorType<Int, 2>, VectorType<Half, 4>]>; 13607330f729Sjoerg def : Builtin<name, [Void, ImageType<Image2dArray, aQual>, VectorType<Int, 4>, VectorType<Half, 4>]>; 13617330f729Sjoerg def : Builtin<name, [Void, ImageType<Image1d, aQual>, Int, VectorType<Half, 4>]>; 13627330f729Sjoerg def : Builtin<name, [Void, ImageType<Image1dBuffer, aQual>, Int, VectorType<Half, 4>]>; 13637330f729Sjoerg def : Builtin<name, [Void, ImageType<Image1dArray, aQual>, VectorType<Int, 2>, VectorType<Half, 4>]>; 13647330f729Sjoerg def : Builtin<name, [Void, ImageType<Image3d, aQual>, VectorType<Int, 4>, VectorType<Half, 4>]>; 13657330f729Sjoerg } 13667330f729Sjoerg} 13677330f729Sjoerg 13687330f729Sjoerg 1369*e038c9c4Sjoerg//-------------------------------------------------------------------- 1370*e038c9c4Sjoerg// OpenCL v2.0 s6.13.15 - Work-group Functions 1371*e038c9c4Sjoerg// --- Table 26 --- 13727330f729Sjoerglet MinVersion = CL20 in { 1373*e038c9c4Sjoerg foreach name = ["work_group_all", "work_group_any"] in { 1374*e038c9c4Sjoerg def : Builtin<name, [Int, Int], Attr.Convergent>; 1375*e038c9c4Sjoerg } 1376*e038c9c4Sjoerg foreach name = ["work_group_broadcast"] in { 1377*e038c9c4Sjoerg def : Builtin<name, [IntLongFloatGenType1, IntLongFloatGenType1, Size], Attr.Convergent>; 1378*e038c9c4Sjoerg def : Builtin<name, [IntLongFloatGenType1, IntLongFloatGenType1, Size, Size], Attr.Convergent>; 1379*e038c9c4Sjoerg def : Builtin<name, [IntLongFloatGenType1, IntLongFloatGenType1, Size, Size, Size], Attr.Convergent>; 1380*e038c9c4Sjoerg } 1381*e038c9c4Sjoerg foreach op = ["add", "min", "max"] in { 1382*e038c9c4Sjoerg foreach name = ["work_group_reduce_", "work_group_scan_exclusive_", 1383*e038c9c4Sjoerg "work_group_scan_inclusive_"] in { 1384*e038c9c4Sjoerg def : Builtin<name # op, [IntLongFloatGenType1, IntLongFloatGenType1], Attr.Convergent>; 1385*e038c9c4Sjoerg } 1386*e038c9c4Sjoerg } 1387*e038c9c4Sjoerg} 1388*e038c9c4Sjoerg 1389*e038c9c4Sjoerg 1390*e038c9c4Sjoerg//-------------------------------------------------------------------- 1391*e038c9c4Sjoerg// OpenCL2.0 : 6.13.16 : Pipe Functions 1392*e038c9c4Sjoerg// --- Table 27 --- 1393*e038c9c4Sjoerg// Defined in Builtins.def 1394*e038c9c4Sjoerg 1395*e038c9c4Sjoerg// --- Table 28 --- 1396*e038c9c4Sjoerg// Builtins taking pipe arguments are defined in Builtins.def 1397*e038c9c4Sjoergdef : Builtin<"is_valid_reserve_id", [Bool, ReserveId]>; 1398*e038c9c4Sjoerg 1399*e038c9c4Sjoerg// --- Table 29 --- 1400*e038c9c4Sjoerg// Defined in Builtins.def 1401*e038c9c4Sjoerg 1402*e038c9c4Sjoerg 1403*e038c9c4Sjoerg//-------------------------------------------------------------------- 1404*e038c9c4Sjoerg// OpenCL2.0 : 6.13.17 : Enqueuing Kernels 1405*e038c9c4Sjoerg// --- Table 30 --- 1406*e038c9c4Sjoerg// Defined in Builtins.def 1407*e038c9c4Sjoerg 1408*e038c9c4Sjoerg// --- Table 32 --- 1409*e038c9c4Sjoerg// Defined in Builtins.def 1410*e038c9c4Sjoerg 1411*e038c9c4Sjoerg// --- Table 33 --- 1412*e038c9c4Sjoerglet MinVersion = CL20 in { 1413*e038c9c4Sjoerg def : Builtin<"enqueue_marker", 1414*e038c9c4Sjoerg [Int, Queue, UInt, PointerType<ConstType<ClkEvent>, GenericAS>, PointerType<ClkEvent, GenericAS>]>; 1415*e038c9c4Sjoerg 1416*e038c9c4Sjoerg // --- Table 34 --- 1417*e038c9c4Sjoerg def : Builtin<"retain_event", [Void, ClkEvent]>; 1418*e038c9c4Sjoerg def : Builtin<"release_event", [Void, ClkEvent]>; 1419*e038c9c4Sjoerg def : Builtin<"create_user_event", [ClkEvent]>; 1420*e038c9c4Sjoerg def : Builtin<"is_valid_event", [Bool, ClkEvent]>; 1421*e038c9c4Sjoerg def : Builtin<"set_user_event_status", [Void, ClkEvent, Int]>; 1422*e038c9c4Sjoerg def : Builtin<"capture_event_profiling_info", 1423*e038c9c4Sjoerg [Void, ClkEvent, ClkProfilingInfo, PointerType<Void, GlobalAS>]>; 1424*e038c9c4Sjoerg 1425*e038c9c4Sjoerg // --- Table 35 --- 1426*e038c9c4Sjoerg def : Builtin<"get_default_queue", [Queue]>; 1427*e038c9c4Sjoerg 1428*e038c9c4Sjoerg def : Builtin<"ndrange_1D", [NDRange, Size]>; 1429*e038c9c4Sjoerg def : Builtin<"ndrange_1D", [NDRange, Size, Size]>; 1430*e038c9c4Sjoerg def : Builtin<"ndrange_1D", [NDRange, Size, Size, Size]>; 1431*e038c9c4Sjoerg def : Builtin<"ndrange_2D", [NDRange, PointerType<ConstType<Size>, PrivateAS>]>; 1432*e038c9c4Sjoerg def : Builtin<"ndrange_2D", [NDRange, PointerType<ConstType<Size>, PrivateAS>, 1433*e038c9c4Sjoerg PointerType<ConstType<Size>, PrivateAS>]>; 1434*e038c9c4Sjoerg def : Builtin<"ndrange_2D", [NDRange, PointerType<ConstType<Size>, PrivateAS>, 1435*e038c9c4Sjoerg PointerType<ConstType<Size>, PrivateAS>, 1436*e038c9c4Sjoerg PointerType<ConstType<Size>, PrivateAS>]>; 1437*e038c9c4Sjoerg def : Builtin<"ndrange_3D", [NDRange, PointerType<ConstType<Size>, PrivateAS>]>; 1438*e038c9c4Sjoerg def : Builtin<"ndrange_3D", [NDRange, PointerType<ConstType<Size>, PrivateAS>, 1439*e038c9c4Sjoerg PointerType<ConstType<Size>, PrivateAS>]>; 1440*e038c9c4Sjoerg def : Builtin<"ndrange_3D", [NDRange, PointerType<ConstType<Size>, PrivateAS>, 1441*e038c9c4Sjoerg PointerType<ConstType<Size>, PrivateAS>, 1442*e038c9c4Sjoerg PointerType<ConstType<Size>, PrivateAS>]>; 1443*e038c9c4Sjoerg} 1444*e038c9c4Sjoerg 1445*e038c9c4Sjoerg 1446*e038c9c4Sjoerg//-------------------------------------------------------------------- 1447*e038c9c4Sjoerg// End of the builtin functions defined in the OpenCL C specification. 1448*e038c9c4Sjoerg// Builtin functions defined in the OpenCL C Extension are below. 1449*e038c9c4Sjoerg//-------------------------------------------------------------------- 1450*e038c9c4Sjoerg 1451*e038c9c4Sjoerg 1452*e038c9c4Sjoerg// OpenCL Extension v2.0 s9.18 - Mipmaps 1453*e038c9c4Sjoerglet Extension = FuncExtKhrMipmapImage in { 1454*e038c9c4Sjoerg // Added to section 6.13.14.2. 1455*e038c9c4Sjoerg foreach aQual = ["RO"] in { 1456*e038c9c4Sjoerg foreach imgTy = [Image2d] in { 1457*e038c9c4Sjoerg foreach name = ["read_imagef"] in { 1458*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, Float], Attr.Pure>; 1459*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, VectorType<Float, 2>, VectorType<Float, 2>], Attr.Pure>; 1460*e038c9c4Sjoerg } 1461*e038c9c4Sjoerg foreach name = ["read_imagei"] in { 1462*e038c9c4Sjoerg def : Builtin<name, [VectorType<Int, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, Float], Attr.Pure>; 1463*e038c9c4Sjoerg def : Builtin<name, [VectorType<Int, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, VectorType<Float, 2>, VectorType<Float, 2>], Attr.Pure>; 1464*e038c9c4Sjoerg } 1465*e038c9c4Sjoerg foreach name = ["read_imageui"] in { 1466*e038c9c4Sjoerg def : Builtin<name, [VectorType<UInt, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, Float], Attr.Pure>; 1467*e038c9c4Sjoerg def : Builtin<name, [VectorType<UInt, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, VectorType<Float, 2>, VectorType<Float, 2>], Attr.Pure>; 1468*e038c9c4Sjoerg } 1469*e038c9c4Sjoerg } 1470*e038c9c4Sjoerg foreach imgTy = [Image2dDepth] in { 1471*e038c9c4Sjoerg foreach name = ["read_imagef"] in { 1472*e038c9c4Sjoerg def : Builtin<name, [Float, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, Float], Attr.Pure>; 1473*e038c9c4Sjoerg def : Builtin<name, [Float, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, VectorType<Float, 2>, VectorType<Float, 2>], Attr.Pure>; 1474*e038c9c4Sjoerg } 1475*e038c9c4Sjoerg } 1476*e038c9c4Sjoerg foreach imgTy = [Image1d] in { 1477*e038c9c4Sjoerg foreach name = ["read_imagef"] in { 1478*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, 4>, ImageType<imgTy, aQual>, Sampler, Float, Float], Attr.Pure>; 1479*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, 4>, ImageType<imgTy, aQual>, Sampler, Float, Float, Float], Attr.Pure>; 1480*e038c9c4Sjoerg } 1481*e038c9c4Sjoerg foreach name = ["read_imagei"] in { 1482*e038c9c4Sjoerg def : Builtin<name, [VectorType<Int, 4>, ImageType<imgTy, aQual>, Sampler, Float, Float], Attr.Pure>; 1483*e038c9c4Sjoerg def : Builtin<name, [VectorType<Int, 4>, ImageType<imgTy, aQual>, Sampler, Float, Float, Float], Attr.Pure>; 1484*e038c9c4Sjoerg } 1485*e038c9c4Sjoerg foreach name = ["read_imageui"] in { 1486*e038c9c4Sjoerg def : Builtin<name, [VectorType<UInt, 4>, ImageType<imgTy, aQual>, Sampler, Float, Float], Attr.Pure>; 1487*e038c9c4Sjoerg def : Builtin<name, [VectorType<UInt, 4>, ImageType<imgTy, aQual>, Sampler, Float, Float, Float], Attr.Pure>; 1488*e038c9c4Sjoerg } 1489*e038c9c4Sjoerg } 1490*e038c9c4Sjoerg foreach imgTy = [Image3d] in { 1491*e038c9c4Sjoerg foreach name = ["read_imagef"] in { 1492*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, VectorType<Float, 4>, VectorType<Float, 4>], Attr.Pure>; 1493*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, Float], Attr.Pure>; 1494*e038c9c4Sjoerg } 1495*e038c9c4Sjoerg foreach name = ["read_imagei"] in { 1496*e038c9c4Sjoerg def : Builtin<name, [VectorType<Int, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, VectorType<Float, 4>, VectorType<Float, 4>], Attr.Pure>; 1497*e038c9c4Sjoerg def : Builtin<name, [VectorType<Int, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, Float], Attr.Pure>; 1498*e038c9c4Sjoerg } 1499*e038c9c4Sjoerg foreach name = ["read_imageui"] in { 1500*e038c9c4Sjoerg def : Builtin<name, [VectorType<UInt, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, VectorType<Float, 4>, VectorType<Float, 4>], Attr.Pure>; 1501*e038c9c4Sjoerg def : Builtin<name, [VectorType<UInt, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, Float], Attr.Pure>; 1502*e038c9c4Sjoerg } 1503*e038c9c4Sjoerg } 1504*e038c9c4Sjoerg foreach imgTy = [Image1dArray] in { 1505*e038c9c4Sjoerg foreach name = ["read_imagef"] in { 1506*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, Float], Attr.Pure>; 1507*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, Float, Float], Attr.Pure>; 1508*e038c9c4Sjoerg } 1509*e038c9c4Sjoerg foreach name = ["read_imagei"] in { 1510*e038c9c4Sjoerg def : Builtin<name, [VectorType<Int, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, Float], Attr.Pure>; 1511*e038c9c4Sjoerg def : Builtin<name, [VectorType<Int, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, Float, Float], Attr.Pure>; 1512*e038c9c4Sjoerg } 1513*e038c9c4Sjoerg foreach name = ["read_imageui"] in { 1514*e038c9c4Sjoerg def : Builtin<name, [VectorType<UInt, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, Float], Attr.Pure>; 1515*e038c9c4Sjoerg def : Builtin<name, [VectorType<UInt, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 2>, Float, Float], Attr.Pure>; 1516*e038c9c4Sjoerg } 1517*e038c9c4Sjoerg } 1518*e038c9c4Sjoerg foreach imgTy = [Image2dArray] in { 1519*e038c9c4Sjoerg foreach name = ["read_imagef"] in { 1520*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, Float], Attr.Pure>; 1521*e038c9c4Sjoerg def : Builtin<name, [VectorType<Float, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, VectorType<Float, 2>, VectorType<Float, 2>], Attr.Pure>; 1522*e038c9c4Sjoerg } 1523*e038c9c4Sjoerg foreach name = ["read_imagei"] in { 1524*e038c9c4Sjoerg def : Builtin<name, [VectorType<Int, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, Float], Attr.Pure>; 1525*e038c9c4Sjoerg def : Builtin<name, [VectorType<Int, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, VectorType<Float, 2>, VectorType<Float, 2>], Attr.Pure>; 1526*e038c9c4Sjoerg } 1527*e038c9c4Sjoerg foreach name = ["read_imageui"] in { 1528*e038c9c4Sjoerg def : Builtin<name, [VectorType<UInt, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, Float], Attr.Pure>; 1529*e038c9c4Sjoerg def : Builtin<name, [VectorType<UInt, 4>, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, VectorType<Float, 2>, VectorType<Float, 2>], Attr.Pure>; 1530*e038c9c4Sjoerg } 1531*e038c9c4Sjoerg } 1532*e038c9c4Sjoerg foreach imgTy = [Image2dArrayDepth] in { 1533*e038c9c4Sjoerg foreach name = ["read_imagef"] in { 1534*e038c9c4Sjoerg def : Builtin<name, [Float, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, Float], Attr.Pure>; 1535*e038c9c4Sjoerg def : Builtin<name, [Float, ImageType<imgTy, aQual>, Sampler, VectorType<Float, 4>, VectorType<Float, 2>, VectorType<Float, 2>], Attr.Pure>; 1536*e038c9c4Sjoerg } 1537*e038c9c4Sjoerg } 1538*e038c9c4Sjoerg } 1539*e038c9c4Sjoerg // Added to section 6.13.14.5 1540*e038c9c4Sjoerg foreach aQual = ["RO", "WO", "RW"] in { 1541*e038c9c4Sjoerg foreach imgTy = [Image1d, Image2d, Image3d, Image1dArray, Image2dArray, Image2dDepth, Image2dArrayDepth] in { 1542*e038c9c4Sjoerg def : Builtin<"get_image_num_mip_levels", [Int, ImageType<imgTy, aQual>]>; 1543*e038c9c4Sjoerg } 1544*e038c9c4Sjoerg } 1545*e038c9c4Sjoerg} 1546*e038c9c4Sjoerg 1547*e038c9c4Sjoerg// Write functions are enabled using a separate extension. 1548*e038c9c4Sjoerglet Extension = FuncExtKhrMipmapImageWrites in { 1549*e038c9c4Sjoerg // Added to section 6.13.14.4. 1550*e038c9c4Sjoerg foreach aQual = ["WO"] in { 1551*e038c9c4Sjoerg foreach imgTy = [Image2d] in { 1552*e038c9c4Sjoerg def : Builtin<"write_imagef", [Void, ImageType<imgTy, aQual>, VectorType<Int, 2>, Int, VectorType<Float, 4>]>; 1553*e038c9c4Sjoerg def : Builtin<"write_imagei", [Void, ImageType<imgTy, aQual>, VectorType<Int, 2>, Int, VectorType<Int, 4>]>; 1554*e038c9c4Sjoerg def : Builtin<"write_imageui", [Void, ImageType<imgTy, aQual>, VectorType<Int, 2>, Int, VectorType<UInt, 4>]>; 1555*e038c9c4Sjoerg } 1556*e038c9c4Sjoerg def : Builtin<"write_imagef", [Void, ImageType<Image2dDepth, aQual>, VectorType<Int, 2>, Int, Float]>; 1557*e038c9c4Sjoerg foreach imgTy = [Image1d] in { 1558*e038c9c4Sjoerg def : Builtin<"write_imagef", [Void, ImageType<imgTy, aQual>, Int, Int, VectorType<Float, 4>]>; 1559*e038c9c4Sjoerg def : Builtin<"write_imagei", [Void, ImageType<imgTy, aQual>, Int, Int, VectorType<Int, 4>]>; 1560*e038c9c4Sjoerg def : Builtin<"write_imageui", [Void, ImageType<imgTy, aQual>, Int, Int, VectorType<UInt, 4>]>; 1561*e038c9c4Sjoerg } 1562*e038c9c4Sjoerg foreach imgTy = [Image1dArray] in { 1563*e038c9c4Sjoerg def : Builtin<"write_imagef", [Void, ImageType<imgTy, aQual>, VectorType<Int, 2>, Int, VectorType<Float, 4>]>; 1564*e038c9c4Sjoerg def : Builtin<"write_imagei", [Void, ImageType<imgTy, aQual>, VectorType<Int, 2>, Int, VectorType<Int, 4>]>; 1565*e038c9c4Sjoerg def : Builtin<"write_imageui", [Void, ImageType<imgTy, aQual>, VectorType<Int, 2>, Int, VectorType<UInt, 4>]>; 1566*e038c9c4Sjoerg } 1567*e038c9c4Sjoerg foreach imgTy = [Image2dArray] in { 1568*e038c9c4Sjoerg def : Builtin<"write_imagef", [Void, ImageType<imgTy, aQual>, VectorType<Int, 4>, Int, VectorType<Float, 4>]>; 1569*e038c9c4Sjoerg def : Builtin<"write_imagei", [Void, ImageType<imgTy, aQual>, VectorType<Int, 4>, Int, VectorType<Int, 4>]>; 1570*e038c9c4Sjoerg def : Builtin<"write_imageui", [Void, ImageType<imgTy, aQual>, VectorType<Int, 4>, Int, VectorType<UInt, 4>]>; 1571*e038c9c4Sjoerg } 1572*e038c9c4Sjoerg def : Builtin<"write_imagef", [Void, ImageType<Image2dArrayDepth, aQual>, VectorType<Int, 4>, Int, Float]>; 1573*e038c9c4Sjoerg let Extension = FuncExtKhrMipmapWritesAndWrite3d in { 1574*e038c9c4Sjoerg foreach imgTy = [Image3d] in { 1575*e038c9c4Sjoerg def : Builtin<"write_imagef", [Void, ImageType<imgTy, aQual>, VectorType<Int, 4>, Int, VectorType<Float, 4>]>; 1576*e038c9c4Sjoerg def : Builtin<"write_imagei", [Void, ImageType<imgTy, aQual>, VectorType<Int, 4>, Int, VectorType<Int, 4>]>; 1577*e038c9c4Sjoerg def : Builtin<"write_imageui", [Void, ImageType<imgTy, aQual>, VectorType<Int, 4>, Int, VectorType<UInt, 4>]>; 1578*e038c9c4Sjoerg } 1579*e038c9c4Sjoerg } 1580*e038c9c4Sjoerg } 1581*e038c9c4Sjoerg} 1582*e038c9c4Sjoerg 1583*e038c9c4Sjoerg//-------------------------------------------------------------------- 1584*e038c9c4Sjoerg// OpenCL Extension v2.0 s18.3 - Creating OpenCL Memory Objects from OpenGL MSAA Textures 1585*e038c9c4Sjoerglet Extension = FuncExtKhrGlMsaaSharing in { 1586*e038c9c4Sjoerg // --- Table 6.13.14.3 --- 1587*e038c9c4Sjoerg foreach aQual = ["RO", "RW"] in { 1588*e038c9c4Sjoerg foreach imgTy = [Image2dMsaa] in { 1589*e038c9c4Sjoerg def : Builtin<"read_imagef", [VectorType<Float, 4>, ImageType<imgTy, aQual>, VectorType<Int, 2>, Int], Attr.Pure>; 1590*e038c9c4Sjoerg def : Builtin<"read_imagei", [VectorType<Int, 4>, ImageType<imgTy, aQual>, VectorType<Int, 2>, Int], Attr.Pure>; 1591*e038c9c4Sjoerg def : Builtin<"read_imageui", [VectorType<UInt, 4>, ImageType<imgTy, aQual>, VectorType<Int, 2>, Int], Attr.Pure>; 1592*e038c9c4Sjoerg } 1593*e038c9c4Sjoerg foreach imgTy = [Image2dArrayMsaa] in { 1594*e038c9c4Sjoerg def : Builtin<"read_imagef", [VectorType<Float, 4>, ImageType<imgTy, aQual>, VectorType<Int, 4>, Int], Attr.Pure>; 1595*e038c9c4Sjoerg def : Builtin<"read_imagei", [VectorType<Int, 4>, ImageType<imgTy, aQual>, VectorType<Int, 4>, Int], Attr.Pure>; 1596*e038c9c4Sjoerg def : Builtin<"read_imageui", [VectorType<UInt, 4>, ImageType<imgTy, aQual>, VectorType<Int, 4>, Int], Attr.Pure>; 1597*e038c9c4Sjoerg } 1598*e038c9c4Sjoerg foreach name = ["read_imagef"] in { 1599*e038c9c4Sjoerg def : Builtin<name, [Float, ImageType<Image2dMsaaDepth, aQual>, VectorType<Int, 2>, Int], Attr.Pure>; 1600*e038c9c4Sjoerg def : Builtin<name, [Float, ImageType<Image2dArrayMsaaDepth, aQual>, VectorType<Int, 4>, Int], Attr.Pure>; 1601*e038c9c4Sjoerg } 1602*e038c9c4Sjoerg } 1603*e038c9c4Sjoerg 1604*e038c9c4Sjoerg // --- Table 6.13.14.5 --- 1605*e038c9c4Sjoerg foreach aQual = ["RO", "WO", "RW"] in { 1606*e038c9c4Sjoerg foreach imgTy = [Image2dMsaa, Image2dArrayMsaa, Image2dMsaaDepth, Image2dArrayMsaaDepth] in { 1607*e038c9c4Sjoerg foreach name = ["get_image_width", "get_image_height", 1608*e038c9c4Sjoerg "get_image_channel_data_type", "get_image_channel_order", 1609*e038c9c4Sjoerg "get_image_num_samples"] in { 1610*e038c9c4Sjoerg def : Builtin<name, [Int, ImageType<imgTy, aQual>], Attr.Const>; 1611*e038c9c4Sjoerg } 1612*e038c9c4Sjoerg def : Builtin<"get_image_dim", [VectorType<Int, 2>, ImageType<imgTy, aQual>], Attr.Const>; 1613*e038c9c4Sjoerg } 1614*e038c9c4Sjoerg foreach imgTy = [Image2dArrayMsaa, Image2dArrayMsaaDepth] in { 1615*e038c9c4Sjoerg def : Builtin<"get_image_array_size", [Size, ImageType<imgTy, aQual>], Attr.Const>; 1616*e038c9c4Sjoerg } 1617*e038c9c4Sjoerg } 1618*e038c9c4Sjoerg} 1619*e038c9c4Sjoerg 1620*e038c9c4Sjoerg//-------------------------------------------------------------------- 1621*e038c9c4Sjoerg// OpenCL Extension v2.0 s28 - Subgroups 1622*e038c9c4Sjoerg// --- Table 28.2.1 --- 1623*e038c9c4Sjoerglet Extension = FuncExtKhrSubgroups in { 1624*e038c9c4Sjoerg foreach name = ["get_sub_group_size", "get_max_sub_group_size", 1625*e038c9c4Sjoerg "get_num_sub_groups", "get_sub_group_id", 1626*e038c9c4Sjoerg "get_sub_group_local_id"] in { 1627*e038c9c4Sjoerg def : Builtin<name, [UInt]>; 1628*e038c9c4Sjoerg } 1629*e038c9c4Sjoerg let MinVersion = CL20 in { 1630*e038c9c4Sjoerg foreach name = ["get_enqueued_num_sub_groups"] in { 1631*e038c9c4Sjoerg def : Builtin<name, [UInt]>; 1632*e038c9c4Sjoerg } 1633*e038c9c4Sjoerg } 1634*e038c9c4Sjoerg} 1635*e038c9c4Sjoerg 1636*e038c9c4Sjoerg// --- Table 28.2.2 --- 1637*e038c9c4Sjoerglet Extension = FuncExtKhrSubgroups in { 1638*e038c9c4Sjoerg def : Builtin<"sub_group_barrier", [Void, MemFenceFlags], Attr.Convergent>; 1639*e038c9c4Sjoerg def : Builtin<"sub_group_barrier", [Void, MemFenceFlags, MemoryScope], Attr.Convergent>; 1640*e038c9c4Sjoerg} 1641*e038c9c4Sjoerg 1642*e038c9c4Sjoerg// --- Table 28.2.4 --- 1643*e038c9c4Sjoerglet Extension = FuncExtKhrSubgroups in { 1644*e038c9c4Sjoerg foreach name = ["sub_group_all", "sub_group_any"] in { 1645*e038c9c4Sjoerg def : Builtin<name, [Int, Int], Attr.Convergent>; 1646*e038c9c4Sjoerg } 1647*e038c9c4Sjoerg foreach name = ["sub_group_broadcast"] in { 1648*e038c9c4Sjoerg def : Builtin<name, [IntLongFloatGenType1, IntLongFloatGenType1, UInt], Attr.Convergent>; 1649*e038c9c4Sjoerg } 1650*e038c9c4Sjoerg foreach name = ["sub_group_reduce_", "sub_group_scan_exclusive_", 1651*e038c9c4Sjoerg "sub_group_scan_inclusive_"] in { 1652*e038c9c4Sjoerg foreach op = ["add", "min", "max"] in { 1653*e038c9c4Sjoerg def : Builtin<name # op, [IntLongFloatGenType1, IntLongFloatGenType1], Attr.Convergent>; 1654*e038c9c4Sjoerg } 1655*e038c9c4Sjoerg } 1656*e038c9c4Sjoerg} 1657*e038c9c4Sjoerg 1658*e038c9c4Sjoerg// OpenCL Extension v3.0 s38 - Extended Subgroup Functions 1659*e038c9c4Sjoerg 1660*e038c9c4Sjoerg// Section 38.4.1 - cl_khr_subgroup_extended_types 1661*e038c9c4Sjoerglet Extension = FuncExtKhrSubgroupExtendedTypes in { 1662*e038c9c4Sjoerg // For sub_group_broadcast, add scalar char, uchar, short, and ushort support, 1663*e038c9c4Sjoerg def : Builtin<"sub_group_broadcast", [CharShortGenType1, CharShortGenType1, UInt], Attr.Convergent>; 1664*e038c9c4Sjoerg // gentype may additionally be one of the supported built-in vector data types. 1665*e038c9c4Sjoerg def : Builtin<"sub_group_broadcast", [AGenTypeNNoScalar, AGenTypeNNoScalar, UInt], Attr.Convergent>; 1666*e038c9c4Sjoerg 1667*e038c9c4Sjoerg foreach name = ["sub_group_reduce_", "sub_group_scan_exclusive_", 1668*e038c9c4Sjoerg "sub_group_scan_inclusive_"] in { 1669*e038c9c4Sjoerg foreach op = ["add", "min", "max"] in { 1670*e038c9c4Sjoerg def : Builtin<name # op, [CharShortGenType1, CharShortGenType1], Attr.Convergent>; 1671*e038c9c4Sjoerg } 1672*e038c9c4Sjoerg } 1673*e038c9c4Sjoerg} 1674*e038c9c4Sjoerg 1675*e038c9c4Sjoerg// Section 38.5.1 - cl_khr_subgroup_non_uniform_vote 1676*e038c9c4Sjoerglet Extension = FuncExtKhrSubgroupNonUniformVote in { 1677*e038c9c4Sjoerg def : Builtin<"sub_group_elect", [Int]>; 1678*e038c9c4Sjoerg def : Builtin<"sub_group_non_uniform_all", [Int, Int]>; 1679*e038c9c4Sjoerg def : Builtin<"sub_group_non_uniform_any", [Int, Int]>; 1680*e038c9c4Sjoerg def : Builtin<"sub_group_non_uniform_all_equal", [Int, AGenType1]>; 1681*e038c9c4Sjoerg} 1682*e038c9c4Sjoerg 1683*e038c9c4Sjoerg// Section 38.6.1 - cl_khr_subgroup_ballot 1684*e038c9c4Sjoerglet Extension = FuncExtKhrSubgroupBallot in { 1685*e038c9c4Sjoerg def : Builtin<"sub_group_non_uniform_broadcast", [AGenTypeN, AGenTypeN, UInt]>; 1686*e038c9c4Sjoerg def : Builtin<"sub_group_broadcast_first", [AGenType1, AGenType1]>; 1687*e038c9c4Sjoerg def : Builtin<"sub_group_ballot", [VectorType<UInt, 4>, Int]>; 1688*e038c9c4Sjoerg def : Builtin<"sub_group_inverse_ballot", [Int, VectorType<UInt, 4>], Attr.Const>; 1689*e038c9c4Sjoerg def : Builtin<"sub_group_ballot_bit_extract", [Int, VectorType<UInt, 4>, UInt], Attr.Const>; 1690*e038c9c4Sjoerg def : Builtin<"sub_group_ballot_bit_count", [UInt, VectorType<UInt, 4>], Attr.Const>; 1691*e038c9c4Sjoerg def : Builtin<"sub_group_ballot_inclusive_scan", [UInt, VectorType<UInt, 4>]>; 1692*e038c9c4Sjoerg def : Builtin<"sub_group_ballot_exclusive_scan", [UInt, VectorType<UInt, 4>]>; 1693*e038c9c4Sjoerg def : Builtin<"sub_group_ballot_find_lsb", [UInt, VectorType<UInt, 4>]>; 1694*e038c9c4Sjoerg def : Builtin<"sub_group_ballot_find_msb", [UInt, VectorType<UInt, 4>]>; 1695*e038c9c4Sjoerg 1696*e038c9c4Sjoerg foreach op = ["eq", "ge", "gt", "le", "lt"] in { 1697*e038c9c4Sjoerg def : Builtin<"get_sub_group_" # op # "_mask", [VectorType<UInt, 4>], Attr.Const>; 1698*e038c9c4Sjoerg } 1699*e038c9c4Sjoerg} 1700*e038c9c4Sjoerg 1701*e038c9c4Sjoerg// Section 38.7.1 - cl_khr_subgroup_non_uniform_arithmetic 1702*e038c9c4Sjoerglet Extension = FuncExtKhrSubgroupNonUniformArithmetic in { 1703*e038c9c4Sjoerg foreach name = ["reduce_", "scan_exclusive_", "scan_inclusive_"] in { 1704*e038c9c4Sjoerg foreach op = ["add", "min", "max", "mul"] in { 1705*e038c9c4Sjoerg def : Builtin<"sub_group_non_uniform_" # name # op, [AGenType1, AGenType1]>; 1706*e038c9c4Sjoerg } 1707*e038c9c4Sjoerg foreach op = ["and", "or", "xor"] in { 1708*e038c9c4Sjoerg def : Builtin<"sub_group_non_uniform_" # name # op, [AIGenType1, AIGenType1]>; 1709*e038c9c4Sjoerg } 1710*e038c9c4Sjoerg foreach op = ["and", "or", "xor"] in { 1711*e038c9c4Sjoerg def : Builtin<"sub_group_non_uniform_" # name # "logical_" # op, [Int, Int]>; 1712*e038c9c4Sjoerg } 1713*e038c9c4Sjoerg } 1714*e038c9c4Sjoerg} 1715*e038c9c4Sjoerg 1716*e038c9c4Sjoerg// Section 38.8.1 - cl_khr_subgroup_shuffle 1717*e038c9c4Sjoerglet Extension = FuncExtKhrSubgroupShuffle in { 1718*e038c9c4Sjoerg def : Builtin<"sub_group_shuffle", [AGenType1, AGenType1, UInt]>; 1719*e038c9c4Sjoerg def : Builtin<"sub_group_shuffle_xor", [AGenType1, AGenType1, UInt]>; 1720*e038c9c4Sjoerg} 1721*e038c9c4Sjoerg 1722*e038c9c4Sjoerg// Section 38.9.1 - cl_khr_subgroup_shuffle_relative 1723*e038c9c4Sjoerglet Extension = FuncExtKhrSubgroupShuffleRelative in { 1724*e038c9c4Sjoerg def : Builtin<"sub_group_shuffle_up", [AGenType1, AGenType1, UInt]>; 1725*e038c9c4Sjoerg def : Builtin<"sub_group_shuffle_down", [AGenType1, AGenType1, UInt]>; 1726*e038c9c4Sjoerg} 1727*e038c9c4Sjoerg 1728*e038c9c4Sjoerg// Section 38.10.1 - cl_khr_subgroup_clustered_reduce 1729*e038c9c4Sjoerglet Extension = FuncExtKhrSubgroupClusteredReduce in { 1730*e038c9c4Sjoerg foreach op = ["add", "min", "max", "mul"] in { 1731*e038c9c4Sjoerg def : Builtin<"sub_group_clustered_reduce_" # op, [AGenType1, AGenType1, UInt]>; 1732*e038c9c4Sjoerg } 1733*e038c9c4Sjoerg foreach op = ["and", "or", "xor"] in { 1734*e038c9c4Sjoerg def : Builtin<"sub_group_clustered_reduce_" # op, [AIGenType1, AIGenType1, UInt]>; 1735*e038c9c4Sjoerg } 1736*e038c9c4Sjoerg foreach op = ["and", "or", "xor"] in { 1737*e038c9c4Sjoerg def : Builtin<"sub_group_clustered_reduce_logical_" # op, [Int, Int, UInt]>; 1738*e038c9c4Sjoerg } 1739*e038c9c4Sjoerg} 1740*e038c9c4Sjoerg 1741*e038c9c4Sjoerg//-------------------------------------------------------------------- 1742*e038c9c4Sjoerg// Arm extensions. 1743*e038c9c4Sjoerglet Extension = ArmIntegerDotProductInt8 in { 1744*e038c9c4Sjoerg foreach name = ["arm_dot"] in { 1745*e038c9c4Sjoerg def : Builtin<name, [UInt, VectorType<UChar, 4>, VectorType<UChar, 4>]>; 1746*e038c9c4Sjoerg def : Builtin<name, [Int, VectorType<Char, 4>, VectorType<Char, 4>]>; 1747*e038c9c4Sjoerg } 1748*e038c9c4Sjoerg} 1749*e038c9c4Sjoerglet Extension = ArmIntegerDotProductAccumulateInt8 in { 1750*e038c9c4Sjoerg foreach name = ["arm_dot_acc"] in { 1751*e038c9c4Sjoerg def : Builtin<name, [UInt, VectorType<UChar, 4>, VectorType<UChar, 4>, UInt]>; 1752*e038c9c4Sjoerg def : Builtin<name, [Int, VectorType<Char, 4>, VectorType<Char, 4>, Int]>; 1753*e038c9c4Sjoerg } 1754*e038c9c4Sjoerg} 1755*e038c9c4Sjoerglet Extension = ArmIntegerDotProductAccumulateInt16 in { 1756*e038c9c4Sjoerg foreach name = ["arm_dot_acc"] in { 1757*e038c9c4Sjoerg def : Builtin<name, [UInt, VectorType<UShort, 2>, VectorType<UShort, 2>, UInt]>; 1758*e038c9c4Sjoerg def : Builtin<name, [Int, VectorType<Short, 2>, VectorType<Short, 2>, Int]>; 1759*e038c9c4Sjoerg } 1760*e038c9c4Sjoerg} 1761*e038c9c4Sjoerglet Extension = ArmIntegerDotProductAccumulateSaturateInt8 in { 1762*e038c9c4Sjoerg foreach name = ["arm_dot_acc_sat"] in { 1763*e038c9c4Sjoerg def : Builtin<name, [UInt, VectorType<UChar, 4>, VectorType<UChar, 4>, UInt]>; 1764*e038c9c4Sjoerg def : Builtin<name, [Int, VectorType<Char, 4>, VectorType<Char, 4>, Int]>; 17657330f729Sjoerg } 17667330f729Sjoerg} 1767