Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
magicwindyyd
mindspore
提交
09d5a722
M
mindspore
项目概览
magicwindyyd
/
mindspore
与 Fork 源项目一致
Fork自
MindSpore / mindspore
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
M
mindspore
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
09d5a722
编写于
6月 15, 2020
作者:
L
laiyongqiang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix summary nodes memory reuse refcount
上级
6c26431a
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
28 addition
and
1 deletion
+28
-1
mindspore/ccsrc/pre_activate/mem_reuse/mem_reuse.cc
mindspore/ccsrc/pre_activate/mem_reuse/mem_reuse.cc
+26
-0
mindspore/ccsrc/pre_activate/mem_reuse/mem_reuse.h
mindspore/ccsrc/pre_activate/mem_reuse/mem_reuse.h
+1
-0
mindspore/ccsrc/session/kernel_graph.h
mindspore/ccsrc/session/kernel_graph.h
+1
-1
未找到文件。
mindspore/ccsrc/pre_activate/mem_reuse/mem_reuse.cc
浏览文件 @
09d5a722
...
...
@@ -298,6 +298,31 @@ void MemReuseUtil::SetReuseRefCount() {
}
}
void
MemReuseUtil
::
SetSummaryNodesRefCount
()
{
bool
summary_exist
=
graph_
->
summary_node_exist
();
if
(
!
summary_exist
)
{
return
;
}
auto
summary_nodes
=
graph_
->
summary_nodes
();
if
(
summary_nodes
.
empty
())
{
return
;
}
for
(
auto
&
node_item
:
summary_nodes
)
{
auto
node
=
node_item
.
second
.
first
;
size_t
index
=
IntToSize
(
node_item
.
second
.
second
);
MS_LOG
(
INFO
)
<<
"set summary node's ref count, node: "
<<
node
->
fullname_with_scope
()
<<
" index: "
<<
index
;
if
(
kernel_output_refs_
.
find
(
node
.
get
())
!=
kernel_output_refs_
.
end
())
{
KernelRefCountPtr
kernel_ref
=
kernel_output_refs_
[
node
.
get
()][
index
];
kernel_ref
->
ref_count_
=
kMaxRefCount
;
kernel_ref
->
ref_count_dynamic_use_
=
kMaxRefCount
;
}
else
{
MS_LOG
(
WARNING
)
<<
"can't find summary node's kernel_def "
<<
node
->
fullname_with_scope
();
}
}
}
void
MemReuseUtil
::
SetGraphOutputRefCount
()
{
auto
nodes
=
AnfAlgo
::
GetAllOutput
(
graph_
->
output
(),
{
prim
::
kPrimTupleGetItem
});
for
(
const
auto
&
node
:
nodes
)
{
...
...
@@ -336,6 +361,7 @@ void MemReuseUtil::SetAllInfo(KernelGraph *graph) {
}
SetKernelDefMap
();
SetReuseRefCount
();
SetSummaryNodesRefCount
();
SetWorkSpaceList
();
#ifdef MEM_REUSE_DEBUG
MemReuseChecker
::
GetInstance
().
CheckMemReuseIR
(
total_refs_list_
,
kernel_def_ptr_list_
,
graph
);
...
...
mindspore/ccsrc/pre_activate/mem_reuse/mem_reuse.h
浏览文件 @
09d5a722
...
...
@@ -63,6 +63,7 @@ class MemReuseUtil {
void
SetWkMap
(
const
CNodePtr
&
kernel
,
KernelDef
*
kernel_def_ptr
);
void
SetKernelDefInputs
();
void
SetReuseRefCount
();
void
SetSummaryNodesRefCount
();
// Set the reference count of graph output specially.
void
SetGraphOutputRefCount
();
// Reset the dynamic used reference count by ref_count_.
...
...
mindspore/ccsrc/session/kernel_graph.h
浏览文件 @
09d5a722
...
...
@@ -142,7 +142,7 @@ class KernelGraph : public FuncGraph {
bool
get_output_null
()
{
return
null_output_
;
}
void
set_output_null
(
bool
is_output_null
)
{
null_output_
=
is_output_null
;
}
void
PrintGraphExecuteOrder
()
const
;
std
::
map
<
std
::
string
,
std
::
pair
<
AnfNodePtr
,
int
>>
&
summary_nodes
()
{
return
summary_nodes_
;
}
const
std
::
map
<
std
::
string
,
std
::
pair
<
AnfNodePtr
,
int
>>
&
summary_nodes
()
const
{
return
summary_nodes_
;
}
void
set_summary_nodes
(
const
std
::
map
<
std
::
string
,
std
::
pair
<
AnfNodePtr
,
int
>>
&
nodes
)
{
summary_nodes_
=
nodes
;
}
private:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录