Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
2039238b
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
2039238b
编写于
5月 12, 2008
作者:
P
Pekka Paalanen
提交者:
Thomas Gleixner
5月 24, 2008
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
mmiotrace: print overrun counts
Signed-off-by:
N
Pekka Paalanen
<
pq@iki.fi
>
Signed-off-by:
N
Ingo Molnar
<
mingo@elte.hu
>
上级
d0a7e8ca
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
25 addition
and
0 deletion
+25
-0
kernel/trace/trace_mmiotrace.c
kernel/trace/trace_mmiotrace.c
+25
-0
未找到文件。
kernel/trace/trace_mmiotrace.c
浏览文件 @
2039238b
...
@@ -17,11 +17,13 @@ struct header_iter {
...
@@ -17,11 +17,13 @@ struct header_iter {
};
};
static
struct
trace_array
*
mmio_trace_array
;
static
struct
trace_array
*
mmio_trace_array
;
static
bool
overrun_detected
;
static
void
mmio_reset_data
(
struct
trace_array
*
tr
)
static
void
mmio_reset_data
(
struct
trace_array
*
tr
)
{
{
int
cpu
;
int
cpu
;
overrun_detected
=
false
;
tr
->
time_start
=
ftrace_now
(
tr
->
cpu
);
tr
->
time_start
=
ftrace_now
(
tr
->
cpu
);
for_each_online_cpu
(
cpu
)
for_each_online_cpu
(
cpu
)
...
@@ -124,12 +126,34 @@ static void mmio_close(struct trace_iterator *iter)
...
@@ -124,12 +126,34 @@ static void mmio_close(struct trace_iterator *iter)
iter
->
private
=
NULL
;
iter
->
private
=
NULL
;
}
}
static
unsigned
long
count_overruns
(
struct
trace_iterator
*
iter
)
{
int
cpu
;
unsigned
long
cnt
=
0
;
for_each_online_cpu
(
cpu
)
{
cnt
+=
iter
->
overrun
[
cpu
];
iter
->
overrun
[
cpu
]
=
0
;
}
return
cnt
;
}
static
ssize_t
mmio_read
(
struct
trace_iterator
*
iter
,
struct
file
*
filp
,
static
ssize_t
mmio_read
(
struct
trace_iterator
*
iter
,
struct
file
*
filp
,
char
__user
*
ubuf
,
size_t
cnt
,
loff_t
*
ppos
)
char
__user
*
ubuf
,
size_t
cnt
,
loff_t
*
ppos
)
{
{
ssize_t
ret
;
ssize_t
ret
;
struct
header_iter
*
hiter
=
iter
->
private
;
struct
header_iter
*
hiter
=
iter
->
private
;
struct
trace_seq
*
s
=
&
iter
->
seq
;
struct
trace_seq
*
s
=
&
iter
->
seq
;
unsigned
long
n
;
n
=
count_overruns
(
iter
);
if
(
n
)
{
/* XXX: This is later than where events were lost. */
trace_seq_printf
(
s
,
"MARK 0.000000 Lost %lu events.
\n
"
,
n
);
if
(
!
overrun_detected
)
pr_warning
(
"mmiotrace has lost events.
\n
"
);
overrun_detected
=
true
;
goto
print_out
;
}
if
(
!
hiter
)
if
(
!
hiter
)
return
0
;
return
0
;
...
@@ -142,6 +166,7 @@ static ssize_t mmio_read(struct trace_iterator *iter, struct file *filp,
...
@@ -142,6 +166,7 @@ static ssize_t mmio_read(struct trace_iterator *iter, struct file *filp,
iter
->
private
=
NULL
;
iter
->
private
=
NULL
;
}
}
print_out:
ret
=
trace_seq_to_user
(
s
,
ubuf
,
cnt
);
ret
=
trace_seq_to_user
(
s
,
ubuf
,
cnt
);
return
(
ret
==
-
EBUSY
)
?
0
:
ret
;
return
(
ret
==
-
EBUSY
)
?
0
:
ret
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录