Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
c0436a69
提交
c0436a69
2月 23, 2012
创建
作者:
Nickolai Zeldovich
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
lock-free linked lists are susceptible to ABA races,
which actually show up on real hardware.. hmm.
上级
020f4b22
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
14 行增加
和
7 行删除
+14
-7
exec.cc
kernel/exec.cc
+0
-5
gc.cc
kernel/gc.cc
+1
-0
kalloc.cc
kernel/kalloc.cc
+5
-1
kmalloc.cc
kernel/kmalloc.cc
+8
-1
没有找到文件。
kernel/exec.cc
浏览文件 @
c0436a69
...
...
@@ -84,7 +84,6 @@ static void dostack(uptr a0, u64 a1)
goto
bad
;
if
(
args
->
vmap
->
insert
(
vmn
,
USERTOP
-
(
USTACKPAGES
*
PGSIZE
),
1
)
<
0
)
goto
bad
;
vmn
=
0
;
// Push argument strings, prepare rest of stack in ustack.
sp
=
USERTOP
;
...
...
@@ -135,7 +134,6 @@ static void doheap(uptr a0, u64 a1)
goto
bad
;
if
(
args
->
vmap
->
insert
(
vmn
,
BRK
,
1
)
<
0
)
goto
bad
;
vmn
=
0
;
prof_end
(
doheap_prof
);
return
;
...
...
@@ -149,7 +147,6 @@ exec(char *path, char **argv)
{
struct
inode
*
ip
=
NULL
;
struct
vmap
*
vmp
=
NULL
;
struct
vmnode
*
vmn
=
NULL
;
struct
elfhdr
elf
;
struct
proghdr
ph
;
u64
off
;
...
...
@@ -227,8 +224,6 @@ exec(char *path, char **argv)
cprintf
(
"exec failed
\n
"
);
if
(
vmp
)
vmp
->
decref
();
if
(
vmn
)
delete
vmn
;
gc_end_epoch
();
return
0
;
...
...
kernel/gc.cc
浏览文件 @
c0436a69
...
...
@@ -58,6 +58,7 @@ gc_free_tofreelist(atomic<rcu_freed*> *head, u64 epoch)
for
(;
r
;
r
=
nr
)
{
if
(
r
->
_rcu_epoch
>
epoch
)
{
cprintf
(
"gc_free_tofreelist: r->epoch %ld > epoch %ld
\n
"
,
r
->
_rcu_epoch
,
epoch
);
cprintf
(
"gc_free_tofreelist: name %s
\n
"
,
r
->
_rcu_type
);
assert
(
0
);
}
nr
=
r
->
_rcu_next
;
...
...
kernel/kalloc.cc
浏览文件 @
c0436a69
...
...
@@ -170,9 +170,13 @@ kalloc_pool(struct kmem *km)
m
=
&
km
[
cn
];
r
=
m
->
freelist
;
while
(
r
&&
!
cmpxch_update
(
&
m
->
freelist
,
&
r
,
r
->
next
))
run
*
nxt
=
r
->
next
;
while
(
r
&&
!
cmpxch_update
(
&
m
->
freelist
,
&
r
,
nxt
))
;
/* spin */
if
(
r
&&
r
->
next
!=
nxt
)
panic
(
"kalloc_pool: aba race %p %p %p
\n
"
,
r
,
r
->
next
,
nxt
);
if
(
r
)
{
m
->
nfree
--
;
break
;
...
...
kernel/kmalloc.cc
浏览文件 @
c0436a69
...
...
@@ -88,11 +88,18 @@ kmalloc(u64 nbytes)
return
0
;
}
}
else
{
if
(
cmpxch
(
&
freelists
[
c
].
buckets
[
b
],
h
,
h
->
next
))
header
*
nxt
=
h
->
next
;
if
(
cmpxch
(
&
freelists
[
c
].
buckets
[
b
],
h
,
nxt
))
{
if
(
h
->
next
!=
nxt
)
panic
(
"kmalloc: aba race"
);
break
;
}
}
}
if
(
ALLOC_MEMSET
)
memset
(
h
,
4
,
(
1
<<
b
));
mtlabel
(
mtrace_label_heap
,
(
void
*
)
h
,
nbytes
,
"kmalloc'ed"
,
sizeof
(
"kmalloc'ed"
));
return
h
;
}
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论