Alp Toker | 5f83e47 | 2014-05-31 21:26:09 +0000 | [diff] [blame] | 1 | #ifndef CL_COMMON_DEFINES_H |
| 2 | #define CL_COMMON_DEFINES_H |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 3 | // This file includes defines that are common to both kernel code and |
| 4 | // the NVPTX back-end. |
| 5 | |
| 6 | // |
| 7 | // Common defines for Image intrinsics |
| 8 | // Channel order |
| 9 | enum { |
| 10 | CLK_R = 0x10B0, |
| 11 | CLK_A = 0x10B1, |
| 12 | CLK_RG = 0x10B2, |
| 13 | CLK_RA = 0x10B3, |
| 14 | CLK_RGB = 0x10B4, |
| 15 | CLK_RGBA = 0x10B5, |
| 16 | CLK_BGRA = 0x10B6, |
| 17 | CLK_ARGB = 0x10B7, |
| 18 | |
| 19 | #if (__NV_CL_C_VERSION == __NV_CL_C_VERSION_1_0) |
| 20 | CLK_xRGB = 0x10B7, |
| 21 | #endif |
| 22 | |
| 23 | CLK_INTENSITY = 0x10B8, |
| 24 | CLK_LUMINANCE = 0x10B9 |
| 25 | |
| 26 | #if (__NV_CL_C_VERSION >= __NV_CL_C_VERSION_1_1) |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 27 | , |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 28 | CLK_Rx = 0x10BA, |
| 29 | CLK_RGx = 0x10BB, |
| 30 | CLK_RGBx = 0x10BC |
| 31 | #endif |
| 32 | }; |
| 33 | |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 34 | typedef enum clk_channel_type { |
| 35 | // valid formats for float return types |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 36 | CLK_SNORM_INT8 = 0x10D0, // four channel RGBA unorm8 |
| 37 | CLK_SNORM_INT16 = 0x10D1, // four channel RGBA unorm16 |
| 38 | CLK_UNORM_INT8 = 0x10D2, // four channel RGBA unorm8 |
| 39 | CLK_UNORM_INT16 = 0x10D3, // four channel RGBA unorm16 |
| 40 | CLK_HALF_FLOAT = 0x10DD, // four channel RGBA half |
| 41 | CLK_FLOAT = 0x10DE, // four channel RGBA float |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 42 | |
| 43 | #if (__NV_CL_C_VERSION >= __NV_CL_C_VERSION_1_1) |
| 44 | CLK_UNORM_SHORT_565 = 0x10D4, |
| 45 | CLK_UNORM_SHORT_555 = 0x10D5, |
| 46 | CLK_UNORM_INT_101010 = 0x10D6, |
| 47 | #endif |
| 48 | |
| 49 | // valid only for integer return types |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 50 | CLK_SIGNED_INT8 = 0x10D7, |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 51 | CLK_SIGNED_INT16 = 0x10D8, |
| 52 | CLK_SIGNED_INT32 = 0x10D9, |
| 53 | CLK_UNSIGNED_INT8 = 0x10DA, |
| 54 | CLK_UNSIGNED_INT16 = 0x10DB, |
| 55 | CLK_UNSIGNED_INT32 = 0x10DC, |
| 56 | |
| 57 | // CI SPI for CPU |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 58 | __CLK_UNORM_INT8888, // four channel ARGB unorm8 |
| 59 | __CLK_UNORM_INT8888R, // four channel BGRA unorm8 |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 60 | |
| 61 | __CLK_VALID_IMAGE_TYPE_COUNT, |
| 62 | __CLK_INVALID_IMAGE_TYPE = __CLK_VALID_IMAGE_TYPE_COUNT, |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 63 | __CLK_VALID_IMAGE_TYPE_MASK_BITS = 4, // number of bits required to |
| 64 | // represent any image type |
| 65 | __CLK_VALID_IMAGE_TYPE_MASK = (1 << __CLK_VALID_IMAGE_TYPE_MASK_BITS) - 1 |
| 66 | } clk_channel_type; |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 67 | |
| 68 | typedef enum clk_sampler_type { |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 69 | __CLK_ADDRESS_BASE = 0, |
| 70 | CLK_ADDRESS_NONE = 0 << __CLK_ADDRESS_BASE, |
| 71 | CLK_ADDRESS_CLAMP = 1 << __CLK_ADDRESS_BASE, |
| 72 | CLK_ADDRESS_CLAMP_TO_EDGE = 2 << __CLK_ADDRESS_BASE, |
| 73 | CLK_ADDRESS_REPEAT = 3 << __CLK_ADDRESS_BASE, |
| 74 | CLK_ADDRESS_MIRROR = 4 << __CLK_ADDRESS_BASE, |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 75 | |
| 76 | #if (__NV_CL_C_VERSION >= __NV_CL_C_VERSION_1_1) |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 77 | CLK_ADDRESS_MIRRORED_REPEAT = CLK_ADDRESS_MIRROR, |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 78 | #endif |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 79 | __CLK_ADDRESS_MASK = |
| 80 | CLK_ADDRESS_NONE | CLK_ADDRESS_CLAMP | CLK_ADDRESS_CLAMP_TO_EDGE | |
| 81 | CLK_ADDRESS_REPEAT | CLK_ADDRESS_MIRROR, |
| 82 | __CLK_ADDRESS_BITS = 3, // number of bits required to |
| 83 | // represent address info |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 84 | |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 85 | __CLK_NORMALIZED_BASE = __CLK_ADDRESS_BITS, |
| 86 | CLK_NORMALIZED_COORDS_FALSE = 0, |
| 87 | CLK_NORMALIZED_COORDS_TRUE = 1 << __CLK_NORMALIZED_BASE, |
| 88 | __CLK_NORMALIZED_MASK = |
| 89 | CLK_NORMALIZED_COORDS_FALSE | CLK_NORMALIZED_COORDS_TRUE, |
| 90 | __CLK_NORMALIZED_BITS = 1, // number of bits required to |
| 91 | // represent normalization |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 92 | |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 93 | __CLK_FILTER_BASE = __CLK_NORMALIZED_BASE + __CLK_NORMALIZED_BITS, |
| 94 | CLK_FILTER_NEAREST = 0 << __CLK_FILTER_BASE, |
| 95 | CLK_FILTER_LINEAR = 1 << __CLK_FILTER_BASE, |
| 96 | CLK_FILTER_ANISOTROPIC = 2 << __CLK_FILTER_BASE, |
| 97 | __CLK_FILTER_MASK = |
| 98 | CLK_FILTER_NEAREST | CLK_FILTER_LINEAR | CLK_FILTER_ANISOTROPIC, |
| 99 | __CLK_FILTER_BITS = 2, // number of bits required to |
| 100 | // represent address info |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 101 | |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 102 | __CLK_MIP_BASE = __CLK_FILTER_BASE + __CLK_FILTER_BITS, |
| 103 | CLK_MIP_NEAREST = 0 << __CLK_MIP_BASE, |
| 104 | CLK_MIP_LINEAR = 1 << __CLK_MIP_BASE, |
| 105 | CLK_MIP_ANISOTROPIC = 2 << __CLK_MIP_BASE, |
| 106 | __CLK_MIP_MASK = CLK_MIP_NEAREST | CLK_MIP_LINEAR | CLK_MIP_ANISOTROPIC, |
| 107 | __CLK_MIP_BITS = 2, |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 108 | |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 109 | __CLK_SAMPLER_BITS = __CLK_MIP_BASE + __CLK_MIP_BITS, |
| 110 | __CLK_SAMPLER_MASK = __CLK_MIP_MASK | __CLK_FILTER_MASK | |
| 111 | __CLK_NORMALIZED_MASK | __CLK_ADDRESS_MASK, |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 112 | |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 113 | __CLK_ANISOTROPIC_RATIO_BITS = 5, |
| 114 | __CLK_ANISOTROPIC_RATIO_MASK = |
| 115 | (int) 0x80000000 >> (__CLK_ANISOTROPIC_RATIO_BITS - 1) |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 116 | } clk_sampler_type; |
| 117 | |
| 118 | // Memory synchronization |
Justin Holewinski | 0497ab1 | 2013-03-30 14:29:21 +0000 | [diff] [blame] | 119 | #define CLK_LOCAL_MEM_FENCE (1 << 0) |
| 120 | #define CLK_GLOBAL_MEM_FENCE (1 << 1) |
Justin Holewinski | ae556d3 | 2012-05-04 20:18:50 +0000 | [diff] [blame] | 121 | |
Alp Toker | 5f83e47 | 2014-05-31 21:26:09 +0000 | [diff] [blame] | 122 | #endif // CL_COMMON_DEFINES_H |