Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
0633b971
提交
0633b971
8月 12, 2006
创建
作者:
kaashoek
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
unlink,mknod,create with multi-component pathnames should work now
remove console init code from userfs
上级
24437cd5
显示空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
41 行增加
和
33 行删除
+41
-33
defs.h
defs.h
+2
-2
fs.c
fs.c
+31
-11
syscall.c
syscall.c
+6
-12
userfs.c
userfs.c
+2
-8
没有找到文件。
defs.h
浏览文件 @
0633b971
...
...
@@ -114,9 +114,9 @@ void ilock(struct inode *ip);
void
iunlock
(
struct
inode
*
ip
);
void
idecref
(
struct
inode
*
ip
);
void
iput
(
struct
inode
*
ip
);
struct
inode
*
namei
(
char
*
path
);
struct
inode
*
namei
(
char
*
path
,
uint
*
);
int
readi
(
struct
inode
*
ip
,
char
*
xdst
,
uint
off
,
uint
n
);
int
writei
(
struct
inode
*
ip
,
char
*
addr
,
uint
off
,
uint
n
);
struct
inode
*
mknod
(
struct
inode
*
,
char
*
,
short
,
short
,
short
);
struct
inode
*
mknod
(
char
*
,
short
,
short
,
short
);
int
unlink
(
char
*
cp
);
void
iupdate
(
struct
inode
*
ip
);
fs.c
浏览文件 @
0633b971
...
...
@@ -189,6 +189,7 @@ ialloc(uint dev, short type)
static
void
ifree
(
struct
inode
*
ip
)
{
cprintf
(
"ifree: %d
\n
"
,
ip
->
inum
);
ip
->
type
=
0
;
iupdate
(
ip
);
}
...
...
@@ -340,7 +341,7 @@ writei(struct inode *ip, char *addr, uint off, uint n)
}
struct
inode
*
namei
(
char
*
path
)
namei
(
char
*
path
,
uint
*
ret_pinum
)
{
struct
inode
*
dp
;
char
*
cp
=
path
;
...
...
@@ -349,17 +350,24 @@ namei(char *path)
struct
dirent
*
ep
;
int
i
;
unsigned
ninum
;
unsigned
pinum
;
dp
=
iget
(
rootdev
,
1
);
pinum
=
dp
->
inum
;
while
(
*
cp
==
'/'
)
cp
++
;
while
(
1
){
if
(
*
cp
==
'\0'
)
if
(
*
cp
==
'\0'
)
{
if
(
ret_pinum
)
*
ret_pinum
=
pinum
;
return
dp
;
}
if
(
dp
->
type
!=
T_DIR
){
if
(
ret_pinum
)
*
ret_pinum
=
pinum
;
iput
(
dp
);
return
0
;
}
...
...
@@ -384,10 +392,13 @@ namei(char *path)
brelse
(
bp
);
}
iput
(
dp
);
if
(
ret_pinum
)
*
ret_pinum
=
pinum
;
return
0
;
found:
dev
=
dp
->
dev
;
pinum
=
dp
->
inum
;
iput
(
dp
);
dp
=
iget
(
dev
,
ninum
);
while
(
*
cp
==
'/'
)
...
...
@@ -396,19 +407,28 @@ namei(char *path)
}
struct
inode
*
mknod
(
struct
inode
*
dp
,
char
*
cp
,
short
type
,
short
major
,
short
minor
)
mknod
(
char
*
cp
,
short
type
,
short
major
,
short
minor
)
{
struct
inode
*
ip
;
struct
inode
*
ip
,
*
dp
;
struct
dirent
*
ep
=
0
;
int
off
;
int
i
;
struct
buf
*
bp
=
0
;
uint
pinum
=
0
;
cprintf
(
"mknod: dir %d %s %d %d %d
\n
"
,
dp
->
inum
,
cp
,
type
,
major
,
minor
);
cprintf
(
"mknod: %s %d %d %d
\n
"
,
cp
,
type
,
major
,
minor
);
if
((
ip
=
namei
(
cp
,
&
pinum
))
!=
0
)
{
iput
(
ip
);
return
0
;
}
cprintf
(
"mknod: pinum = %d
\n
"
,
pinum
);
dp
=
iget
(
rootdev
,
pinum
);
ip
=
ialloc
(
dp
->
dev
,
type
);
if
(
ip
==
0
)
return
0
;
if
(
ip
==
0
)
{
iput
(
dp
);
return
0
;
}
ip
->
major
=
major
;
ip
->
minor
=
minor
;
ip
->
size
=
0
;
...
...
@@ -434,10 +454,9 @@ mknod(struct inode *dp, char *cp, short type, short major, short minor)
for
(
i
=
0
;
i
<
DIRSIZ
&&
cp
[
i
];
i
++
)
ep
->
name
[
i
]
=
cp
[
i
];
bwrite
(
dp
->
dev
,
bp
,
bmap
(
dp
,
off
/
BSIZE
));
// write directory block
brelse
(
bp
);
dp
->
size
+=
sizeof
(
struct
dirent
);
// update directory inode
iupdate
(
dp
);
iput
(
dp
);
return
ip
;
}
...
...
@@ -449,8 +468,9 @@ unlink(char *cp)
struct
dirent
*
ep
=
0
;
int
off
;
struct
buf
*
bp
=
0
;
uint
pinum
;
if
((
ip
=
namei
(
cp
))
==
0
)
{
if
((
ip
=
namei
(
cp
,
&
pinum
))
==
0
)
{
cprintf
(
"file to be unlinked doesn't exist
\n
"
);
return
-
1
;
}
...
...
@@ -475,7 +495,7 @@ unlink(char *cp)
iupdate
(
ip
);
ifree
(
ip
);
// is this the right order?
dp
=
iget
(
rootdev
,
1
);
// XXX should parse name
dp
=
iget
(
rootdev
,
pinum
);
for
(
off
=
0
;
off
<
dp
->
size
;
off
+=
BSIZE
)
{
bp
=
bread
(
dp
->
dev
,
bmap
(
dp
,
off
/
BSIZE
));
for
(
ep
=
(
struct
dirent
*
)
bp
->
data
;
...
...
syscall.c
浏览文件 @
0633b971
...
...
@@ -253,20 +253,17 @@ sys_open(void)
uint
arg0
,
arg1
;
int
ufd
;
struct
fd
*
fd
;
struct
inode
*
dp
;
int
l
;
if
(
fetcharg
(
0
,
&
arg0
)
<
0
||
fetcharg
(
1
,
&
arg1
)
<
0
)
return
-
1
;
if
((
l
=
checkstring
(
arg0
))
<
0
)
return
-
1
;
if
((
ip
=
namei
(
cp
->
mem
+
arg0
))
==
0
)
{
if
((
ip
=
namei
(
cp
->
mem
+
arg0
,
0
))
==
0
)
{
if
(
arg1
&
O_CREATE
)
{
if
(
l
>=
DIRSIZ
)
return
-
1
;
dp
=
iget
(
rootdev
,
1
);
// XXX should parse name
ip
=
mknod
(
dp
,
cp
->
mem
+
arg0
,
T_FILE
,
0
,
0
);
iput
(
dp
);
ip
=
mknod
(
cp
->
mem
+
arg0
,
T_FILE
,
0
,
0
);
if
(
ip
==
0
)
return
-
1
;
}
else
return
-
1
;
}
...
...
@@ -303,7 +300,7 @@ int
sys_mknod
(
void
)
{
struct
proc
*
cp
=
curproc
[
cpu
()];
struct
inode
*
dp
,
*
nip
;
struct
inode
*
nip
;
uint
arg0
,
arg1
,
arg2
,
arg3
;
int
l
;
...
...
@@ -317,10 +314,7 @@ sys_mknod(void)
if
(
l
>=
DIRSIZ
)
return
-
1
;
dp
=
iget
(
rootdev
,
1
);
// XXX should parse name
nip
=
mknod
(
dp
,
cp
->
mem
+
arg0
,
(
short
)
arg1
,
(
short
)
arg2
,
(
short
)
arg3
);
iput
(
dp
);
nip
=
mknod
(
cp
->
mem
+
arg0
,
(
short
)
arg1
,
(
short
)
arg2
,
(
short
)
arg3
);
iput
(
nip
);
return
(
nip
==
0
)
?
-
1
:
0
;
}
...
...
@@ -357,7 +351,7 @@ sys_exec(void)
return
-
1
;
if
(
checkstring
(
arg0
)
<
0
)
return
-
1
;
ip
=
namei
(
cp
->
mem
+
arg0
);
ip
=
namei
(
cp
->
mem
+
arg0
,
0
);
if
(
ip
==
0
)
return
-
1
;
...
...
@@ -495,7 +489,7 @@ sys_block(void)
ip
->
type
,
ip
->
nlink
,
ip
->
size
,
ip
->
addrs
[
0
]);
iput
(
ip
);
ip
=
namei
(
".././//./../usertests"
);
ip
=
namei
(
".././//./../usertests"
,
0
);
if
(
ip
){
cprintf
(
"namei(usertests): %d %d %d %d %d %d %d %d
\n
"
,
ip
->
dev
,
ip
->
inum
,
ip
->
count
,
ip
->
busy
,
...
...
userfs.c
浏览文件 @
0633b971
...
...
@@ -5,7 +5,7 @@
// file system tests
char
buf
[
3
000
];
char
buf
[
2
000
];
char
*
echo_args
[]
=
{
"echo"
,
"hello"
,
"goodbye"
,
0
};
char
*
cat_args
[]
=
{
"cat"
,
"README"
,
0
};
...
...
@@ -14,14 +14,8 @@ main(void)
{
int
fd
;
int
i
;
int
stdout
;
int
stdout
=
1
;
// printf(stdout, "userfs running\n");
if
(
mknod
(
"console"
,
T_DEV
,
1
,
1
)
<
0
)
puts
(
"mknod failed
\n
"
);
else
puts
(
"made a node
\n
"
);
stdout
=
open
(
"console"
,
O_WRONLY
);
printf
(
stdout
,
"userfs is running
\n
"
);
block
();
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论