Cycles: OpenCL tweaks
[blender.git] / intern / cycles / kernel / kernel_compat_opencl.h
1 /*
2  * Copyright 2011, Blender Foundation.
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  */
18
19 #ifndef __KERNEL_COMPAT_OPENCL_H__
20 #define __KERNEL_COMPAT_OPENCL_H__
21
22 #define __KERNEL_GPU__
23 #define __KERNEL_OPENCL__
24
25 /* no namespaces in opencl */
26 #define CCL_NAMESPACE_BEGIN
27 #define CCL_NAMESPACE_END
28 #define WITH_OPENCL
29
30 /* in opencl all functions are device functions, so leave this empty */
31 #define __device
32 #define __device_inline
33 #define __device_noinline
34
35 /* no assert in opencl */
36 #define kernel_assert(cond)
37
38 /* manual implementation of interpolated 1D lookup */
39 __device float kernel_tex_interp_(__global float *data, int width, float x)
40 {
41         x = clamp(x, 0.0f, 1.0f)*width;
42
43         int index = min((int)x, width-1);
44         int nindex = min(index+1, width-1);
45         float t = x - index;
46
47         return (1.0f - t)*data[index] + t*data[nindex];
48 }
49
50 /* make_type definitions with opencl style element initializers */
51 #ifdef make_float2
52 #undef make_float2
53 #endif
54 #ifdef make_float3
55 #undef make_float3
56 #endif
57 #ifdef make_float4
58 #undef make_float4
59 #endif
60 #ifdef make_int2
61 #undef make_int2
62 #endif
63 #ifdef make_int3
64 #undef make_int3
65 #endif
66 #ifdef make_int4
67 #undef make_int4
68 #endif
69
70 #define make_float2(x, y) ((float2)(x, y))
71 #define make_float3(x, y, z) ((float3)(x, y, z))
72 #define make_float4(x, y, z, w) ((float4)(x, y, z, w))
73 #define make_int2(x, y) ((int2)(x, y))
74 #define make_int3(x, y, z) ((int3)(x, y, z))
75 #define make_int4(x, y, z, w) ((int4)(x, y, z, w))
76
77 /* math functions */
78 #define __uint_as_float(x) as_float(x)
79 #define __float_as_uint(x) as_uint(x)
80 #define __int_as_float(x) as_float(x)
81 #define __float_as_int(x) as_int(x)
82 #define sqrtf(x) sqrt(((float)x))
83 #define cosf(x) cos(((float)x))
84 #define sinf(x) sin(((float)x))
85 #define powf(x, y) pow(((float)x), ((float)y))
86 #define fabsf(x) fabs(((float)x))
87 #define copysignf(x, y) copysign(((float)x), ((float)y))
88 #define cosf(x) cos(((float)x))
89 #define asinf(x) asin(((float)x))
90 #define acosf(x) acos(((float)x))
91 #define atanf(x) atan(((float)x))
92 #define tanf(x) tan(((float)x))
93 #define logf(x) log(((float)x))
94 #define floorf(x) floor(((float)x))
95 #define expf(x) exp(((float)x))
96 #define hypotf(x, y) hypot(((float)x), ((float)y))
97 #define atan2f(x, y) atan2(((float)x), ((float)y))
98 #define fmaxf(x, y) fmax(((float)x), ((float)y))
99 #define fminf(x, y) fmin(((float)x), ((float)y))
100
101 /* data lookup defines */
102 #define kernel_data (*kg->data)
103 #define kernel_tex_interp(t, x, size) kernel_tex_interp_(kg->t, size, x)
104 #define kernel_tex_fetch(t, index) kg->t[index]
105
106 /* define NULL */
107 #define NULL 0
108
109 #include "util_types.h"
110
111 #endif /* __KERNEL_COMPAT_OPENCL_H__ */
112