Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
23439b16
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
23439b16
编写于
11月 04, 2020
作者:
C
Chen Weihang
提交者:
GitHub
11月 04, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
show cpp stack when catch signal (#28415)
上级
3c95acc3
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
13 addition
and
8 deletion
+13
-8
paddle/fluid/platform/init.cc
paddle/fluid/platform/init.cc
+13
-8
未找到文件。
paddle/fluid/platform/init.cc
浏览文件 @
23439b16
...
@@ -287,7 +287,7 @@ void SignalHandle(const char *data, int size) {
...
@@ -287,7 +287,7 @@ void SignalHandle(const char *data, int size) {
// NOTE2: we only deal with the time info ane signal info,
// NOTE2: we only deal with the time info ane signal info,
// the stack trace will generated by paddle self
// the stack trace will generated by paddle self
if
(
StartsWith
(
data
,
"*** Aborted at"
))
{
if
(
StartsWith
(
data
,
"*** Aborted at"
))
{
*
signal_msg_dunmer_ptr
<<
" [TimeInfo: "
<<
std
::
string
(
data
,
size
-
1
)
*
signal_msg_dunmer_ptr
<<
"
\n
[TimeInfo: "
<<
std
::
string
(
data
,
size
-
1
)
<<
"]
\n
"
;
<<
"]
\n
"
;
}
else
if
(
StartsWith
(
data
,
"***"
))
{
}
else
if
(
StartsWith
(
data
,
"***"
))
{
std
::
string
signal_info
(
data
,
size
-
1
);
std
::
string
signal_info
(
data
,
size
-
1
);
...
@@ -295,14 +295,19 @@ void SignalHandle(const char *data, int size) {
...
@@ -295,14 +295,19 @@ void SignalHandle(const char *data, int size) {
size_t
start_pos
=
signal_info
.
rfind
(
useless_substr
);
size_t
start_pos
=
signal_info
.
rfind
(
useless_substr
);
signal_info
.
replace
(
start_pos
,
useless_substr
.
length
(),
""
);
signal_info
.
replace
(
start_pos
,
useless_substr
.
length
(),
""
);
*
signal_msg_dunmer_ptr
<<
" [SignalInfo: "
<<
signal_info
<<
"]
\n
"
;
*
signal_msg_dunmer_ptr
<<
" [SignalInfo: "
<<
signal_info
<<
"]
\n
"
;
// NOTE3: Here does not throw an exception,
// NOTE3: Final singal error message print.
// Here does not throw an exception,
// otherwise it will casue "terminate called recursively"
// otherwise it will casue "terminate called recursively"
auto
exp
=
platform
::
EnforceNotMet
(
std
::
ostringstream
sout
;
platform
::
errors
::
Fatal
(
sout
<<
platform
::
GetCurrentTraceBackString
();
"A serious error (%s) is detected by the operating system."
,
sout
<<
"
\n
----------------------
\n
Error Message "
ParseSignalErrorString
(
signal_info
)),
"Summary:
\n
----------------------
\n
"
;
__FILE__
,
__LINE__
);
sout
<<
platform
::
errors
::
Fatal
(
std
::
cout
<<
exp
.
what
()
<<
(
*
signal_msg_dunmer_ptr
).
str
()
<<
std
::
endl
;
"`%s` is detected by the operating system."
,
ParseSignalErrorString
(
signal_info
))
.
to_string
();
std
::
cout
<<
sout
.
str
()
<<
(
*
signal_msg_dunmer_ptr
).
str
()
<<
std
::
endl
;
}
}
}
catch
(...)
{
}
catch
(...)
{
// Since the program has already triggered a system error,
// Since the program has already triggered a system error,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录