Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
ef921d5f
提交
ef921d5f
4月 28, 2012
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'old-types' into scale-amd64
上级
32a3900d
9ff30503
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
41 行增加
和
22 行删除
+41
-22
file.hh
include/file.hh
+1
-0
fs.cc
kernel/fs.cc
+40
-22
没有找到文件。
include/file.hh
浏览文件 @
ef921d5f
...
...
@@ -69,6 +69,7 @@ struct inode : public referenced, public rcu_freed
short
minor
;
u32
size
;
std
::
atomic
<
u32
>
addrs
[
NDIRECT
+
1
];
std
::
atomic
<
volatile
u32
*>
iaddrs
;
private
:
inode
();
...
...
kernel/fs.cc
浏览文件 @
ef921d5f
...
...
@@ -45,6 +45,8 @@
static
void
itrunc
(
struct
inode
*
);
static
inode
*
the_root
;
#define IADDRSSZ (sizeof(u32)*NINDIRECT)
// Read the super block.
static
void
readsb
(
int
dev
,
struct
superblock
*
sb
)
...
...
@@ -240,6 +242,14 @@ iupdate(struct inode *ip)
memmove
(
dip
->
addrs
,
ip
->
addrs
,
sizeof
(
ip
->
addrs
));
bwrite
(
bp
);
brelse
(
bp
,
1
);
if
(
ip
->
addrs
[
NDIRECT
]
!=
0
)
{
assert
(
ip
->
iaddrs
.
load
()
!=
nullptr
);
bp
=
bread
(
ip
->
dev
,
ip
->
addrs
[
NDIRECT
],
1
);
memmove
(
bp
->
data
,
(
void
*
)
ip
->
iaddrs
.
load
(),
IADDRSSZ
);
bwrite
(
bp
);
brelse
(
bp
,
1
);
}
}
// Find the inode with number inum on device dev
...
...
@@ -253,7 +263,8 @@ inode::inode()
:
rcu_freed
(
"inode"
),
flags
(
0
),
readbusy
(
0
)
{
dir
=
0
;
dir
.
store
(
nullptr
);
iaddrs
.
store
(
nullptr
);
}
inode
::~
inode
()
...
...
@@ -265,6 +276,10 @@ inode::~inode()
gc_delayed
(
d
);
assert
(
cmpxch
(
&
dir
,
d
,
(
decltype
(
d
))
0
));
}
if
(
iaddrs
.
load
()
!=
nullptr
)
{
kmfree
((
void
*
)
iaddrs
.
load
(),
IADDRSSZ
);
iaddrs
.
store
(
nullptr
);
}
destroylock
(
&
lock
);
destroycondvar
(
&
cv
);
...
...
@@ -512,8 +527,8 @@ iunlockput(struct inode *ip)
static
u32
bmap
(
struct
inode
*
ip
,
u32
bn
)
{
u32
addr
,
*
a
;
struct
buf
*
bp
;
u32
addr
;
if
(
bn
<
NDIRECT
){
retry0
:
...
...
@@ -528,9 +543,11 @@ bmap(struct inode *ip, u32 bn)
}
bn
-=
NDIRECT
;
if
(
bn
<
NINDIRECT
){
// Load indirect block, allocating if necessary.
retry1
:
if
(
bn
>=
NINDIRECT
)
panic
(
"bmap: out of range"
);
retry1
:
if
(
ip
->
iaddrs
==
nullptr
)
{
if
((
addr
=
ip
->
addrs
[
NDIRECT
])
==
0
)
{
addr
=
balloc
(
ip
->
dev
);
if
(
!
cmpxch
(
&
ip
->
addrs
[
NDIRECT
],
(
u32
)
0
,
addr
))
{
...
...
@@ -539,26 +556,27 @@ bmap(struct inode *ip, u32 bn)
}
}
int
writerflag
=
0
;
bp
=
bread
(
ip
->
dev
,
addr
,
writerflag
);
a
=
(
u32
*
)
bp
->
data
;
if
((
addr
=
a
[
bn
])
==
0
){
brelse
(
bp
,
writerflag
);
writerflag
=
1
;
bp
=
bread
(
ip
->
dev
,
addr
,
writerflag
);
a
=
(
u32
*
)
bp
->
data
;
addr
=
a
[
bn
];
if
(
addr
==
0
)
{
a
[
bn
]
=
addr
=
balloc
(
ip
->
dev
);
bwrite
(
bp
);
}
volatile
u32
*
iaddrs
=
(
u32
*
)
kmalloc
(
IADDRSSZ
,
"iaddrs"
);
bp
=
bread
(
ip
->
dev
,
addr
,
0
);
memmove
((
void
*
)
iaddrs
,
bp
->
data
,
IADDRSSZ
);
brelse
(
bp
,
0
);
if
(
!
cmpxch
(
&
ip
->
iaddrs
,
(
volatile
u32
*
)
nullptr
,
iaddrs
))
{
bfree
(
ip
->
dev
,
addr
);
kmfree
((
void
*
)
iaddrs
,
IADDRSSZ
);
goto
retry1
;
}
}
retry2
:
if
((
addr
=
ip
->
iaddrs
[
bn
])
==
0
)
{
addr
=
balloc
(
ip
->
dev
);
if
(
!
__sync_bool_compare_and_swap
(
&
ip
->
iaddrs
[
bn
],
(
u32
)
0
,
addr
))
{
bfree
(
ip
->
dev
,
addr
);
goto
retry2
;
}
brelse
(
bp
,
writerflag
);
return
addr
;
}
panic
(
"bmap: out of range"
)
;
return
addr
;
}
// Truncate inode (discard contents).
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论