Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
b42c4c52
提交
b42c4c52
2月 24, 2012
创建
作者:
Nickolai Zeldovich
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
use versioned ptrs to avoid aba in kmalloc too
上级
883a02e7
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
16 行增加
和
9 行删除
+16
-9
kmalloc.cc
kernel/kmalloc.cc
+16
-9
没有找到文件。
kernel/kmalloc.cc
浏览文件 @
b42c4c52
...
...
@@ -19,7 +19,7 @@ struct header {
};
struct
freelist
{
std
::
atomic
<
header
*>
buckets
[
KMMAX
+
1
];
versioned
<
header
*>
buckets
[
KMMAX
+
1
];
char
name
[
MAXNAME
];
};
...
...
@@ -46,9 +46,12 @@ morecore(int c, int b)
assert
(
sz
>=
sizeof
(
header
));
for
(
char
*
q
=
p
;
q
+
sz
<=
p
+
PGSIZE
;
q
+=
sz
){
struct
header
*
h
=
(
struct
header
*
)
q
;
h
->
next
=
freelists
[
c
].
buckets
[
b
];
while
(
!
cmpxch_update
(
&
freelists
[
c
].
buckets
[
b
],
&
h
->
next
,
h
))
;
/* spin */
for
(;;)
{
auto
headptr
=
freelists
[
c
].
buckets
[
b
].
load
();
h
->
next
=
headptr
.
ptr
();
if
(
freelists
[
c
].
buckets
[
b
].
compare_exchange
(
headptr
,
h
))
break
;
}
}
return
0
;
...
...
@@ -81,7 +84,8 @@ kmalloc(u64 nbytes)
int
c
=
mycpu
()
->
id
;
for
(;;)
{
h
=
freelists
[
c
].
buckets
[
b
];
auto
headptr
=
freelists
[
c
].
buckets
[
b
].
load
();
h
=
headptr
.
ptr
();
if
(
!
h
)
{
if
(
morecore
(
c
,
b
)
<
0
)
{
cprintf
(
"kmalloc(%d) failed
\n
"
,
(
int
)
nbytes
);
...
...
@@ -89,7 +93,7 @@ kmalloc(u64 nbytes)
}
}
else
{
header
*
nxt
=
h
->
next
;
if
(
cmpxch
(
&
freelists
[
c
].
buckets
[
b
],
h
,
nxt
))
{
if
(
freelists
[
c
].
buckets
[
b
].
compare_exchange
(
headptr
,
nxt
))
{
if
(
h
->
next
!=
nxt
)
panic
(
"kmalloc: aba race"
);
break
;
...
...
@@ -117,9 +121,12 @@ kmfree(void *ap, u64 nbytes)
memset
(
ap
,
3
,
(
1
<<
b
));
int
c
=
mycpu
()
->
id
;
h
->
next
=
freelists
[
c
].
buckets
[
b
];
while
(
!
cmpxch_update
(
&
freelists
[
c
].
buckets
[
b
],
&
h
->
next
,
h
))
;
/* spin */
for
(;;)
{
auto
headptr
=
freelists
[
c
].
buckets
[
b
].
load
();
h
->
next
=
headptr
.
ptr
();
if
(
freelists
[
c
].
buckets
[
b
].
compare_exchange
(
headptr
,
h
))
break
;
}
mtunlabel
(
mtrace_label_heap
,
ap
);
}
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论