Cycles: Support multithreaded compilation of kernels
[blender.git] / intern / cycles / device / device_intern.h
1 /*
2  * Copyright 2011-2013 Blender Foundation
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 #ifndef __DEVICE_INTERN_H__
18 #define __DEVICE_INTERN_H__
19
20 CCL_NAMESPACE_BEGIN
21
22 class Device;
23
24 Device *device_cpu_create(DeviceInfo& info, Stats &stats, Profiler &profiler, bool background);
25 bool device_opencl_init();
26 Device *device_opencl_create(DeviceInfo& info, Stats &stats, Profiler &profiler, bool background);
27 bool device_opencl_compile_kernel(const vector<string>& parameters);
28 bool device_cuda_init();
29 Device *device_cuda_create(DeviceInfo& info, Stats &stats, Profiler &profiler, bool background);
30 Device *device_network_create(DeviceInfo& info, Stats &stats, Profiler &profiler, const char *address);
31 Device *device_multi_create(DeviceInfo& info, Stats &stats, Profiler &profiler, bool background);
32
33 void device_cpu_info(vector<DeviceInfo>& devices);
34 void device_opencl_info(vector<DeviceInfo>& devices);
35 void device_cuda_info(vector<DeviceInfo>& devices);
36 void device_network_info(vector<DeviceInfo>& devices);
37
38 string device_cpu_capabilities();
39 string device_opencl_capabilities();
40 string device_cuda_capabilities();
41
42 CCL_NAMESPACE_END
43
44 #endif  /* __DEVICE_INTERN_H__ */