Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
aaada9c3
提交
aaada9c3
3月 06, 2012
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
A filetable class
上级
e4afcf9f
显示空白字符变更
内嵌
并排
正在显示
5 个修改的文件
包含
93 行增加
和
38 行删除
+93
-38
filetable.hh
include/filetable.hh
+66
-0
proc.hh
include/proc.hh
+2
-1
async.cc
kernel/async.cc
+2
-2
proc.cc
kernel/proc.cc
+14
-14
sysfile.cc
kernel/sysfile.cc
+9
-21
没有找到文件。
include/filetable.hh
0 → 100644
浏览文件 @
aaada9c3
#include "atomic.hh"
class
filetable
{
public
:
filetable
()
:
ref_
(
1
)
{
for
(
int
fd
=
0
;
fd
<
NOFILE
;
fd
++
)
ofile_
[
fd
]
=
nullptr
;
}
filetable
(
const
filetable
&
f
)
:
ref_
(
1
)
{
for
(
int
fd
=
0
;
fd
<
NOFILE
;
fd
++
)
{
if
(
f
.
ofile_
[
fd
])
ofile_
[
fd
]
=
filedup
(
f
.
ofile_
[
fd
]);
else
ofile_
[
fd
]
=
nullptr
;
}
}
~
filetable
()
{
for
(
int
fd
=
0
;
fd
<
NOFILE
;
fd
++
){
if
(
ofile_
[
fd
]){
fileclose
(
ofile_
[
fd
]);
ofile_
[
fd
]
=
0
;
}
}
}
struct
file
*
getfile
(
int
fd
)
{
if
(
fd
<
0
||
fd
>=
NOFILE
)
return
nullptr
;
return
ofile_
[
fd
];
}
int
allocfd
(
struct
file
*
f
)
{
for
(
int
fd
=
0
;
fd
<
NOFILE
;
fd
++
){
if
(
ofile_
[
fd
]
==
nullptr
){
ofile_
[
fd
]
=
f
;
return
fd
;
}
}
return
-
1
;
}
void
close
(
int
fd
)
{
struct
file
*
f
=
ofile_
[
fd
];
ofile_
[
fd
]
=
nullptr
;
fileclose
(
f
);
}
void
decref
()
{
if
(
--
ref_
==
0
)
delete
this
;
}
void
incref
()
{
ref_
++
;
}
NEW_DELETE_OPS
(
filetable
)
private
:
struct
file
*
ofile_
[
NOFILE
];
std
::
atomic
<
u64
>
ref_
;
};
include/proc.hh
浏览文件 @
aaada9c3
...
@@ -3,6 +3,7 @@
...
@@ -3,6 +3,7 @@
#include "spinlock.h"
#include "spinlock.h"
#include "atomic.hh"
#include "atomic.hh"
#include "cpputil.hh"
#include "cpputil.hh"
#include "filetable.hh"
// Saved registers for kernel context switches.
// Saved registers for kernel context switches.
// (also implicitly defined in swtch.S)
// (also implicitly defined in swtch.S)
...
@@ -47,7 +48,7 @@ struct proc : public rcu_freed {
...
@@ -47,7 +48,7 @@ struct proc : public rcu_freed {
struct
trapframe
*
tf
;
// Trap frame for current syscall
struct
trapframe
*
tf
;
// Trap frame for current syscall
struct
context
*
context
;
// swtch() here to run process
struct
context
*
context
;
// swtch() here to run process
int
killed
;
// If non-zero, have been killed
int
killed
;
// If non-zero, have been killed
struct
file
*
ofile
[
NOFILE
];
// Open files
filetable
*
ftable
;
struct
inode
*
cwd
;
// Current directory
struct
inode
*
cwd
;
// Current directory
char
name
[
16
];
// Process name (debugging)
char
name
[
16
];
// Process name (debugging)
u64
tsc
;
u64
tsc
;
...
...
kernel/async.cc
浏览文件 @
aaada9c3
...
@@ -72,9 +72,9 @@ sys_async(int fd, size_t count, off_t off,
...
@@ -72,9 +72,9 @@ sys_async(int fd, size_t count, off_t off,
msg
=
&
ipcctl
->
msg
[
msgid
];
msg
=
&
ipcctl
->
msg
[
msgid
];
ubuf
=
(
kshared
+
PGSIZE
+
(
pageid
*
PGSIZE
));
ubuf
=
(
kshared
+
PGSIZE
+
(
pageid
*
PGSIZE
));
if
(
fd
<
0
||
fd
>=
NOFILE
||
(
f
=
myproc
()
->
ofile
[
fd
])
==
0
)
if
((
f
=
myproc
()
->
ftable
->
getfile
(
fd
))
==
nullptr
)
return
-
1
;
return
-
1
;
if
(
f
->
type
!=
file
::
FD_INODE
)
if
(
f
->
type
!=
file
::
FD_INODE
)
return
-
1
;
return
-
1
;
f
->
ip
->
ref
++
;
f
->
ip
->
ref
++
;
...
...
kernel/proc.cc
浏览文件 @
aaada9c3
...
@@ -38,7 +38,7 @@ enum { sched_debug = 0 };
...
@@ -38,7 +38,7 @@ enum { sched_debug = 0 };
proc
::
proc
(
int
npid
)
:
proc
::
proc
(
int
npid
)
:
rcu_freed
(
"proc"
),
vmap
(
0
),
brk
(
0
),
kstack
(
0
),
rcu_freed
(
"proc"
),
vmap
(
0
),
brk
(
0
),
kstack
(
0
),
pid
(
npid
),
parent
(
0
),
tf
(
0
),
context
(
0
),
killed
(
0
),
pid
(
npid
),
parent
(
0
),
tf
(
0
),
context
(
0
),
killed
(
0
),
cwd
(
0
),
tsc
(
0
),
curcycles
(
0
),
cpuid
(
0
),
epoch
(
0
),
ftable
(
0
),
cwd
(
0
),
tsc
(
0
),
curcycles
(
0
),
cpuid
(
0
),
epoch
(
0
),
on_runq
(
-
1
),
cpu_pin
(
0
),
runq
(
0
),
oncv
(
0
),
cv_wakeup
(
0
),
on_runq
(
-
1
),
cpu_pin
(
0
),
runq
(
0
),
oncv
(
0
),
cv_wakeup
(
0
),
user_fs_
(
0
),
state_
(
EMBRYO
)
user_fs_
(
0
),
state_
(
EMBRYO
)
{
{
...
@@ -48,7 +48,6 @@ proc::proc(int npid) :
...
@@ -48,7 +48,6 @@ proc::proc(int npid) :
memset
(
&
childq
,
0
,
sizeof
(
childq
));
memset
(
&
childq
,
0
,
sizeof
(
childq
));
memset
(
&
child_next
,
0
,
sizeof
(
child_next
));
memset
(
&
child_next
,
0
,
sizeof
(
child_next
));
memset
(
ofile
,
0
,
sizeof
(
ofile
));
memset
(
&
runqlink
,
0
,
sizeof
(
runqlink
));
memset
(
&
runqlink
,
0
,
sizeof
(
runqlink
));
memset
(
&
cv_waiters
,
0
,
sizeof
(
cv_waiters
));
memset
(
&
cv_waiters
,
0
,
sizeof
(
cv_waiters
));
memset
(
&
cv_sleep
,
0
,
sizeof
(
cv_sleep
));
memset
(
&
cv_sleep
,
0
,
sizeof
(
cv_sleep
));
...
@@ -122,19 +121,13 @@ void
...
@@ -122,19 +121,13 @@ void
exit
(
void
)
exit
(
void
)
{
{
struct
proc
*
p
,
*
np
;
struct
proc
*
p
,
*
np
;
int
fd
;
int
wakeupinit
;
int
wakeupinit
;
if
(
myproc
()
==
bootproc
)
if
(
myproc
()
==
bootproc
)
panic
(
"init exiting"
);
panic
(
"init exiting"
);
// Close all open files.
if
(
myproc
()
->
ftable
)
for
(
fd
=
0
;
fd
<
NOFILE
;
fd
++
){
myproc
()
->
ftable
->
decref
();
if
(
myproc
()
->
ofile
[
fd
]){
fileclose
(
myproc
()
->
ofile
[
fd
]);
myproc
()
->
ofile
[
fd
]
=
0
;
}
}
// Kernel threads might not have a cwd
// Kernel threads might not have a cwd
if
(
myproc
()
->
cwd
!=
nullptr
)
{
if
(
myproc
()
->
cwd
!=
nullptr
)
{
...
@@ -246,6 +239,9 @@ inituser(void)
...
@@ -246,6 +239,9 @@ inituser(void)
extern
u64
_initcode_size
;
extern
u64
_initcode_size
;
p
=
allocproc
();
p
=
allocproc
();
p
->
ftable
=
new
filetable
();
if
(
p
->
ftable
==
nullptr
)
panic
(
"userinit: new filetable"
);
bootproc
=
p
;
bootproc
=
p
;
if
((
p
->
vmap
=
new
vmap
())
==
0
)
if
((
p
->
vmap
=
new
vmap
())
==
0
)
panic
(
"userinit: out of vmaps?"
);
panic
(
"userinit: out of vmaps?"
);
...
@@ -432,7 +428,7 @@ procdumpall(void)
...
@@ -432,7 +428,7 @@ procdumpall(void)
int
int
fork
(
int
flags
)
fork
(
int
flags
)
{
{
int
i
,
pid
;
int
pid
;
struct
proc
*
np
;
struct
proc
*
np
;
int
cow
=
1
;
int
cow
=
1
;
...
@@ -464,9 +460,13 @@ fork(int flags)
...
@@ -464,9 +460,13 @@ fork(int flags)
// Clear %eax so that fork returns 0 in the child.
// Clear %eax so that fork returns 0 in the child.
np
->
tf
->
rax
=
0
;
np
->
tf
->
rax
=
0
;
for
(
i
=
0
;
i
<
NOFILE
;
i
++
)
np
->
ftable
=
new
filetable
(
*
myproc
()
->
ftable
);
if
(
myproc
()
->
ofile
[
i
])
if
(
np
->
ftable
==
nullptr
)
{
np
->
ofile
[
i
]
=
filedup
(
myproc
()
->
ofile
[
i
]);
// XXX(sbw) leaking?
freeproc
(
np
);
return
-
1
;
}
np
->
cwd
=
idup
(
myproc
()
->
cwd
);
np
->
cwd
=
idup
(
myproc
()
->
cwd
);
pid
=
np
->
pid
;
pid
=
np
->
pid
;
safestrcpy
(
np
->
name
,
myproc
()
->
name
,
sizeof
(
myproc
()
->
name
));
safestrcpy
(
np
->
name
,
myproc
()
->
name
,
sizeof
(
myproc
()
->
name
));
...
...
kernel/sysfile.cc
浏览文件 @
aaada9c3
...
@@ -19,7 +19,7 @@ argfd(int fd, struct file **pf)
...
@@ -19,7 +19,7 @@ argfd(int fd, struct file **pf)
{
{
struct
file
*
f
;
struct
file
*
f
;
if
(
fd
<
0
||
fd
>=
NOFILE
||
(
f
=
myproc
()
->
ofile
[
fd
])
==
0
)
if
(
(
f
=
myproc
()
->
ftable
->
getfile
(
fd
))
==
nullptr
)
return
-
1
;
return
-
1
;
if
(
pf
)
if
(
pf
)
*
pf
=
f
;
*
pf
=
f
;
...
@@ -31,15 +31,7 @@ argfd(int fd, struct file **pf)
...
@@ -31,15 +31,7 @@ argfd(int fd, struct file **pf)
static
int
static
int
fdalloc
(
struct
file
*
f
)
fdalloc
(
struct
file
*
f
)
{
{
int
fd
;
return
myproc
()
->
ftable
->
allocfd
(
f
);
for
(
fd
=
0
;
fd
<
NOFILE
;
fd
++
){
if
(
myproc
()
->
ofile
[
fd
]
==
0
){
myproc
()
->
ofile
[
fd
]
=
f
;
return
fd
;
}
}
return
-
1
;
}
}
long
long
...
@@ -73,7 +65,7 @@ sys_pread(int fd, void *ubuf, size_t count, off_t offset)
...
@@ -73,7 +65,7 @@ sys_pread(int fd, void *ubuf, size_t count, off_t offset)
uptr
i
=
(
uptr
)
ubuf
;
uptr
i
=
(
uptr
)
ubuf
;
int
r
;
int
r
;
if
(
fd
<
0
||
fd
>=
NOFILE
||
(
f
=
myproc
()
->
ofile
[
fd
])
==
0
)
if
((
f
=
myproc
()
->
ftable
->
getfile
(
fd
))
==
nullptr
)
return
-
1
;
return
-
1
;
for
(
uptr
va
=
PGROUNDDOWN
(
i
);
va
<
i
+
count
;
va
=
va
+
PGSIZE
)
for
(
uptr
va
=
PGROUNDDOWN
(
i
);
va
<
i
+
count
;
va
=
va
+
PGSIZE
)
...
@@ -108,8 +100,7 @@ sys_close(int fd)
...
@@ -108,8 +100,7 @@ sys_close(int fd)
if
(
argfd
(
fd
,
&
f
)
<
0
)
if
(
argfd
(
fd
,
&
f
)
<
0
)
return
-
1
;
return
-
1
;
myproc
()
->
ofile
[
fd
]
=
0
;
myproc
()
->
ftable
->
close
(
fd
);
fileclose
(
f
);
return
0
;
return
0
;
}
}
...
@@ -296,7 +287,7 @@ sys_openat(int dirfd, const char *path, int omode)
...
@@ -296,7 +287,7 @@ sys_openat(int dirfd, const char *path, int omode)
}
else
if
(
dirfd
<
0
||
dirfd
>=
NOFILE
)
{
}
else
if
(
dirfd
<
0
||
dirfd
>=
NOFILE
)
{
return
-
1
;
return
-
1
;
}
else
{
}
else
{
struct
file
*
fdir
=
myproc
()
->
ofile
[
dirfd
]
;
struct
file
*
fdir
=
myproc
()
->
ftable
->
getfile
(
dirfd
)
;
if
(
fdir
==
nullptr
||
fdir
->
type
!=
file
::
FD_INODE
)
if
(
fdir
==
nullptr
||
fdir
->
type
!=
file
::
FD_INODE
)
return
-
1
;
return
-
1
;
cwd
=
fdir
->
ip
;
cwd
=
fdir
->
ip
;
...
@@ -424,8 +415,7 @@ sys_pipe(int *fd)
...
@@ -424,8 +415,7 @@ sys_pipe(int *fd)
fd0
=
-
1
;
fd0
=
-
1
;
if
((
fd0
=
fdalloc
(
rf
))
<
0
||
(
fd1
=
fdalloc
(
wf
))
<
0
){
if
((
fd0
=
fdalloc
(
rf
))
<
0
||
(
fd1
=
fdalloc
(
wf
))
<
0
){
if
(
fd0
>=
0
)
if
(
fd0
>=
0
)
myproc
()
->
ofile
[
fd0
]
=
0
;
myproc
()
->
ftable
->
close
(
fd0
);
fileclose
(
rf
);
fileclose
(
wf
);
fileclose
(
wf
);
return
-
1
;
return
-
1
;
}
}
...
@@ -437,15 +427,14 @@ sys_pipe(int *fd)
...
@@ -437,15 +427,14 @@ sys_pipe(int *fd)
static
void
static
void
freesocket
(
int
fd
)
freesocket
(
int
fd
)
{
{
fileclose
(
myproc
()
->
ofile
[
fd
]);
myproc
()
->
ftable
->
close
(
fd
);
myproc
()
->
ofile
[
fd
]
=
0
;
}
}
static
int
static
int
getsocket
(
int
fd
,
struct
file
**
ret
)
getsocket
(
int
fd
,
struct
file
**
ret
)
{
{
struct
file
*
f
;
struct
file
*
f
;
if
(
fd
<
0
||
fd
>=
NOFILE
||
(
f
=
myproc
()
->
ofile
[
fd
])
==
0
)
if
(
(
f
=
myproc
()
->
ftable
->
getfile
(
fd
))
==
nullptr
)
return
-
1
;
return
-
1
;
if
(
f
->
type
!=
file
::
FD_SOCKET
)
if
(
f
->
type
!=
file
::
FD_SOCKET
)
return
-
1
;
return
-
1
;
...
@@ -493,8 +482,7 @@ sys_socket(int domain, int type, int protocol)
...
@@ -493,8 +482,7 @@ sys_socket(int domain, int type, int protocol)
s
=
netsocket
(
domain
,
type
,
protocol
);
s
=
netsocket
(
domain
,
type
,
protocol
);
if
(
s
<
0
)
{
if
(
s
<
0
)
{
myproc
()
->
ofile
[
fd
]
=
0
;
myproc
()
->
ftable
->
close
(
fd
);
fileclose
(
f
);
return
s
;
return
s
;
}
}
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论