Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
731728ab
提交
731728ab
2月 23, 2012
创建
作者:
Nickolai Zeldovich
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
atomic (lockless) kmalloc
上级
4646ef72
显示空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
25 行增加
和
23 行删除
+25
-23
kmalloc.cc
kernel/kmalloc.cc
+25
-23
没有找到文件。
kernel/kmalloc.cc
浏览文件 @
731728ab
...
@@ -19,9 +19,8 @@ struct header {
...
@@ -19,9 +19,8 @@ struct header {
};
};
struct
freelist
{
struct
freelist
{
st
ruct
header
*
buckets
[
KMMAX
+
1
];
st
d
::
atomic
<
header
*>
buckets
[
KMMAX
+
1
];
char
name
[
MAXNAME
];
char
name
[
MAXNAME
];
struct
spinlock
lock
;
};
};
struct
freelist
freelists
[
NCPU
];
struct
freelist
freelists
[
NCPU
];
...
@@ -32,17 +31,16 @@ kminit(void)
...
@@ -32,17 +31,16 @@ kminit(void)
for
(
int
c
=
0
;
c
<
NCPU
;
c
++
)
{
for
(
int
c
=
0
;
c
<
NCPU
;
c
++
)
{
freelists
[
c
].
name
[
0
]
=
(
char
)
c
+
'0'
;
freelists
[
c
].
name
[
0
]
=
(
char
)
c
+
'0'
;
safestrcpy
(
freelists
[
c
].
name
+
1
,
"freelist"
,
MAXNAME
-
1
);
safestrcpy
(
freelists
[
c
].
name
+
1
,
"freelist"
,
MAXNAME
-
1
);
initlock
(
&
freelists
[
c
].
lock
,
freelists
[
c
].
name
,
LOCKSTAT_KMALLOC
);
}
}
}
}
// get more space for freelists[c].buckets[b]
// get more space for freelists[c].buckets[b]
void
int
morecore
(
int
c
,
int
b
)
morecore
(
int
c
,
int
b
)
{
{
char
*
p
=
kalloc
();
char
*
p
=
kalloc
();
if
(
p
==
0
)
if
(
p
==
0
)
return
;
return
-
1
;
int
sz
=
1
<<
b
;
int
sz
=
1
<<
b
;
for
(
char
*
q
=
p
;
for
(
char
*
q
=
p
;
...
@@ -52,15 +50,14 @@ morecore(int c, int b)
...
@@ -52,15 +50,14 @@ morecore(int c, int b)
h
->
next
=
freelists
[
c
].
buckets
[
b
];
h
->
next
=
freelists
[
c
].
buckets
[
b
];
freelists
[
c
].
buckets
[
b
]
=
h
;
freelists
[
c
].
buckets
[
b
]
=
h
;
}
}
return
0
;
}
}
void
*
void
*
kmalloc
(
u64
nbytes
)
kmalloc
(
u64
nbytes
)
{
{
int
nn
=
1
,
b
=
0
;
int
nn
=
1
,
b
=
0
;
void
*
r
=
0
;
struct
header
*
h
;
int
c
=
mycpu
()
->
id
;
while
(
nn
<
nbytes
&&
b
<=
KMMAX
){
while
(
nn
<
nbytes
&&
b
<=
KMMAX
){
nn
*=
2
;
nn
*=
2
;
...
@@ -71,21 +68,27 @@ kmalloc(u64 nbytes)
...
@@ -71,21 +68,27 @@ kmalloc(u64 nbytes)
if
(
b
>
KMMAX
)
if
(
b
>
KMMAX
)
panic
(
"kmalloc too big"
);
panic
(
"kmalloc too big"
);
acquire
(
&
freelists
[
c
].
lock
);
scoped_gc_epoch
gc
;
if
(
freelists
[
c
].
buckets
[
b
]
==
0
)
struct
header
*
h
;
morecore
(
c
,
b
);
int
c
=
mycpu
()
->
id
;
for
(;;)
{
h
=
freelists
[
c
].
buckets
[
b
];
h
=
freelists
[
c
].
buckets
[
b
];
if
(
h
){
if
(
!
h
)
{
freelists
[
c
].
buckets
[
b
]
=
h
->
next
;
if
(
morecore
(
c
,
b
)
<
0
)
{
r
=
h
+
1
;
cprintf
(
"kmalloc(%d) failed
\n
"
,
(
int
)
nbytes
);
h
->
next
=
(
header
*
)
(
long
)
b
;
return
0
;
}
}
else
{
if
(
cmpxch
(
&
freelists
[
c
].
buckets
[
b
],
h
,
h
->
next
))
break
;
}
}
release
(
&
freelists
[
c
].
lock
);
}
void
*
r
=
h
+
1
;
h
->
next
=
(
header
*
)
(
long
)
b
;
if
(
r
)
mtlabel
(
mtrace_label_heap
,
r
,
nbytes
,
"kmalloc'ed"
,
sizeof
(
"kmalloc'ed"
));
mtlabel
(
mtrace_label_heap
,
r
,
nbytes
,
"kmalloc'ed"
,
sizeof
(
"kmalloc'ed"
));
if
(
r
==
0
)
cprintf
(
"kmalloc(%d) failed
\n
"
,
(
int
)
nbytes
);
return
r
;
return
r
;
}
}
...
@@ -96,8 +99,6 @@ kmfree(void *ap)
...
@@ -96,8 +99,6 @@ kmfree(void *ap)
struct
header
*
h
;
struct
header
*
h
;
int
b
;
int
b
;
acquire
(
&
freelists
[
c
].
lock
);
h
=
(
struct
header
*
)
((
char
*
)
ap
-
sizeof
(
struct
header
));
h
=
(
struct
header
*
)
((
char
*
)
ap
-
sizeof
(
struct
header
));
b
=
(
long
)
h
->
next
;
b
=
(
long
)
h
->
next
;
if
(
b
<
0
||
b
>
KMMAX
)
if
(
b
<
0
||
b
>
KMMAX
)
...
@@ -108,9 +109,10 @@ kmfree(void *ap)
...
@@ -108,9 +109,10 @@ kmfree(void *ap)
memset
(
ap
,
3
,
(
1
<<
b
)
-
sizeof
(
struct
header
));
memset
(
ap
,
3
,
(
1
<<
b
)
-
sizeof
(
struct
header
));
h
->
next
=
freelists
[
c
].
buckets
[
b
];
h
->
next
=
freelists
[
c
].
buckets
[
b
];
freelists
[
c
].
buckets
[
b
]
=
h
;
while
(
!
cmpxch_update
(
&
freelists
[
c
].
buckets
[
b
],
&
h
->
next
,
h
))
;
/* spin */
mtunlabel
(
mtrace_label_heap
,
ap
);
mtunlabel
(
mtrace_label_heap
,
ap
);
release
(
&
freelists
[
c
].
lock
);
}
}
int
int
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论