xref: /netbsd-src/external/apache2/llvm/dist/clang/lib/Sema/OpenCLBuiltins.td (revision e038c9c4676b0f19b1b7dd08a940c6ed64a6d5ae)
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