Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
536eb7ed
提交
536eb7ed
4月 09, 2012
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
More timing/scheduling stats
上级
f029295e
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
11 行增加
和
8 行删除
+11
-8
Makefrag
bin/Makefrag
+1
-1
xtime.cc
bin/xtime.cc
+3
-2
pmc.hh
include/pmc.hh
+7
-5
没有找到文件。
bin/Makefrag
浏览文件 @
536eb7ed
...
@@ -30,7 +30,7 @@ UPROGS= \
...
@@ -30,7 +30,7 @@ UPROGS= \
wqsh \
wqsh \
cp \
cp \
perf \
perf \
pmc
\
xtime
\
asharing \
asharing \
xls \
xls \
xdu \
xdu \
...
...
bin/
pmc
.cc
→
bin/
xtime
.cc
浏览文件 @
536eb7ed
...
@@ -71,12 +71,13 @@ main(int ac, const char *av[])
...
@@ -71,12 +71,13 @@ main(int ac, const char *av[])
sys_stat
*
s1
=
sys_stat
::
read
();
sys_stat
*
s1
=
sys_stat
::
read
();
pmc_count
pmc1
=
pmc_count
::
read
(
0
);
pmc_count
pmc1
=
pmc_count
::
read
(
0
);
u64
t1
=
rdtsc
();
u64
t1
=
rdtsc
();
sys_stat
*
s2
=
s1
->
delta
(
s0
);
sys_stat
*
s2
=
s1
->
delta
(
s0
);
fprintf
(
1
,
"%s cycles
\n
"
,
valstr
(
t1
-
t0
));
fprintf
(
1
,
"%s cycles
\n
"
,
valstr
(
t1
-
t0
));
fprintf
(
1
,
"%s %s
\n
"
,
valstr
(
pmc1
.
delta
(
pmc0
).
sum
()),
fprintf
(
1
,
"%s %s
\n
"
,
valstr
(
pmc1
.
delta
(
pmc0
).
sum
()),
pmc_selector
[
pmci
].
name
);
pmc_selector
[
pmci
].
name
);
fprintf
(
1
,
"%lu %lu
\n
"
,
s2
->
busy
(),
s2
->
idle
());
u64
tot
=
s2
->
busy
()
+
s2
->
idle
();
fprintf
(
1
,
".%lu idle
\n
"
,
(
s2
->
idle
()
*
100
)
/
tot
);
exit
();
exit
();
}
}
include/pmc.hh
浏览文件 @
536eb7ed
...
@@ -6,18 +6,20 @@ struct pmc_count {
...
@@ -6,18 +6,20 @@ struct pmc_count {
perf_start
(
sel
,
0
);
perf_start
(
sel
,
0
);
}
}
static
pmc_count
read
(
unsigned
int
ctr
)
{
static
pmc_count
read
(
unsigned
int
ctr
,
bool
*
map
=
nullptr
)
{
pmc_count
n
;
pmc_count
n
;
// XXX(sbw) we loose our original affinity
// XXX(sbw) we loose our original affinity
for
(
int
i
=
0
;
i
<
NCPU
;
i
++
)
{
for
(
int
i
=
0
;
i
<
NCPU
;
i
++
)
{
setaffinity
(
i
);
if
(
map
==
nullptr
||
map
[
i
])
{
// XXX(sbw) qemu doesn't seem to support CR4_PCE
setaffinity
(
i
);
// XXX(sbw) qemu doesn't seem to support CR4_PCE
#if defined(HW_qemu)
#if defined(HW_qemu)
n
.
count_
[
i
]
=
0
;
n
.
count_
[
i
]
=
0
;
#else
#else
n
.
count_
[
i
]
=
rdpmc
(
ctr
);
n
.
count_
[
i
]
=
rdpmc
(
ctr
);
#endif
#endif
}
}
}
setaffinity
(
-
1
);
setaffinity
(
-
1
);
return
n
;
return
n
;
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论