Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
32a3900d
提交
32a3900d
4月 28, 2012
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'old-types' into scale-amd64
上级
2db6c3ef
87942b7c
隐藏空白字符变更
内嵌
并排
正在显示
6 个修改的文件
包含
42 行增加
和
16 行删除
+42
-16
dirbench.cc
bin/dirbench.cc
+2
-2
filebench.cc
bin/filebench.cc
+5
-0
file.hh
include/file.hh
+1
-1
file.cc
kernel/file.cc
+0
-2
fs.cc
kernel/fs.cc
+16
-4
sysfile.cc
kernel/sysfile.cc
+18
-7
没有找到文件。
bin/dirbench.cc
浏览文件 @
32a3900d
...
...
@@ -69,7 +69,7 @@ main(int ac, char** av)
mkdir
(
"/dbx"
);
mtenable
(
"xv6-
sched
bench"
);
mtenable
(
"xv6-
dir
bench"
);
u64
t0
=
rdtsc
();
for
(
u32
i
=
0
;
i
<
nthread
;
i
++
)
{
int
pid
=
fork
(
0
);
...
...
@@ -82,7 +82,7 @@ main(int ac, char** av)
for
(
u32
i
=
0
;
i
<
nthread
;
i
++
)
wait
();
u64
t1
=
rdtsc
();
mtdisable
(
"xv6-
sched
bench"
);
mtdisable
(
"xv6-
dir
bench"
);
printf
(
"dirbench: %lu
\n
"
,
t1
-
t0
);
return
0
;
...
...
bin/filebench.cc
浏览文件 @
32a3900d
...
...
@@ -7,12 +7,15 @@
#define xfork() fork()
#define xexit() exit(EXIT_SUCCESS)
#define xcreat(name) open((name), O_CREATE|O_WRONLY, S_IRUSR|S_IWUSR)
#define mtenable(x) do { } while(0)
#define mtdisable(x) do { } while(0)
typedef
uint64_t
u64
;
#else
#include "types.h"
#include "user.h"
#include "fcntl.h"
#include "amd64.h"
#include "mtrace.h"
#define xfork() fork(0)
#define xexit() exit()
#define xcreat(name) open((name), O_CREATE|O_WRONLY)
...
...
@@ -78,6 +81,7 @@ main(int ac, char **av)
}
close
(
fd
);
mtenable
(
"xv6-filebench"
);
u64
t0
=
rdtsc
();
for
(
int
i
=
0
;
i
<
nthread
;
i
++
)
{
int
pid
=
xfork
();
...
...
@@ -90,6 +94,7 @@ main(int ac, char **av)
for
(
int
i
=
0
;
i
<
nthread
;
i
++
)
wait
();
u64
t1
=
rdtsc
();
mtdisable
(
"xv6-filebench"
);
printf
(
"filebench: %lu
\n
"
,
t1
-
t0
);
return
0
;
...
...
include/file.hh
浏览文件 @
32a3900d
...
...
@@ -68,7 +68,7 @@ struct inode : public referenced, public rcu_freed
short
major
;
short
minor
;
u32
size
;
u32
addrs
[
NDIRECT
+
1
];
std
::
atomic
<
u32
>
addrs
[
NDIRECT
+
1
];
private
:
inode
();
...
...
kernel/file.cc
浏览文件 @
32a3900d
...
...
@@ -91,11 +91,9 @@ file::pread(char *addr, size_t n, off_t off)
{
if
(
type
==
file
::
FD_INODE
){
int
r
;
ilock
(
ip
,
0
);
if
(
ip
->
type
==
0
)
panic
(
"file::pread"
);
r
=
readi
(
ip
,
addr
,
off
,
n
);
iunlock
(
ip
);
return
r
;
}
return
-
1
;
...
...
kernel/fs.cc
浏览文件 @
32a3900d
...
...
@@ -516,16 +516,28 @@ bmap(struct inode *ip, u32 bn)
struct
buf
*
bp
;
if
(
bn
<
NDIRECT
){
if
((
addr
=
ip
->
addrs
[
bn
])
==
0
)
ip
->
addrs
[
bn
]
=
addr
=
balloc
(
ip
->
dev
);
retry0
:
if
((
addr
=
ip
->
addrs
[
bn
])
==
0
)
{
addr
=
balloc
(
ip
->
dev
);
if
(
!
cmpxch
(
&
ip
->
addrs
[
bn
],
(
u32
)
0
,
addr
))
{
bfree
(
ip
->
dev
,
addr
);
goto
retry0
;
}
}
return
addr
;
}
bn
-=
NDIRECT
;
if
(
bn
<
NINDIRECT
){
// Load indirect block, allocating if necessary.
if
((
addr
=
ip
->
addrs
[
NDIRECT
])
==
0
)
ip
->
addrs
[
NDIRECT
]
=
addr
=
balloc
(
ip
->
dev
);
retry1
:
if
((
addr
=
ip
->
addrs
[
NDIRECT
])
==
0
)
{
addr
=
balloc
(
ip
->
dev
);
if
(
!
cmpxch
(
&
ip
->
addrs
[
NDIRECT
],
(
u32
)
0
,
addr
))
{
bfree
(
ip
->
dev
,
addr
);
goto
retry1
;
}
}
int
writerflag
=
0
;
bp
=
bread
(
ip
->
dev
,
addr
,
writerflag
);
...
...
kernel/sysfile.cc
浏览文件 @
32a3900d
...
...
@@ -62,16 +62,27 @@ ssize_t
sys_pread
(
int
fd
,
void
*
ubuf
,
size_t
count
,
off_t
offset
)
{
sref
<
file
>
f
;
uptr
i
=
(
uptr
)
ubuf
;
if
(
!
getfile
(
fd
,
&
f
))
return
-
1
;
for
(
uptr
va
=
PGROUNDDOWN
(
i
);
va
<
i
+
count
;
va
=
va
+
PGSIZE
)
if
(
pagefault
(
myproc
()
->
vmap
,
va
,
0
)
<
0
)
return
-
1
;
return
f
->
pread
((
char
*
)
ubuf
,
count
,
offset
);
if
(
count
<
PGSIZE
)
{
ssize_t
r
;
char
*
b
;
b
=
kalloc
(
"preadbuf"
);
r
=
f
->
pread
(
b
,
count
,
offset
);
if
(
r
>
0
)
putmem
(
ubuf
,
b
,
r
);
kfree
(
b
);
return
r
;
}
else
{
// XXX(sbw) pagefaulting doesn't guarantee ubuf is mapped
// while pread executes
uptr
i
=
(
uptr
)
ubuf
;
for
(
uptr
va
=
PGROUNDDOWN
(
i
);
va
<
i
+
count
;
va
=
va
+
PGSIZE
)
if
(
pagefault
(
myproc
()
->
vmap
,
va
,
0
)
<
0
)
return
-
1
;
return
f
->
pread
((
char
*
)
ubuf
,
count
,
offset
);
}
}
//SYSCALL
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论