Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
s920243400
PaddleDetection
提交
15cc9128
P
PaddleDetection
项目概览
s920243400
/
PaddleDetection
与 Fork 源项目一致
Fork自
PaddlePaddle / PaddleDetection
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleDetection
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
15cc9128
编写于
8月 30, 2018
作者:
F
fengjiayi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix compile error
上级
407ff0bd
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
6 addition
and
6 deletion
+6
-6
paddle/fluid/platform/device_context.cc
paddle/fluid/platform/device_context.cc
+5
-5
paddle/fluid/platform/device_context.h
paddle/fluid/platform/device_context.h
+1
-1
未找到文件。
paddle/fluid/platform/device_context.cc
浏览文件 @
15cc9128
...
@@ -145,9 +145,9 @@ class EigenCudaStreamDevice : public Eigen::StreamInterface {
...
@@ -145,9 +145,9 @@ class EigenCudaStreamDevice : public Eigen::StreamInterface {
class
CudnnHolder
{
class
CudnnHolder
{
public:
public:
CudnnHolder
(
const
cudaStream_t
*
stream
,
const
CUDAPlace
&
place
)
CudnnHolder
(
const
cudaStream_t
*
stream
,
const
CUDAPlace
&
place
)
:
stream_
(
stream
),
place_
(
place
),
workspace_
(
nullptr
),
workspace_len_
(
0
)
{
:
workspace_
(
nullptr
),
workspace_len_
(
0
),
stream_
(
stream
),
place_
(
place
)
{
PADDLE_ENFORCE
(
dynload
::
cudnnCreate
(
&
cudnn_handle_
));
PADDLE_ENFORCE
(
dynload
::
cudnnCreate
(
&
cudnn_handle_
));
PADDLE_ENFORCE
(
dynload
::
cudnnSetStream
(
cudnn_handle_
,
stream_
));
PADDLE_ENFORCE
(
dynload
::
cudnnSetStream
(
cudnn_handle_
,
*
stream_
));
}
}
cudnnHandle_t
get_cudnn_handle
()
const
{
return
cudnn_handle_
;
}
cudnnHandle_t
get_cudnn_handle
()
const
{
return
cudnn_handle_
;
}
...
@@ -157,14 +157,14 @@ class CudnnHolder {
...
@@ -157,14 +157,14 @@ class CudnnHolder {
void
*
new_workspace
=
paddle
::
memory
::
Alloc
(
place_
,
required_len
);
void
*
new_workspace
=
paddle
::
memory
::
Alloc
(
place_
,
required_len
);
if
(
workspace_
!=
nullptr
)
{
if
(
workspace_
!=
nullptr
)
{
// Maybe someone is using the current workspace
// Maybe someone is using the current workspace
PADDLE_ENFORCE
(
cudaStreamSynchronize
(
stream_
));
PADDLE_ENFORCE
(
cudaStreamSynchronize
(
*
stream_
));
PADDLE_ENFORCE
(
cudaGetLastError
());
PADDLE_ENFORCE
(
cudaGetLastError
());
paddle
::
memory
::
Free
(
place_
,
workspace_
);
paddle
::
memory
::
Free
(
place_
,
workspace_
);
}
}
workspace_
=
new_workspace
;
workspace_
=
new_workspace
;
workspace_len_
=
required_len
;
workspace_len_
=
required_len
;
}
}
return
workspace_
return
workspace_
;
}
}
~
CudnnHolder
()
{
PADDLE_ENFORCE
(
dynload
::
cudnnDestroy
(
cudnn_handle_
));
}
~
CudnnHolder
()
{
PADDLE_ENFORCE
(
dynload
::
cudnnDestroy
(
cudnn_handle_
));
}
...
@@ -231,7 +231,7 @@ cudnnHandle_t CUDADeviceContext::cudnn_handle() const {
...
@@ -231,7 +231,7 @@ cudnnHandle_t CUDADeviceContext::cudnn_handle() const {
return
cudnn_holder_
->
get_cudnn_handle
();
return
cudnn_holder_
->
get_cudnn_handle
();
}
}
void
*
cudnn_workspace
(
size_t
required_len
)
const
{
void
*
CUDADeviceContext
::
cudnn_workspace
(
size_t
required_len
)
const
{
return
cudnn_holder_
->
get_workspace
(
required_len
);
return
cudnn_holder_
->
get_workspace
(
required_len
);
}
}
...
...
paddle/fluid/platform/device_context.h
浏览文件 @
15cc9128
...
@@ -69,7 +69,7 @@ struct DefaultDeviceContextType<platform::CPUPlace> {
...
@@ -69,7 +69,7 @@ struct DefaultDeviceContextType<platform::CPUPlace> {
#ifdef PADDLE_WITH_CUDA
#ifdef PADDLE_WITH_CUDA
class
EigenCudaStreamDevice
;
class
EigenCudaStreamDevice
;
class
C
UDNN
Holder
;
class
C
udnn
Holder
;
class
CUDADeviceContext
:
public
DeviceContext
{
class
CUDADeviceContext
:
public
DeviceContext
{
public:
public:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录