Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
de9d8dc5
提交
de9d8dc5
2月 27, 2012
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Some wq benchmarking
上级
30b3b571
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
92 行增加
和
0 行删除
+92
-0
wq.cc
kernel/wq.cc
+92
-0
没有找到文件。
kernel/wq.cc
浏览文件 @
de9d8dc5
...
...
@@ -233,10 +233,102 @@ testwq(void)
if
(
wq_push2
(
__test_stub
,
(
void
*
)
i
,
(
void
*
)
&
running
)
<
0
)
panic
(
"testwq: oops"
);
}
while
(
running
)
nop_pause
();
e
=
rdtsc
();
cprintf
(
"testwq: %lu
\n
"
,
(
e
-
s
)
/
iters
);
wq_dump
();
}
else
{
while
(
running
)
wq_trywork
();
}
popcli
();
}
static
struct
work
**
do_allocwork
(
struct
work
**
w
,
int
iters
)
{
int
i
;
for
(
i
=
0
;
i
<
iters
;
i
++
)
w
[
i
]
=
allocwork
();
return
w
;
}
static
struct
work
**
do_freework
(
struct
work
**
w
,
int
iters
)
{
int
i
;
for
(
i
=
0
;
i
<
iters
;
i
++
)
freework
(
w
[
i
]);
return
w
;
}
void
benchwq
(
void
)
{
enum
{
alloc_iters
=
100
};
static
volatile
atomic
<
int
>
running
(
alloc_iters
);
static
struct
work
*
w
[
alloc_iters
];
u64
e2
,
e
,
s
;
long
i
;
pushcli
();
if
(
mycpu
()
->
id
==
0
)
{
microdelay
(
1
);
// Warm up
do_allocwork
(
w
,
alloc_iters
);
do_freework
(
w
,
alloc_iters
);
s
=
rdtsc
();
do_allocwork
(
w
,
alloc_iters
);
e
=
rdtsc
();
cprintf
(
"allocwork: %lu
\n
"
,
(
e
-
s
)
/
alloc_iters
);
s
=
rdtsc
();
do_freework
(
w
,
alloc_iters
);
e
=
rdtsc
();
cprintf
(
"freework: %lu
\n
"
,
(
e
-
s
)
/
alloc_iters
);
do_allocwork
(
w
,
alloc_iters
);
for
(
i
=
0
;
i
<
alloc_iters
;
i
++
)
{
w
[
i
]
->
rip
=
(
void
*
)
__test_stub
;
w
[
i
]
->
arg1
=
(
void
*
)
&
running
;
}
s
=
rdtsc
();
for
(
i
=
0
;
i
<
alloc_iters
;
i
++
)
{
if
(
wq_push
(
w
[
i
])
<
0
)
panic
(
"testwq: oops"
);
}
e
=
rdtsc
();
while
(
running
)
nop_pause
();
e2
=
rdtsc
();
cprintf
(
"wq_push: %lu
\n
"
,
(
e
-
s
)
/
alloc_iters
);
cprintf
(
"wq finished: %lu
\n
"
,
(
e2
-
s
)
/
alloc_iters
);
do_allocwork
(
w
,
alloc_iters
);
for
(
i
=
0
;
i
<
alloc_iters
;
i
++
)
{
w
[
i
]
->
rip
=
(
void
*
)
__test_stub
;
w
[
i
]
->
arg1
=
(
void
*
)
&
running
;
}
s
=
rdtsc
();
for
(
i
=
0
;
i
<
alloc_iters
;
i
++
)
{
running
=
1
;
if
(
wq_push
(
w
[
i
])
<
0
)
panic
(
"testwq: oops"
);
while
(
running
)
nop_pause
();
}
e
=
rdtsc
();
cprintf
(
"wq_push one: %lu
\n
"
,
(
e
-
s
)
/
alloc_iters
);
wq_dump
();
}
else
{
while
(
running
)
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论