Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
e79b1659
提交
e79b1659
8月 27, 2007
创建
作者:
rsc
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
nits
上级
13491bf3
显示空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
7 行增加
和
17 行删除
+7
-17
sysfile.c
sysfile.c
+7
-17
没有找到文件。
sysfile.c
浏览文件 @
e79b1659
...
@@ -213,7 +213,7 @@ sys_unlink(void)
...
@@ -213,7 +213,7 @@ sys_unlink(void)
}
}
static
struct
inode
*
static
struct
inode
*
mkpath
(
char
*
path
,
int
canexist
,
short
type
,
short
major
,
short
minor
)
create
(
char
*
path
,
int
canexist
,
short
type
,
short
major
,
short
minor
)
{
{
uint
off
;
uint
off
;
struct
inode
*
ip
,
*
dp
;
struct
inode
*
ip
,
*
dp
;
...
@@ -240,8 +240,6 @@ mkpath(char *path, int canexist, short type, short major, short minor)
...
@@ -240,8 +240,6 @@ mkpath(char *path, int canexist, short type, short major, short minor)
ilock
(
ip
);
ilock
(
ip
);
ip
->
major
=
major
;
ip
->
major
=
major
;
ip
->
minor
=
minor
;
ip
->
minor
=
minor
;
ip
->
size
=
0
;
ip
->
nlink
=
1
;
iupdate
(
ip
);
iupdate
(
ip
);
if
(
dirlink
(
dp
,
name
,
ip
->
inum
)
<
0
){
if
(
dirlink
(
dp
,
name
,
ip
->
inum
)
<
0
){
...
@@ -256,7 +254,7 @@ mkpath(char *path, int canexist, short type, short major, short minor)
...
@@ -256,7 +254,7 @@ mkpath(char *path, int canexist, short type, short major, short minor)
iupdate
(
dp
);
iupdate
(
dp
);
// No ip->nlink++ for ".": avoid cyclic ref count.
// No ip->nlink++ for ".": avoid cyclic ref count.
if
(
dirlink
(
ip
,
"."
,
ip
->
inum
)
<
0
||
dirlink
(
ip
,
".."
,
dp
->
inum
)
<
0
)
if
(
dirlink
(
ip
,
"."
,
ip
->
inum
)
<
0
||
dirlink
(
ip
,
".."
,
dp
->
inum
)
<
0
)
panic
(
"
mkpath
dots"
);
panic
(
"
create
dots"
);
}
}
iunlockput
(
dp
);
iunlockput
(
dp
);
return
ip
;
return
ip
;
...
@@ -274,7 +272,7 @@ sys_open(void)
...
@@ -274,7 +272,7 @@ sys_open(void)
return
-
1
;
return
-
1
;
if
(
omode
&
O_CREATE
){
if
(
omode
&
O_CREATE
){
if
((
ip
=
mkpath
(
path
,
1
,
T_FILE
,
0
,
0
))
==
0
)
if
((
ip
=
create
(
path
,
1
,
T_FILE
,
0
,
0
))
==
0
)
return
-
1
;
return
-
1
;
}
else
{
}
else
{
if
((
ip
=
namei
(
path
))
==
0
)
if
((
ip
=
namei
(
path
))
==
0
)
...
@@ -297,16 +295,8 @@ sys_open(void)
...
@@ -297,16 +295,8 @@ sys_open(void)
f
->
type
=
FD_INODE
;
f
->
type
=
FD_INODE
;
f
->
ip
=
ip
;
f
->
ip
=
ip
;
f
->
off
=
0
;
f
->
off
=
0
;
if
(
omode
&
O_RDWR
)
{
f
->
readable
=
!
(
omode
&
O_WRONLY
);
f
->
readable
=
1
;
f
->
writable
=
(
omode
&
O_WRONLY
)
||
(
omode
&
O_RDWR
);
f
->
writable
=
1
;
}
else
if
(
omode
&
O_WRONLY
)
{
f
->
readable
=
0
;
f
->
writable
=
1
;
}
else
{
f
->
readable
=
1
;
f
->
writable
=
0
;
}
return
fd
;
return
fd
;
}
}
...
@@ -322,7 +312,7 @@ sys_mknod(void)
...
@@ -322,7 +312,7 @@ sys_mknod(void)
if
((
len
=
argstr
(
0
,
&
path
))
<
0
||
if
((
len
=
argstr
(
0
,
&
path
))
<
0
||
argint
(
1
,
&
major
)
<
0
||
argint
(
1
,
&
major
)
<
0
||
argint
(
2
,
&
minor
)
<
0
||
argint
(
2
,
&
minor
)
<
0
||
(
ip
=
mkpath
(
path
,
0
,
T_DEV
,
major
,
minor
))
==
0
)
(
ip
=
create
(
path
,
0
,
T_DEV
,
major
,
minor
))
==
0
)
return
-
1
;
return
-
1
;
iunlockput
(
ip
);
iunlockput
(
ip
);
return
0
;
return
0
;
...
@@ -334,7 +324,7 @@ sys_mkdir(void)
...
@@ -334,7 +324,7 @@ sys_mkdir(void)
char
*
path
;
char
*
path
;
struct
inode
*
ip
;
struct
inode
*
ip
;
if
(
argstr
(
0
,
&
path
)
<
0
||
(
ip
=
mkpath
(
path
,
0
,
T_DIR
,
0
,
0
))
==
0
)
if
(
argstr
(
0
,
&
path
)
<
0
||
(
ip
=
create
(
path
,
0
,
T_DIR
,
0
,
0
))
==
0
)
return
-
1
;
return
-
1
;
iunlockput
(
ip
);
iunlockput
(
ip
);
return
0
;
return
0
;
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论