Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
a32cf397
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
a32cf397
编写于
9月 26, 2006
作者:
A
Andi Kleen
提交者:
Andi Kleen
9月 26, 2006
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[PATCH] i386: Get ebp from unwinder state when continuing fallback backtrace
Cc: jbeulich@novell.com Signed-off-by:
N
Andi Kleen
<
ak@suse.de
>
上级
950fee84
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
17 addition
and
8 deletion
+17
-8
arch/i386/kernel/traps.c
arch/i386/kernel/traps.c
+14
-8
include/asm-i386/unwind.h
include/asm-i386/unwind.h
+3
-0
未找到文件。
arch/i386/kernel/traps.c
浏览文件 @
a32cf397
...
...
@@ -171,7 +171,7 @@ void dump_trace(struct task_struct *task, struct pt_regs *regs,
unsigned
long
*
stack
,
struct
stacktrace_ops
*
ops
,
void
*
data
)
{
unsigned
long
ebp
;
unsigned
long
ebp
=
0
;
if
(
!
task
)
task
=
current
;
...
...
@@ -199,6 +199,7 @@ void dump_trace(struct task_struct *task, struct pt_regs *regs,
stack
=
(
void
*
)
UNW_SP
(
&
info
);
if
(
!
stack
)
return
;
ebp
=
UNW_FP
(
&
info
);
}
else
ops
->
warning
(
data
,
"Full inexact backtrace again:
\n
"
);
}
else
if
(
call_trace
>=
1
)
...
...
@@ -207,13 +208,16 @@ void dump_trace(struct task_struct *task, struct pt_regs *regs,
ops
->
warning
(
data
,
"Full inexact backtrace again:
\n
"
);
}
else
ops
->
warning
(
data
,
"Inexact backtrace:
\n
"
);
}
else
if
(
!
stack
)
{
}
if
(
!
stack
)
{
unsigned
long
dummy
;
stack
=
&
dummy
;
if
(
task
&&
task
!=
current
)
stack
=
(
unsigned
long
*
)
task
->
thread
.
esp
;
}
#ifdef CONFIG_FRAME_POINTER
if
(
!
ebp
)
{
if
(
task
==
current
)
{
/* Grab ebp right from our regs */
asm
(
"movl %%ebp, %0"
:
"=r"
(
ebp
)
:
);
...
...
@@ -221,6 +225,8 @@ void dump_trace(struct task_struct *task, struct pt_regs *regs,
/* ebp is the last reg pushed by switch_to */
ebp
=
*
(
unsigned
long
*
)
task
->
thread
.
esp
;
}
}
#endif
while
(
1
)
{
struct
thread_info
*
context
;
...
...
include/asm-i386/unwind.h
浏览文件 @
a32cf397
...
...
@@ -28,6 +28,8 @@ struct unwind_frame_info
#define FRAME_LINK_OFFSET 0
#define STACK_BOTTOM(tsk) STACK_LIMIT((tsk)->thread.esp0)
#define STACK_TOP(tsk) ((tsk)->thread.esp0)
#else
#define UNW_FP(frame) ((void)(frame), 0)
#endif
#define STACK_LIMIT(ptr) (((ptr) - 1) & ~(THREAD_SIZE - 1))
...
...
@@ -88,6 +90,7 @@ static inline int arch_unw_user_mode(const struct unwind_frame_info *info)
#define UNW_PC(frame) ((void)(frame), 0)
#define UNW_SP(frame) ((void)(frame), 0)
#define UNW_FP(frame) ((void)(frame), 0)
static
inline
int
arch_unw_user_mode
(
const
void
*
info
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录