Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
d13a7df9
提交
d13a7df9
4月 07, 2012
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
pagelookup returns the kernel addr for a user addr
上级
63692bb2
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
55 行增加
和
2 行删除
+55
-2
kernel.hh
include/kernel.hh
+2
-1
vm.hh
include/vm.hh
+1
-0
vm.cc
kernel/vm.cc
+52
-1
没有找到文件。
include/kernel.hh
浏览文件 @
d13a7df9
...
...
@@ -235,7 +235,8 @@ void uartintr(void);
// vm.c
void
switchvm
(
struct
proc
*
);
int
pagefault
(
struct
vmap
*
,
uptr
,
u32
);
int
pagefault
(
struct
vmap
*
,
uptr
,
u32
);
void
*
pagelookup
(
struct
vmap
*
,
uptr
);
// zalloc.cc
char
*
zalloc
(
const
char
*
name
);
...
...
include/vm.hh
浏览文件 @
d13a7df9
...
...
@@ -96,6 +96,7 @@ struct vmap {
int
remove
(
uptr
start
,
uptr
len
);
int
pagefault
(
uptr
va
,
u32
err
);
void
*
pagelookup
(
uptr
va
);
int
copyout
(
uptr
va
,
void
*
p
,
u64
len
);
int
sbrk
(
ssize_t
n
,
uptr
*
addr
);
...
...
kernel/vm.cc
浏览文件 @
d13a7df9
...
...
@@ -633,7 +633,7 @@ vmap::pagefault(uptr va, u32 err)
}
int
pagefault
(
struct
vmap
*
vmap
,
uptr
va
,
u32
err
)
pagefault
(
vmap
*
vmap
,
uptr
va
,
u32
err
)
{
#if MTRACE
mt_ascope
ascope
(
"%s(%p)"
,
__func__
,
va
);
...
...
@@ -656,6 +656,57 @@ pagefault(struct vmap *vmap, uptr va, u32 err)
}
}
void
*
vmap
::
pagelookup
(
uptr
va
)
{
if
(
va
>=
USERTOP
)
return
nullptr
;
scoped_gc_epoch
gc
;
vma
*
m
=
lookup
(
va
,
1
);
if
(
m
==
0
||
m
->
n
==
nullptr
)
return
nullptr
;
u64
npg
=
(
PGROUNDDOWN
(
va
)
-
m
->
vma_start
)
/
PGSIZE
;
if
(
!
m
->
n
->
page
[
npg
])
// XXX(sbw) you might think we don't need to zero if ONDEMAND;
// however, our vmnode might include not backed by a file
// (e.g. the bss section of an ELF segment)
// XXX(austin) Why is this still necessary now that we map zeroed
// parts of segments separately?
if
(
m
->
n
->
allocpg
(
npg
,
true
)
<
0
)
throw_bad_alloc
();
char
*
kptr
=
(
char
*
)(
m
->
n
->
page
[
npg
]);
mtreadavar
(
"vmnode:%016x"
,
m
->
n
);
return
&
kptr
[
va
&
(
PGSIZE
-
1
)];
}
void
*
pagelookup
(
vmap
*
vmap
,
uptr
va
)
{
#if MTRACE
mt_ascope
ascope
(
"%s(%p)"
,
__func__
,
va
);
mtwriteavar
(
"thread:%x"
,
myproc
()
->
pid
);
mtwriteavar
(
"page:%p.%016x"
,
vmap
,
PGROUNDDOWN
(
va
));
#endif
for
(;;)
{
#if EXCEPTIONS
try
{
#endif
return
vmap
->
pagelookup
(
va
);
#if EXCEPTIONS
}
catch
(
retryable
&
e
)
{
cprintf
(
"%d: pagelookup retry
\n
"
,
myproc
()
->
pid
);
gc_wakeup
();
yield
();
}
#endif
}
}
// Copy len bytes from p to user address va in vmap.
// Most useful when vmap is not the current page table.
int
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论