Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
0dff86aa
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
0dff86aa
编写于
12月 23, 2008
作者:
I
Ingo Molnar
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
x86, perfcounters: print out the ->used bitmask
Impact: extend debug printouts Signed-off-by:
N
Ingo Molnar
<
mingo@elte.hu
>
上级
95cdd2e7
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
4 addition
and
0 deletion
+4
-0
arch/x86/kernel/cpu/perf_counter.c
arch/x86/kernel/cpu/perf_counter.c
+4
-0
未找到文件。
arch/x86/kernel/cpu/perf_counter.c
浏览文件 @
0dff86aa
...
@@ -255,6 +255,7 @@ static int pmc_generic_enable(struct perf_counter *counter)
...
@@ -255,6 +255,7 @@ static int pmc_generic_enable(struct perf_counter *counter)
idx
=
find_first_zero_bit
(
cpuc
->
used
,
nr_counters_generic
);
idx
=
find_first_zero_bit
(
cpuc
->
used
,
nr_counters_generic
);
if
(
idx
==
nr_counters_generic
)
if
(
idx
==
nr_counters_generic
)
return
-
EAGAIN
;
return
-
EAGAIN
;
set_bit
(
idx
,
cpuc
->
used
);
set_bit
(
idx
,
cpuc
->
used
);
hwc
->
idx
=
idx
;
hwc
->
idx
=
idx
;
}
}
...
@@ -274,6 +275,7 @@ static int pmc_generic_enable(struct perf_counter *counter)
...
@@ -274,6 +275,7 @@ static int pmc_generic_enable(struct perf_counter *counter)
void
perf_counter_print_debug
(
void
)
void
perf_counter_print_debug
(
void
)
{
{
u64
ctrl
,
status
,
overflow
,
pmc_ctrl
,
pmc_count
,
prev_left
;
u64
ctrl
,
status
,
overflow
,
pmc_ctrl
,
pmc_count
,
prev_left
;
struct
cpu_hw_counters
*
cpuc
;
int
cpu
,
idx
;
int
cpu
,
idx
;
if
(
!
nr_counters_generic
)
if
(
!
nr_counters_generic
)
...
@@ -282,6 +284,7 @@ void perf_counter_print_debug(void)
...
@@ -282,6 +284,7 @@ void perf_counter_print_debug(void)
local_irq_disable
();
local_irq_disable
();
cpu
=
smp_processor_id
();
cpu
=
smp_processor_id
();
cpuc
=
&
per_cpu
(
cpu_hw_counters
,
cpu
);
rdmsrl
(
MSR_CORE_PERF_GLOBAL_CTRL
,
ctrl
);
rdmsrl
(
MSR_CORE_PERF_GLOBAL_CTRL
,
ctrl
);
rdmsrl
(
MSR_CORE_PERF_GLOBAL_STATUS
,
status
);
rdmsrl
(
MSR_CORE_PERF_GLOBAL_STATUS
,
status
);
...
@@ -291,6 +294,7 @@ void perf_counter_print_debug(void)
...
@@ -291,6 +294,7 @@ void perf_counter_print_debug(void)
printk
(
KERN_INFO
"CPU#%d: ctrl: %016llx
\n
"
,
cpu
,
ctrl
);
printk
(
KERN_INFO
"CPU#%d: ctrl: %016llx
\n
"
,
cpu
,
ctrl
);
printk
(
KERN_INFO
"CPU#%d: status: %016llx
\n
"
,
cpu
,
status
);
printk
(
KERN_INFO
"CPU#%d: status: %016llx
\n
"
,
cpu
,
status
);
printk
(
KERN_INFO
"CPU#%d: overflow: %016llx
\n
"
,
cpu
,
overflow
);
printk
(
KERN_INFO
"CPU#%d: overflow: %016llx
\n
"
,
cpu
,
overflow
);
printk
(
KERN_INFO
"CPU#%d: used: %016llx
\n
"
,
cpu
,
*
(
u64
*
)
cpuc
->
used
);
for
(
idx
=
0
;
idx
<
nr_counters_generic
;
idx
++
)
{
for
(
idx
=
0
;
idx
<
nr_counters_generic
;
idx
++
)
{
rdmsrl
(
MSR_ARCH_PERFMON_EVENTSEL0
+
idx
,
pmc_ctrl
);
rdmsrl
(
MSR_ARCH_PERFMON_EVENTSEL0
+
idx
,
pmc_ctrl
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录