Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
386b6539
提交
386b6539
2月 10, 2012
创建
作者:
Nickolai Zeldovich
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
gc.cc
上级
7a53b299
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
6 行增加
和
4 行删除
+6
-4
gc.cc
gc.cc
+6
-4
没有找到文件。
gc.c
→
gc.c
c
浏览文件 @
386b6539
extern
"C"
{
#include "types.h"
#include "kernel.h"
#include "mmu.h"
...
...
@@ -7,6 +8,7 @@
#include "queue.h"
#include "proc.h"
#include "cpu.h"
}
// GC scheme based on Fraser's:
// a machine has a global_epoch
...
...
@@ -61,7 +63,7 @@ u64 global_epoch __mpalign__;
struct
gc
*
gc_alloc
()
{
struct
gc
*
r
=
kmalloc
(
sizeof
(
struct
gc
));
struct
gc
*
r
=
(
gc
*
)
kmalloc
(
sizeof
(
struct
gc
));
assert
(
r
);
__sync_fetch_and_add
(
&
gc_state
[
mycpu
()
->
id
].
ndelayed
,
1
);
return
r
;
...
...
@@ -69,7 +71,7 @@ gc_alloc()
static
void
*
gc_min
(
void
*
vkey
,
void
*
v
,
void
*
arg
){
u64
*
min_epoch_p
=
arg
;
u64
*
min_epoch_p
=
(
u64
*
)
arg
;
struct
proc
*
p
=
(
struct
proc
*
)
v
;
// Some threads may never call begin/end_epoch(), and never update
// p->epoch, so gc_thread does it for them. XXX get rid off lock?
...
...
@@ -175,7 +177,7 @@ gc_delayfreelist(void)
u64
min
=
global
;
// make that global_epoch doesn't run into a core's min_epoch
for
(
int
c
=
0
;
c
<
ncpu
;
c
++
)
{
int
w
=
gc_state
[
c
].
min_epoch
+
NEPOCH
-
1
;
u64
w
=
gc_state
[
c
].
min_epoch
+
NEPOCH
-
1
;
if
(
w
<
min
)
{
min
=
w
;
}
...
...
@@ -322,7 +324,7 @@ initgc(void)
initcondvar
(
&
gc_state
[
i
].
cv
,
"gc_cv"
);
}
for
(
u32
c
=
0
;
c
<
ncpu
;
c
++
)
{
for
(
int
c
=
0
;
c
<
ncpu
;
c
++
)
{
struct
proc
*
gcp
;
gcp
=
threadalloc
(
gc_worker
,
NULL
);
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论