Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
0538397f
提交
0538397f
2月 26, 2012
创建
作者:
Nickolai Zeldovich
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
inline range::lock
上级
1c96fd2f
显示空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
9 行增加
和
12 行删除
+9
-12
crange.hh
include/crange.hh
+2
-2
crange.cc
kernel/crange.cc
+7
-10
没有找到文件。
include/crange.hh
浏览文件 @
0538397f
...
...
@@ -88,7 +88,7 @@ struct range : public rcu_freed {
const
int
nlevel
;
// the number of levels this range should appear
crange
*
const
cr
;
// the crange this range is part of
markptr
<
range
>*
const
next
;
// one next pointer per level
spinlock
*
lock
;
// on separate cache line?
spinlock
lock
;
// on separate cache line?
void
print
(
int
l
);
void
dec_ref
(
void
);
...
...
@@ -166,7 +166,7 @@ struct crange_locked {
for
(
range
*
e
=
prev_
;
e
&&
e
!=
succ_
;
e
=
n
)
{
// as soon a we release, the next pointer can change, so read it first
n
=
e
->
next
[
0
].
ptr
();
release
(
e
->
lock
);
release
(
&
e
->
lock
);
}
}
}
...
...
kernel/crange.cc
浏览文件 @
0538397f
...
...
@@ -91,8 +91,7 @@ range::~range()
for
(
int
l
=
0
;
l
<
nlevel
;
l
++
)
{
next
[
l
]
=
(
struct
range
*
)
0xDEADBEEF
;
}
destroylock
(
lock
);
kmalignfree
(
lock
,
CACHELINE
,
sizeof
(
struct
spinlock
));
destroylock
(
&
lock
);
delete
[]
next
;
}
...
...
@@ -118,9 +117,7 @@ range::range(crange *crarg, u64 k, u64 sz, int nl)
assert
(
cr
->
nlevel
>
0
);
assert
(
next
);
for
(
int
l
=
0
;
l
<
nlevel
;
l
++
)
next
[
l
]
=
0
;
assert
(
kmalign
((
void
**
)
&
lock
,
CACHELINE
,
sizeof
(
struct
spinlock
))
==
0
);
initlock
(
lock
,
"crange"
,
LOCKSTAT_CRANGE
);
initlock
(
&
lock
,
"crange"
,
LOCKSTAT_CRANGE
);
}
//
...
...
@@ -132,11 +129,11 @@ int
range
::
lockif
(
markptr
<
range
>
e
)
{
assert
(
!
e
.
mark
());
acquire
(
lock
);
acquire
(
&
lock
);
if
(
next
[
0
]
==
e
)
{
return
1
;
}
release
(
lock
);
release
(
&
lock
);
// cprintf("%d: range_lock_pred: retry %u\n", mycpu()->id, key);
return
0
;
}
...
...
@@ -329,7 +326,7 @@ crange::lock_range(u64 k, u64 sz, int l, range **er, range **pr, range **fr, ran
assert
(
*
fr
);
*
lr
=
e
;
if
(
l
==
0
)
{
acquire
(
e
->
lock
);
// lock all ranges in the sequence
acquire
(
&
e
->
lock
);
// lock all ranges in the sequence
}
e
=
e
->
next
[
l
].
ptr
();
}
...
...
@@ -444,7 +441,7 @@ crange_locked::replace(range *prev, range *repl)
range
*
newlast
=
0
;
for
(
range
*
e
=
repl
;
e
;
e
=
e
->
next
[
0
].
ptr
())
{
assert
(
e
->
key
>=
base_
&&
e
->
key
+
e
->
size
<=
base_
+
size_
);
acquire
(
e
->
lock
);
acquire
(
&
e
->
lock
);
newlast
=
e
;
}
...
...
@@ -458,7 +455,7 @@ crange_locked::replace(range *prev, range *repl)
crange
::
mark
(
replaced
,
succ_
);
for
(
range
*
e
=
replaced
;
e
&&
e
!=
succ_
;
e
=
e
->
next
[
0
].
ptr
())
{
release
(
e
->
lock
);
release
(
&
e
->
lock
);
e
->
dec_ref
();
}
}
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论