Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
ce70a0b4
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看板
提交
ce70a0b4
编写于
2月 04, 2009
作者:
I
Ingo Molnar
浏览文件
操作
浏览文件
下载
差异文件
Merge branches 'tracing/blktrace', 'tracing/ftrace', 'tracing/urgent' and 'linus' into tracing/core
上级
939b3669
79fb0768
229c4ef8
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
70 addition
and
18 deletion
+70
-18
kernel/trace/Kconfig
kernel/trace/Kconfig
+3
-4
kernel/trace/ftrace.c
kernel/trace/ftrace.c
+5
-0
kernel/trace/trace.c
kernel/trace/trace.c
+55
-10
kernel/trace/trace_boot.c
kernel/trace/trace_boot.c
+7
-4
未找到文件。
kernel/trace/Kconfig
浏览文件 @
ce70a0b4
...
...
@@ -164,9 +164,8 @@ config BOOT_TRACER
representation of the delays during initcalls - but the raw
/debug/tracing/trace text output is readable too.
( Note that tracing self tests can't be enabled if this tracer is
selected, because the self-tests are an initcall as well and that
would invalidate the boot trace. )
You must pass in ftrace=initcall to the kernel command line
to enable this on bootup.
config TRACE_BRANCH_PROFILING
bool "Trace likely/unlikely profiler"
...
...
@@ -326,7 +325,7 @@ config FTRACE_SELFTEST
config FTRACE_STARTUP_TEST
bool "Perform a startup test on ftrace"
depends on TRACING && DEBUG_KERNEL
&& !BOOT_TRACER
depends on TRACING && DEBUG_KERNEL
select FTRACE_SELFTEST
help
This option performs a series of startup tests on ftrace. On bootup
...
...
kernel/trace/ftrace.c
浏览文件 @
ce70a0b4
...
...
@@ -1729,9 +1729,12 @@ static void clear_ftrace_pid(struct pid *pid)
{
struct
task_struct
*
p
;
rcu_read_lock
();
do_each_pid_task
(
pid
,
PIDTYPE_PID
,
p
)
{
clear_tsk_trace_trace
(
p
);
}
while_each_pid_task
(
pid
,
PIDTYPE_PID
,
p
);
rcu_read_unlock
();
put_pid
(
pid
);
}
...
...
@@ -1739,9 +1742,11 @@ static void set_ftrace_pid(struct pid *pid)
{
struct
task_struct
*
p
;
rcu_read_lock
();
do_each_pid_task
(
pid
,
PIDTYPE_PID
,
p
)
{
set_tsk_trace_trace
(
p
);
}
while_each_pid_task
(
pid
,
PIDTYPE_PID
,
p
);
rcu_read_unlock
();
}
static
void
clear_ftrace_pid_task
(
struct
pid
**
pid
)
...
...
kernel/trace/trace.c
浏览文件 @
ce70a0b4
...
...
@@ -53,6 +53,11 @@ unsigned long __read_mostly tracing_thresh;
*/
static
bool
__read_mostly
tracing_selftest_running
;
/*
* If a tracer is running, we do not want to run SELFTEST.
*/
static
bool
__read_mostly
tracing_selftest_disabled
;
/* For tracers that don't implement custom flags */
static
struct
tracer_opt
dummy_tracer_opt
[]
=
{
{
}
...
...
@@ -110,14 +115,19 @@ static cpumask_var_t __read_mostly tracing_buffer_mask;
*/
int
ftrace_dump_on_oops
;
static
int
tracing_set_tracer
(
char
*
buf
);
static
int
tracing_set_tracer
(
const
char
*
buf
);
#define BOOTUP_TRACER_SIZE 100
static
char
bootup_tracer_buf
[
BOOTUP_TRACER_SIZE
]
__initdata
;
static
char
*
default_bootup_tracer
;
static
int
__init
set_ftrace
(
char
*
str
)
{
tracing_set_tracer
(
str
);
strncpy
(
bootup_tracer_buf
,
str
,
BOOTUP_TRACER_SIZE
);
default_bootup_tracer
=
bootup_tracer_buf
;
return
1
;
}
__setup
(
"ftrace"
,
set_ftrace
);
__setup
(
"ftrace
=
"
,
set_ftrace
);
static
int
__init
set_ftrace_dump_on_oops
(
char
*
str
)
{
...
...
@@ -469,7 +479,7 @@ int register_tracer(struct tracer *type)
type
->
flags
->
opts
=
dummy_tracer_opt
;
#ifdef CONFIG_FTRACE_STARTUP_TEST
if
(
type
->
selftest
)
{
if
(
type
->
selftest
&&
!
tracing_selftest_disabled
)
{
struct
tracer
*
saved_tracer
=
current_trace
;
struct
trace_array
*
tr
=
&
global_trace
;
int
i
;
...
...
@@ -511,8 +521,25 @@ int register_tracer(struct tracer *type)
out:
tracing_selftest_running
=
false
;
mutex_unlock
(
&
trace_types_lock
);
lock_kernel
();
if
(
!
ret
&&
default_bootup_tracer
)
{
if
(
!
strncmp
(
default_bootup_tracer
,
type
->
name
,
BOOTUP_TRACER_SIZE
))
{
printk
(
KERN_INFO
"Starting tracer '%s'
\n
"
,
type
->
name
);
/* Do we want this tracer to start on bootup? */
tracing_set_tracer
(
type
->
name
);
default_bootup_tracer
=
NULL
;
/* disable other selftests, since this will break it. */
tracing_selftest_disabled
=
1
;
#ifdef CONFIG_FTRACE_STARTUP_TEST
printk
(
KERN_INFO
"Disabling FTRACE selftests due"
" to running tracer '%s'
\n
"
,
type
->
name
);
#endif
}
}
lock_kernel
();
return
ret
;
}
...
...
@@ -2166,7 +2193,7 @@ tracing_set_trace_read(struct file *filp, char __user *ubuf,
return
simple_read_from_buffer
(
ubuf
,
cnt
,
ppos
,
buf
,
r
);
}
static
int
tracing_set_tracer
(
char
*
buf
)
static
int
tracing_set_tracer
(
c
onst
c
har
*
buf
)
{
struct
trace_array
*
tr
=
&
global_trace
;
struct
tracer
*
t
;
...
...
@@ -3061,12 +3088,9 @@ __init static int tracer_alloc_buffers(void)
trace_init_cmdlines
();
register_tracer
(
&
nop_trace
);
current_trace
=
&
nop_trace
;
#ifdef CONFIG_BOOT_TRACER
register_tracer
(
&
boot_tracer
);
current_trace
=
&
boot_tracer
;
current_trace
->
init
(
&
global_trace
);
#else
current_trace
=
&
nop_trace
;
#endif
/* All seems OK, enable tracing */
tracing_disabled
=
0
;
...
...
@@ -3084,5 +3108,26 @@ __init static int tracer_alloc_buffers(void)
out:
return
ret
;
}
__init
static
int
clear_boot_tracer
(
void
)
{
/*
* The default tracer at boot buffer is an init section.
* This function is called in lateinit. If we did not
* find the boot tracer, then clear it out, to prevent
* later registration from accessing the buffer that is
* about to be freed.
*/
if
(
!
default_bootup_tracer
)
return
0
;
printk
(
KERN_INFO
"ftrace bootup tracer '%s' not registered.
\n
"
,
default_bootup_tracer
);
default_bootup_tracer
=
NULL
;
return
0
;
}
early_initcall
(
tracer_alloc_buffers
);
fs_initcall
(
tracer_init_debugfs
);
late_initcall
(
clear_boot_tracer
);
kernel/trace/trace_boot.c
浏览文件 @
ce70a0b4
...
...
@@ -28,13 +28,13 @@ void start_boot_trace(void)
void
enable_boot_trace
(
void
)
{
if
(
pre_initcalls_finished
)
if
(
boot_trace
&&
pre_initcalls_finished
)
tracing_start_sched_switch_record
();
}
void
disable_boot_trace
(
void
)
{
if
(
pre_initcalls_finished
)
if
(
boot_trace
&&
pre_initcalls_finished
)
tracing_stop_sched_switch_record
();
}
...
...
@@ -43,6 +43,9 @@ static int boot_trace_init(struct trace_array *tr)
int
cpu
;
boot_trace
=
tr
;
if
(
!
tr
)
return
0
;
for_each_cpu
(
cpu
,
cpu_possible_mask
)
tracing_reset
(
tr
,
cpu
);
...
...
@@ -132,7 +135,7 @@ void trace_boot_call(struct boot_trace_call *bt, initcall_t fn)
unsigned
long
irq_flags
;
struct
trace_array
*
tr
=
boot_trace
;
if
(
!
pre_initcalls_finished
)
if
(
!
tr
||
!
pre_initcalls_finished
)
return
;
/* Get its name now since this function could
...
...
@@ -164,7 +167,7 @@ void trace_boot_ret(struct boot_trace_ret *bt, initcall_t fn)
unsigned
long
irq_flags
;
struct
trace_array
*
tr
=
boot_trace
;
if
(
!
pre_initcalls_finished
)
if
(
!
tr
||
!
pre_initcalls_finished
)
return
;
sprint_symbol
(
bt
->
func
,
(
unsigned
long
)
fn
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录