Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
58a15f25
提交
58a15f25
4月 08, 2012
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
a scheduler benchmark that is simpler to analyze
上级
94a5fb99
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
72 行增加
和
29 行删除
+72
-29
schedbench.cc
bin/schedbench.cc
+72
-29
没有找到文件。
bin/schedbench.cc
浏览文件 @
58a15f25
...
...
@@ -8,43 +8,50 @@
static
volatile
std
::
atomic
<
u64
>
waiting
;
static
volatile
std
::
atomic
<
u64
>
waking
;
static
volatile
u64
ftx
;
static
int
iters
;
static
int
nworkers
;
static
struct
{
u64
mem
;
__padout__
;
}
ftx
[
256
]
__mpalign__
;
static
void
*
worker
(
void
*
x
)
void
*
worker
0
(
void
*
x
)
{
// Ping pong a futex between a pair of workers
u64
id
=
(
u64
)
x
;
u64
*
f
=
&
(
ftx
[
id
>>
1
].
mem
);
long
r
;
int
i
;
for
(
i
=
0
;
i
<
iters
;
i
++
)
{
++
waiting
;
r
=
futex
((
u64
*
)
&
ftx
,
FUTEX_WAIT
,
(
u64
)
i
,
0
);
if
(
r
<
0
&&
r
!=
-
EWOULDBLOCK
)
die
(
"FUTEX_WAIT: %d"
,
r
);
while
(
waking
.
load
()
==
1
)
nop_pause
();
if
(
id
&
0x1
)
{
for
(
u64
i
=
0
;
i
<
iters
;
i
++
)
{
r
=
futex
(
f
,
FUTEX_WAIT
,
(
u64
)(
i
<<
1
),
0
);
if
(
r
<
0
&&
r
!=
-
EWOULDBLOCK
)
die
(
"futex: %d"
,
r
);
*
f
=
(
i
<<
1
)
+
2
;
r
=
futex
(
f
,
FUTEX_WAKE
,
1
,
0
);
assert
(
r
==
0
);
}
}
else
{
for
(
u64
i
=
0
;
i
<
iters
;
i
++
)
{
*
f
=
(
i
<<
1
)
+
1
;
r
=
futex
(
f
,
FUTEX_WAKE
,
1
,
0
);
assert
(
r
==
0
);
r
=
futex
(
f
,
FUTEX_WAIT
,
(
u64
)(
i
<<
1
)
+
1
,
0
);
if
(
r
<
0
&&
r
!=
-
EWOULDBLOCK
)
die
(
"futex: %d"
,
r
);
}
}
return
nullptr
;
}
static
void
master
(
void
)
void
master
0
(
void
)
{
long
r
;
for
(
int
i
=
0
;
i
<
iters
;
i
++
)
{
while
(
waiting
.
load
()
<
(
i
+
1
)
*
nworkers
)
nop_pause
();
waking
.
store
(
1
);
ftx
=
i
+
1
;
r
=
futex
((
u64
*
)
&
ftx
,
FUTEX_WAKE
,
nworkers
,
0
);
assert
(
r
==
0
);
waking
.
store
(
0
);
}
for
(
int
i
=
0
;
i
<
nworkers
;
i
++
)
wait
();
}
int
...
...
@@ -54,7 +61,7 @@ main(int ac, char** av)
if
(
ac
<
3
)
die
(
"usage: %s iters nworkers"
,
av
[
0
]);
ftx
=
0
;
iters
=
atoi
(
av
[
1
]);
nworkers
=
atoi
(
av
[
2
]);
waiting
.
store
(
0
);
...
...
@@ -62,17 +69,53 @@ main(int ac, char** av)
for
(
int
i
=
0
;
i
<
nworkers
;
i
++
)
{
pthread_t
th
;
r
=
pthread_create
(
&
th
,
nullptr
,
worker
,
nullptr
);
r
=
pthread_create
(
&
th
,
nullptr
,
worker
0
,
(
void
*
)(
u64
)
i
);
if
(
r
<
0
)
die
(
"pthread_create"
);
}
nsleep
(
1000
*
1000
);
u64
t0
=
rdtsc
();
master
();
master
0
();
u64
t1
=
rdtsc
();
printf
(
"%lu
\n
"
,
(
t1
-
t0
)
/
iters
);
for
(
int
i
=
0
;
i
<
nworkers
;
i
++
)
wait
();
}
#if 0
static volatile u64 ftx;
static
void* worker0(void* x)
{
long r;
int i;
for (i = 0; i < iters; i++) {
++waiting;
r = futex((u64*)&ftx, FUTEX_WAIT, (u64)i, 0);
if (r < 0 && r != -EWOULDBLOCK)
die("FUTEX_WAIT: %d", r);
while (waking.load() == 1)
nop_pause();
}
return nullptr;
}
static
void master0(void)
{
long r;
for (int i = 0; i < iters; i++) {
while (waiting.load() < (i+1)*nworkers)
nop_pause();
waking.store(1);
ftx = i+1;
r = futex((u64*)&ftx, FUTEX_WAKE, nworkers, 0);
assert(r == 0);
waking.store(0);
}
}
#endif
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论