Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
275a8c9f
提交
275a8c9f
2月 29, 2012
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Rejigger 'cilk' stuff to use wq
上级
2f3519f1
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
32 行增加
和
130 行删除
+32
-130
kernel.hh
include/kernel.hh
+1
-1
lockstat.h
include/lockstat.h
+1
-0
cilk.cc
kernel/cilk.cc
+29
-129
param.h
param.h
+1
-0
没有找到文件。
include/kernel.hh
浏览文件 @
275a8c9f
...
@@ -264,7 +264,7 @@ void freework(struct work *w);
...
@@ -264,7 +264,7 @@ void freework(struct work *w);
// cilk.c
// cilk.c
#if CILKENABLE
#if CILKENABLE
void
cilk_push
(
void
*
rip
,
u64
arg0
,
u64
arg1
);
void
cilk_push
(
void
(
*
fn
)(
uptr
,
uptr
)
,
u64
arg0
,
u64
arg1
);
void
cilk_start
(
void
);
void
cilk_start
(
void
);
void
cilk_end
(
void
);
void
cilk_end
(
void
);
void
cilk_dump
(
void
);
void
cilk_dump
(
void
);
...
...
include/lockstat.h
浏览文件 @
275a8c9f
...
@@ -42,6 +42,7 @@ struct klockstat;
...
@@ -42,6 +42,7 @@ struct klockstat;
// Debug knobs
// Debug knobs
#define LOCKSTAT_BIO 1
#define LOCKSTAT_BIO 1
#define LOCKSTAT_CILK 1
#define LOCKSTAT_CONDVAR 0
#define LOCKSTAT_CONDVAR 0
#define LOCKSTAT_CONSOLE 1
#define LOCKSTAT_CONSOLE 1
#define LOCKSTAT_CRANGE 1
#define LOCKSTAT_CRANGE 1
...
...
kernel/cilk.cc
浏览文件 @
275a8c9f
...
@@ -36,6 +36,7 @@
...
@@ -36,6 +36,7 @@
#include "queue.h"
#include "queue.h"
#include "proc.hh"
#include "proc.hh"
#include "mtrace.h"
#include "mtrace.h"
#include "wq.hh"
#define NSLOTS (1 << CILKSHIFT)
#define NSLOTS (1 << CILKSHIFT)
...
@@ -59,7 +60,6 @@ struct cilkthread {
...
@@ -59,7 +60,6 @@ struct cilkthread {
struct
cilkstat
{
struct
cilkstat
{
u64
push
;
u64
push
;
u64
full
;
u64
full
;
u64
pop
;
u64
steal
;
u64
steal
;
__padout__
;
__padout__
;
}
__mpalign__
;
}
__mpalign__
;
...
@@ -67,12 +67,6 @@ struct cilkstat {
...
@@ -67,12 +67,6 @@ struct cilkstat {
static
struct
cilkqueue
queue
[
NCPU
]
__mpalign__
;
static
struct
cilkqueue
queue
[
NCPU
]
__mpalign__
;
static
struct
cilkstat
stat
[
NCPU
]
__mpalign__
;
static
struct
cilkstat
stat
[
NCPU
]
__mpalign__
;
static
struct
cilkqueue
*
cilk_cur
(
void
)
{
return
&
queue
[
mycpu
()
->
id
];
}
static
struct
cilkframe
*
static
struct
cilkframe
*
cilk_frame
(
void
)
cilk_frame
(
void
)
{
{
...
@@ -85,73 +79,20 @@ cilk_stat(void)
...
@@ -85,73 +79,20 @@ cilk_stat(void)
return
&
stat
[
mycpu
()
->
id
];
return
&
stat
[
mycpu
()
->
id
];
}
}
static
int
__cilk_push
(
struct
cilkqueue
*
q
,
struct
cilkthread
*
t
)
{
int
i
;
i
=
q
->
head
;
if
((
i
-
q
->
tail
)
==
NSLOTS
)
{
cilk_stat
()
->
full
++
;
return
-
1
;
}
i
=
i
&
(
NSLOTS
-
1
);
q
->
thread
[
i
]
=
t
;
q
->
head
++
;
cilk_stat
()
->
push
++
;
return
0
;
}
static
struct
cilkthread
*
__cilk_pop
(
struct
cilkqueue
*
q
)
{
int
i
;
acquire
(
&
q
->
lock
);
i
=
q
->
head
;
if
((
i
-
q
->
tail
)
==
0
)
{
release
(
&
q
->
lock
);
return
0
;
}
i
=
(
i
-
1
)
&
(
NSLOTS
-
1
);
q
->
head
--
;
release
(
&
q
->
lock
);
cilk_stat
()
->
pop
++
;
return
q
->
thread
[
i
];
}
static
struct
cilkthread
*
__cilk_steal
(
struct
cilkqueue
*
q
)
{
int
i
;
acquire
(
&
q
->
lock
);
i
=
q
->
tail
;
if
((
i
-
q
->
head
)
==
0
)
{
release
(
&
q
->
lock
);
return
0
;
}
i
=
i
&
(
NSLOTS
-
1
);
q
->
tail
++
;
release
(
&
q
->
lock
);
cilk_stat
()
->
steal
++
;
return
q
->
thread
[
i
];
}
static
void
static
void
__cilk_run
(
struct
cilkthread
*
th
)
__cilk_run
(
struct
work
*
w
,
void
*
xfn
,
void
*
arg0
,
void
*
arg1
,
void
*
xframe
)
{
{
void
(
*
fn
)(
uptr
arg0
,
uptr
arg1
)
=
(
void
(
*
)(
uptr
,
uptr
))
th
->
rip
;
void
(
*
fn
)(
uptr
arg0
,
uptr
arg1
)
=
(
void
(
*
)(
uptr
,
uptr
))
xfn
;
struct
cilkframe
*
frame
=
(
struct
cilkframe
*
)
xframe
;
struct
cilkframe
*
old
=
mycpu
()
->
cilkframe
;
struct
cilkframe
*
old
=
mycpu
()
->
cilkframe
;
mycpu
()
->
cilkframe
=
th
->
frame
;
if
(
old
!=
frame
)
fn
(
th
->
arg0
,
th
->
arg1
);
cilk_stat
()
->
steal
++
;
mycpu
()
->
cilkframe
=
frame
;
fn
((
uptr
)
arg0
,
(
uptr
)
arg1
);
mycpu
()
->
cilkframe
=
old
;
mycpu
()
->
cilkframe
=
old
;
th
->
frame
->
ref
--
;
frame
->
ref
--
;
kfree
(
th
);
}
}
// Add the (rip, arg0, arg1) work to the local work queue.
// Add the (rip, arg0, arg1) work to the local work queue.
...
@@ -160,56 +101,27 @@ __cilk_run(struct cilkthread *th)
...
@@ -160,56 +101,27 @@ __cilk_run(struct cilkthread *th)
void
void
cilk_push
(
void
(
*
fn
)(
uptr
,
uptr
),
u64
arg0
,
u64
arg1
)
cilk_push
(
void
(
*
fn
)(
uptr
,
uptr
),
u64
arg0
,
u64
arg1
)
{
{
struct
cilkthread
*
th
;
struct
work
*
w
;
th
=
(
struct
cilkthread
*
)
kalloc
();
w
=
allocwork
();
if
(
th
==
nullptr
)
{
if
(
w
==
nullptr
)
{
fn
(
arg0
,
arg1
);
fn
(
arg0
,
arg1
);
return
;
return
;
}
}
th
->
rip
=
(
uptr
)
fn
;
w
->
rip
=
(
void
*
)
__cilk_run
;
th
->
arg0
=
arg0
;
w
->
arg0
=
(
void
*
)
fn
;
th
->
arg1
=
arg1
;
w
->
arg1
=
(
void
*
)
arg0
;
th
->
frame
=
cilk_frame
();
w
->
arg2
=
(
void
*
)
arg1
;
w
->
arg3
=
(
void
*
)
cilk_frame
();
if
(
__cilk_push
(
cilk_cur
(),
th
))
{
kfree
(
th
);
if
(
wq_push
(
w
))
{
freework
(
w
);
fn
(
arg0
,
arg1
);
fn
(
arg0
,
arg1
);
}
else
cilk_stat
()
->
full
++
;
}
else
{
cilk_frame
()
->
ref
++
;
cilk_frame
()
->
ref
++
;
}
cilk_stat
()
->
push
++
;
// Try to execute one cilkthread.
// Check local queue then steal from other queues.
int
cilk_trywork
(
void
)
{
struct
cilkthread
*
th
;
int
i
;
pushcli
();
th
=
__cilk_pop
(
cilk_cur
());
if
(
th
!=
nullptr
)
{
__cilk_run
(
th
);
popcli
();
return
1
;
}
// XXX(sbw) should be random
for
(
i
=
0
;
i
<
NCPU
;
i
++
)
{
if
(
i
==
mycpu
()
->
id
)
continue
;
th
=
__cilk_steal
(
&
queue
[
i
]);
if
(
th
!=
nullptr
)
{
__cilk_run
(
th
);
popcli
();
return
1
;
}
}
}
popcli
();
return
0
;
}
}
// Start a new work queue frame.
// Start a new work queue frame.
...
@@ -229,21 +141,9 @@ cilk_start(void)
...
@@ -229,21 +141,9 @@ cilk_start(void)
void
void
cilk_end
(
void
)
cilk_end
(
void
)
{
{
while
(
cilk_frame
()
->
ref
!=
0
)
{
while
(
cilk_frame
()
->
ref
!=
0
)
struct
cilkthread
*
th
;
wq_trywork
();
int
i
;
while
((
th
=
__cilk_pop
(
cilk_cur
()))
!=
nullptr
)
__cilk_run
(
th
);
for
(
i
=
0
;
i
<
NCPU
;
i
++
)
{
th
=
__cilk_steal
(
&
queue
[
i
]);
if
(
th
!=
nullptr
)
{
__cilk_run
(
th
);
break
;
}
}
}
mycpu
()
->
cilkframe
=
0
;
mycpu
()
->
cilkframe
=
0
;
popcli
();
popcli
();
}
}
...
@@ -253,8 +153,8 @@ cilk_dump(void)
...
@@ -253,8 +153,8 @@ cilk_dump(void)
{
{
int
i
;
int
i
;
for
(
i
=
0
;
i
<
NCPU
;
i
++
)
for
(
i
=
0
;
i
<
NCPU
;
i
++
)
cprintf
(
"push %lu full %lu
pop %lu
steal %lu
\n
"
,
cprintf
(
"push %lu full %lu steal %lu
\n
"
,
stat
[
i
].
push
,
stat
[
i
].
full
,
stat
[
i
].
pop
,
stat
[
i
].
steal
);
stat
[
i
].
push
,
stat
[
i
].
full
,
stat
[
i
].
steal
);
}
}
static
void
static
void
...
@@ -285,7 +185,7 @@ testcilk(void)
...
@@ -285,7 +185,7 @@ testcilk(void)
running
=
0
;
running
=
0
;
}
else
{
}
else
{
while
(
running
)
while
(
running
)
cilk
_trywork
();
wq
_trywork
();
}
}
popcli
();
popcli
();
}
}
...
...
param.h
浏览文件 @
275a8c9f
...
@@ -24,6 +24,7 @@
...
@@ -24,6 +24,7 @@
#define ALLOC_MEMSET DEBUG
#define ALLOC_MEMSET DEBUG
#define KSHAREDSIZE (32 << 10)
#define KSHAREDSIZE (32 << 10)
#define WQSHIFT 7
#define WQSHIFT 7
#define CILKENABLE 0
#if defined(HW_josmp)
#if defined(HW_josmp)
#define NCPU 16 // maximum number of CPUs
#define NCPU 16 // maximum number of CPUs
#define MTRACE 0
#define MTRACE 0
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论