1 #ifndef __CL_COMMON_DEFINES_H__
2 #define __CL_COMMON_DEFINES_H__
3 // This file includes defines that are common to both kernel code and
7 // Common defines for Image intrinsics
19 #if (__NV_CL_C_VERSION == __NV_CL_C_VERSION_1_0)
23 CLK_INTENSITY = 0x10B8,
24 CLK_LUMINANCE = 0x10B9
26 #if (__NV_CL_C_VERSION >= __NV_CL_C_VERSION_1_1)
35 typedef enum clk_channel_type {
36 // valid formats for float return types
37 CLK_SNORM_INT8 = 0x10D0, // four channel RGBA unorm8
38 CLK_SNORM_INT16 = 0x10D1, // four channel RGBA unorm16
39 CLK_UNORM_INT8 = 0x10D2, // four channel RGBA unorm8
40 CLK_UNORM_INT16 = 0x10D3, // four channel RGBA unorm16
41 CLK_HALF_FLOAT = 0x10DD, // four channel RGBA half
42 CLK_FLOAT = 0x10DE, // four channel RGBA float
44 #if (__NV_CL_C_VERSION >= __NV_CL_C_VERSION_1_1)
45 CLK_UNORM_SHORT_565 = 0x10D4,
46 CLK_UNORM_SHORT_555 = 0x10D5,
47 CLK_UNORM_INT_101010 = 0x10D6,
50 // valid only for integer return types
51 CLK_SIGNED_INT8 = 0x10D7,
52 CLK_SIGNED_INT16 = 0x10D8,
53 CLK_SIGNED_INT32 = 0x10D9,
54 CLK_UNSIGNED_INT8 = 0x10DA,
55 CLK_UNSIGNED_INT16 = 0x10DB,
56 CLK_UNSIGNED_INT32 = 0x10DC,
59 __CLK_UNORM_INT8888 , // four channel ARGB unorm8
60 __CLK_UNORM_INT8888R, // four channel BGRA unorm8
62 __CLK_VALID_IMAGE_TYPE_COUNT,
63 __CLK_INVALID_IMAGE_TYPE = __CLK_VALID_IMAGE_TYPE_COUNT,
64 __CLK_VALID_IMAGE_TYPE_MASK_BITS = 4, // number of bits required to
65 // represent any image type
66 __CLK_VALID_IMAGE_TYPE_MASK = ( 1 << __CLK_VALID_IMAGE_TYPE_MASK_BITS ) - 1
69 typedef enum clk_sampler_type {
70 __CLK_ADDRESS_BASE = 0,
71 CLK_ADDRESS_NONE = 0 << __CLK_ADDRESS_BASE,
72 CLK_ADDRESS_CLAMP = 1 << __CLK_ADDRESS_BASE,
73 CLK_ADDRESS_CLAMP_TO_EDGE = 2 << __CLK_ADDRESS_BASE,
74 CLK_ADDRESS_REPEAT = 3 << __CLK_ADDRESS_BASE,
75 CLK_ADDRESS_MIRROR = 4 << __CLK_ADDRESS_BASE,
77 #if (__NV_CL_C_VERSION >= __NV_CL_C_VERSION_1_1)
78 CLK_ADDRESS_MIRRORED_REPEAT = CLK_ADDRESS_MIRROR,
80 __CLK_ADDRESS_MASK = CLK_ADDRESS_NONE | CLK_ADDRESS_CLAMP |
81 CLK_ADDRESS_CLAMP_TO_EDGE |
82 CLK_ADDRESS_REPEAT | CLK_ADDRESS_MIRROR,
83 __CLK_ADDRESS_BITS = 3, // number of bits required to
84 // represent address info
86 __CLK_NORMALIZED_BASE = __CLK_ADDRESS_BITS,
87 CLK_NORMALIZED_COORDS_FALSE = 0,
88 CLK_NORMALIZED_COORDS_TRUE = 1 << __CLK_NORMALIZED_BASE,
89 __CLK_NORMALIZED_MASK = CLK_NORMALIZED_COORDS_FALSE |
90 CLK_NORMALIZED_COORDS_TRUE,
91 __CLK_NORMALIZED_BITS = 1, // number of bits required to
92 // represent normalization
94 __CLK_FILTER_BASE = __CLK_NORMALIZED_BASE +
95 __CLK_NORMALIZED_BITS,
96 CLK_FILTER_NEAREST = 0 << __CLK_FILTER_BASE,
97 CLK_FILTER_LINEAR = 1 << __CLK_FILTER_BASE,
98 CLK_FILTER_ANISOTROPIC = 2 << __CLK_FILTER_BASE,
99 __CLK_FILTER_MASK = CLK_FILTER_NEAREST | CLK_FILTER_LINEAR |
100 CLK_FILTER_ANISOTROPIC,
101 __CLK_FILTER_BITS = 2, // number of bits required to
102 // represent address info
104 __CLK_MIP_BASE = __CLK_FILTER_BASE + __CLK_FILTER_BITS,
105 CLK_MIP_NEAREST = 0 << __CLK_MIP_BASE,
106 CLK_MIP_LINEAR = 1 << __CLK_MIP_BASE,
107 CLK_MIP_ANISOTROPIC = 2 << __CLK_MIP_BASE,
108 __CLK_MIP_MASK = CLK_MIP_NEAREST | CLK_MIP_LINEAR |
112 __CLK_SAMPLER_BITS = __CLK_MIP_BASE + __CLK_MIP_BITS,
113 __CLK_SAMPLER_MASK = __CLK_MIP_MASK | __CLK_FILTER_MASK |
114 __CLK_NORMALIZED_MASK | __CLK_ADDRESS_MASK,
116 __CLK_ANISOTROPIC_RATIO_BITS = 5,
117 __CLK_ANISOTROPIC_RATIO_MASK = (int) 0x80000000 >>
118 (__CLK_ANISOTROPIC_RATIO_BITS-1)
121 // Memory synchronization
122 #define CLK_LOCAL_MEM_FENCE (1 << 0)
123 #define CLK_GLOBAL_MEM_FENCE (1 << 1)
125 #endif // __CL_COMMON_DEFINES_H__