fix gpu build error

revert-4814-Add_sequence_project_op
qijun 7 years ago
parent e42cafb24f
commit d4be9730fc

@ -80,26 +80,34 @@ class ExecutorImpl : public Executor {
template <typename T, typename... Args> template <typename T, typename... Args>
std::unique_ptr<T> make_unique(Args&&... args) { std::unique_ptr<T> make_unique(Args&&... args) {
return std::unique_ptr<T>(new T(std::forward<Args>(args)...)); return std::unique_ptr<T>(new T(std::forward<Args>(args)...));
} }
static std::unique_ptr<platform::CPUDeviceContext> g_cpu_device_context = platform::CPUDeviceContext* GetCPUDeviceContext() {
make_unique<platform::CPUDeviceContext>(platform::CPUPlace()); static std::unique_ptr<platform::CPUDeviceContext> g_cpu_device_context =
make_unique<platform::CPUDeviceContext>(platform::CPUPlace());
return g_cpu_device_context.get();
}
#ifndef PADDLE_ONLY_CPU #ifndef PADDLE_ONLY_CPU
static std::unique_ptr<platform::CUDADeviceContext> g_cuda_device_context = platform::CUDADeviceContext* GetCUDADeviceContext() {
make_unique<platform::CUDADeviceContext>(platform::GPUPlace(0)); static std::unique_ptr<platform::CUDADeviceContext> g_cuda_device_context =
make_unique<platform::CUDADeviceContext>(platform::GPUPlace(0));
return g_cuda_device_context.get();
}
#endif #endif
Executor* NewLocalExecutor(const platform::Place& place, Executor* NewLocalExecutor(const platform::Place& place,
const ProgramDesc& pdesc, bool is_linear) { const ProgramDesc& pdesc, bool is_linear) {
platform::DeviceContext* device_context = nullptr; platform::DeviceContext* device_context = nullptr;
if (platform::is_cpu_place(place)) { if (platform::is_cpu_place(place)) {
device_context = g_cpu_device_context.get(); device_context = GetCPUDeviceContext();
} } else if (platform::is_gpu_place(place)) {
#ifndef PADDLE_ONLY_CPU #ifndef PADDLE_ONLY_CPU
else if { device_context = GetCUDADeviceContext();
device_context = g_cuda_device_context.get(); }
#else
PADDLE_THROW("'GPUPlace' is not supported in CPU only device.");
} }
#endif #endif
return new ExecutorImpl(device_context, &pdesc, is_linear); return new ExecutorImpl(device_context, &pdesc, is_linear);

@ -23,4 +23,5 @@ TEST(Executor, Init) {
CPUPlace cpu_place; CPUPlace cpu_place;
Executor* executor = NewLocalExecutor(cpu_place, pdesc, true); Executor* executor = NewLocalExecutor(cpu_place, pdesc, true);
executor->Run(); executor->Run();
delete executor;
} }
Loading…
Cancel
Save