Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
16083d44
提交
16083d44
8月 20, 2006
创建
作者:
kaashoek
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
removed block system call
renumber system calls (run gmake clean!) skeleton for dup system call
上级
8787cd01
隐藏空白字符变更
内嵌
并排
正在显示
7 个修改的文件
包含
43 行增加
和
59 行删除
+43
-59
defs.h
defs.h
+1
-0
fd.c
fd.c
+6
-0
syscall.c
syscall.c
+20
-41
syscall.h
syscall.h
+14
-14
user.h
user.h
+1
-1
userfs.c
userfs.c
+0
-2
usys.S
usys.S
+1
-1
没有找到文件。
defs.h
浏览文件 @
16083d44
...
@@ -94,6 +94,7 @@ int fd_read(struct fd *fd, char *addr, int n);
...
@@ -94,6 +94,7 @@ int fd_read(struct fd *fd, char *addr, int n);
int
fd_write
(
struct
fd
*
fd
,
char
*
addr
,
int
n
);
int
fd_write
(
struct
fd
*
fd
,
char
*
addr
,
int
n
);
int
fd_stat
(
struct
fd
*
fd
,
struct
stat
*
);
int
fd_stat
(
struct
fd
*
fd
,
struct
stat
*
);
void
fd_incref
(
struct
fd
*
fd
);
void
fd_incref
(
struct
fd
*
fd
);
int
fd_dup
(
struct
fd
*
fd
);
// ide.c
// ide.c
void
ide_init
(
void
);
void
ide_init
(
void
);
...
...
fd.c
浏览文件 @
16083d44
...
@@ -149,3 +149,9 @@ fd_incref(struct fd *fd)
...
@@ -149,3 +149,9 @@ fd_incref(struct fd *fd)
fd
->
ref
++
;
fd
->
ref
++
;
release
(
&
fd_table_lock
);
release
(
&
fd_table_lock
);
}
}
int
fd_dup
(
struct
fd
*
fd
)
{
return
-
1
;
}
syscall.c
浏览文件 @
16083d44
...
@@ -399,6 +399,23 @@ sys_fstat(void)
...
@@ -399,6 +399,23 @@ sys_fstat(void)
}
}
int
int
sys_dup
(
void
)
{
struct
proc
*
cp
=
curproc
[
cpu
()];
uint
fd
;
int
r
;
if
(
fetcharg
(
0
,
&
fd
)
<
0
)
return
-
1
;
if
(
fd
<
0
||
fd
>=
NOFILE
)
return
-
1
;
if
(
cp
->
fds
[
fd
]
==
0
)
return
-
1
;
r
=
fd_dup
(
cp
->
fds
[
fd
]);
return
r
;
}
int
sys_link
(
void
)
sys_link
(
void
)
{
{
struct
proc
*
cp
=
curproc
[
cpu
()];
struct
proc
*
cp
=
curproc
[
cpu
()];
...
@@ -543,44 +560,6 @@ sys_exec(void)
...
@@ -543,44 +560,6 @@ sys_exec(void)
return
0
;
return
0
;
}
}
int
sys_block
(
void
)
{
int
i
,
j
;
struct
buf
*
b
;
struct
inode
*
ip
;
for
(
i
=
0
;
i
<
2
;
i
++
)
{
cprintf
(
"issue read
\n
"
);
b
=
bread
(
1
,
i
);
cprintf
(
"disk 1 sector %d: "
,
i
);
for
(
j
=
0
;
j
<
4
;
j
++
)
cprintf
(
"%x "
,
b
->
data
[
j
]
&
0xff
);
cprintf
(
"
\n
"
);
brelse
(
b
);
}
ip
=
iget
(
1
,
1
);
cprintf
(
"iget 1: %d %d %d %d %d %d %d %d
\n
"
,
ip
->
dev
,
ip
->
inum
,
ip
->
count
,
ip
->
busy
,
ip
->
type
,
ip
->
nlink
,
ip
->
size
,
ip
->
addrs
[
0
]);
iput
(
ip
);
ip
=
namei
(
".././//./../usertests"
,
NAMEI_LOOKUP
,
0
);
if
(
ip
){
cprintf
(
"namei(usertests): %d %d %d %d %d %d %d %d
\n
"
,
ip
->
dev
,
ip
->
inum
,
ip
->
count
,
ip
->
busy
,
ip
->
type
,
ip
->
nlink
,
ip
->
size
,
ip
->
addrs
[
0
]);
iput
(
ip
);
}
else
{
cprintf
(
"namei(usertests) failed
\n
"
);
}
return
0
;
}
void
void
syscall
(
void
)
syscall
(
void
)
{
{
...
@@ -610,9 +589,6 @@ syscall(void)
...
@@ -610,9 +589,6 @@ syscall(void)
case
SYS_close
:
case
SYS_close
:
ret
=
sys_close
();
ret
=
sys_close
();
break
;
break
;
case
SYS_block
:
ret
=
sys_block
();
break
;
case
SYS_kill
:
case
SYS_kill
:
ret
=
sys_kill
();
ret
=
sys_kill
();
break
;
break
;
...
@@ -640,6 +616,9 @@ syscall(void)
...
@@ -640,6 +616,9 @@ syscall(void)
case
SYS_chdir
:
case
SYS_chdir
:
ret
=
sys_chdir
();
ret
=
sys_chdir
();
break
;
break
;
case
SYS_dup
:
ret
=
sys_dup
();
break
;
default:
default:
cprintf
(
"unknown sys call %d
\n
"
,
num
);
cprintf
(
"unknown sys call %d
\n
"
,
num
);
// XXX fault
// XXX fault
...
...
syscall.h
浏览文件 @
16083d44
#define SYS_fork 1
#define SYS_fork 1
#define SYS_exit 2
#define SYS_exit 2
#define SYS_wait 3
#define SYS_wait 3
#define SYS_pipe
5
#define SYS_pipe
4
#define SYS_write
6
#define SYS_write
5
#define SYS_read
7
#define SYS_read
6
#define SYS_close
8
#define SYS_close
7
#define SYS_
block
9
#define SYS_
kill
9
#define SYS_
kill
10
#define SYS_
exec
10
#define SYS_
exec 13
#define SYS_
open 11
#define SYS_
open 14
#define SYS_
mknod 12
#define SYS_
mknod 15
#define SYS_
unlink 13
#define SYS_
unlink 16
#define SYS_
fstat 14
#define SYS_
fstat 17
#define SYS_
link 15
#define SYS_
link 18
#define SYS_
mkdir 16
#define SYS_
mkdir 19
#define SYS_
chdir 17
#define SYS_
chdir 20
#define SYS_
dup 18
user.h
浏览文件 @
16083d44
...
@@ -6,7 +6,6 @@ int pipe(int*);
...
@@ -6,7 +6,6 @@ int pipe(int*);
int
write
(
int
,
void
*
,
int
);
int
write
(
int
,
void
*
,
int
);
int
read
(
int
,
void
*
,
int
);
int
read
(
int
,
void
*
,
int
);
int
close
(
int
);
int
close
(
int
);
int
block
(
void
);
int
kill
(
int
);
int
kill
(
int
);
int
panic
(
char
*
);
int
panic
(
char
*
);
int
cons_puts
(
char
*
);
int
cons_puts
(
char
*
);
...
@@ -18,6 +17,7 @@ int fstat (int fd, struct stat *stat);
...
@@ -18,6 +17,7 @@ int fstat (int fd, struct stat *stat);
int
link
(
char
*
,
char
*
);
int
link
(
char
*
,
char
*
);
int
mkdir
(
char
*
);
int
mkdir
(
char
*
);
int
chdir
(
char
*
);
int
chdir
(
char
*
);
int
dup
(
int
);
int
stat
(
char
*
,
struct
stat
*
stat
);
int
stat
(
char
*
,
struct
stat
*
stat
);
int
puts
(
char
*
);
int
puts
(
char
*
);
...
...
userfs.c
浏览文件 @
16083d44
...
@@ -20,8 +20,6 @@ main(void)
...
@@ -20,8 +20,6 @@ main(void)
printf
(
stdout
,
"userfs is running
\n
"
);
printf
(
stdout
,
"userfs is running
\n
"
);
block
();
fd
=
open
(
"echo"
,
0
);
fd
=
open
(
"echo"
,
0
);
if
(
fd
>=
0
){
if
(
fd
>=
0
){
printf
(
stdout
,
"open echo ok
\n
"
);
printf
(
stdout
,
"open echo ok
\n
"
);
...
...
usys.S
浏览文件 @
16083d44
...
@@ -15,7 +15,6 @@ STUB(pipe)
...
@@ -15,7 +15,6 @@ STUB(pipe)
STUB(read)
STUB(read)
STUB(write)
STUB(write)
STUB(close)
STUB(close)
STUB(block)
STUB(kill)
STUB(kill)
STUB(exec)
STUB(exec)
STUB(open)
STUB(open)
...
@@ -25,3 +24,4 @@ STUB(fstat)
...
@@ -25,3 +24,4 @@ STUB(fstat)
STUB(link)
STUB(link)
STUB(mkdir)
STUB(mkdir)
STUB(chdir)
STUB(chdir)
STUB(dup)
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论