Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
b2705655
提交
b2705655
2月 16, 2012
创建
作者:
Nickolai Zeldovich
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
syscall.c -> syscall.cc
上级
19f389d9
显示空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
42 行增加
和
36 行删除
+42
-36
bootdata.c
bootdata.c
+37
-0
kernel.h
kernel.h
+1
-0
syscall.cc
syscall.cc
+3
-36
syscall.h
syscall.h
+1
-0
没有找到文件。
bootdata.c
浏览文件 @
b2705655
...
@@ -2,6 +2,8 @@
...
@@ -2,6 +2,8 @@
#include "mmu.h"
#include "mmu.h"
#include "spinlock.h"
#include "spinlock.h"
#include "kalloc.h"
#include "kalloc.h"
#include "syscall.h"
#include "kernel.h"
/*
/*
* Data structures that use C99 designated initializers,
* Data structures that use C99 designated initializers,
...
@@ -43,3 +45,38 @@ struct kmem slabmem[slab_type_max][NCPU] = {
...
@@ -43,3 +45,38 @@ struct kmem slabmem[slab_type_max][NCPU] = {
},
},
};
};
#define SYSCALL(name) [SYS_##name] = (void*)sys_##name
long
(
*
syscalls
[])(
u64
,
u64
,
u64
,
u64
,
u64
,
u64
)
=
{
SYSCALL
(
chdir
),
SYSCALL
(
close
),
SYSCALL
(
dup
),
SYSCALL
(
exec
),
SYSCALL
(
exit
),
SYSCALL
(
fork
),
SYSCALL
(
fstat
),
SYSCALL
(
getpid
),
SYSCALL
(
kill
),
SYSCALL
(
link
),
SYSCALL
(
mkdir
),
SYSCALL
(
mknod
),
SYSCALL
(
open
),
SYSCALL
(
pipe
),
SYSCALL
(
read
),
SYSCALL
(
sbrk
),
SYSCALL
(
sleep
),
SYSCALL
(
unlink
),
SYSCALL
(
wait
),
SYSCALL
(
write
),
SYSCALL
(
uptime
),
SYSCALL
(
map
),
SYSCALL
(
unmap
),
SYSCALL
(
halt
),
SYSCALL
(
socket
),
SYSCALL
(
bind
),
SYSCALL
(
listen
),
SYSCALL
(
accept
),
SYSCALL
(
pread
),
SYSCALL
(
kernlet
),
};
kernel.h
浏览文件 @
b2705655
...
@@ -333,6 +333,7 @@ long sys_listen(int, int);
...
@@ -333,6 +333,7 @@ long sys_listen(int, int);
long
sys_accept
(
int
,
void
*
,
void
*
);
long
sys_accept
(
int
,
void
*
,
void
*
);
long
sys_pread
(
int
fd
,
void
*
ubuf
,
size_t
count
,
off_t
offset
);
long
sys_pread
(
int
fd
,
void
*
ubuf
,
size_t
count
,
off_t
offset
);
long
sys_kernlet
(
int
,
size_t
,
off_t
);
long
sys_kernlet
(
int
,
size_t
,
off_t
);
extern
long
(
*
syscalls
[])(
u64
,
u64
,
u64
,
u64
,
u64
,
u64
);
// other exported/imported functions
// other exported/imported functions
void
cmain
(
u64
mbmagic
,
u64
mbaddr
);
void
cmain
(
u64
mbmagic
,
u64
mbaddr
);
...
...
syscall.c
→
syscall.c
c
浏览文件 @
b2705655
extern
"C"
{
#include "types.h"
#include "types.h"
#include "mmu.h"
#include "mmu.h"
#include "kernel.h"
#include "kernel.h"
...
@@ -9,6 +10,7 @@
...
@@ -9,6 +10,7 @@
#include "syscall.h"
#include "syscall.h"
#include "cpu.h"
#include "cpu.h"
#include "kmtrace.h"
#include "kmtrace.h"
}
// User code makes a system call with INT T_SYSCALL.
// User code makes a system call with INT T_SYSCALL.
// System call number in %eax.
// System call number in %eax.
...
@@ -146,41 +148,6 @@ kmemcpy(void *umem, void *src, u64 size)
...
@@ -146,41 +148,6 @@ kmemcpy(void *umem, void *src, u64 size)
return
0
;
return
0
;
}
}
#define SYSCALL(name) [SYS_##name] = (void*)sys_##name
static
long
(
*
syscalls
[])(
u64
,
u64
,
u64
,
u64
,
u64
,
u64
)
=
{
SYSCALL
(
chdir
),
SYSCALL
(
close
),
SYSCALL
(
dup
),
SYSCALL
(
exec
),
SYSCALL
(
exit
),
SYSCALL
(
fork
),
SYSCALL
(
fstat
),
SYSCALL
(
getpid
),
SYSCALL
(
kill
),
SYSCALL
(
link
),
SYSCALL
(
mkdir
),
SYSCALL
(
mknod
),
SYSCALL
(
open
),
SYSCALL
(
pipe
),
SYSCALL
(
read
),
SYSCALL
(
sbrk
),
SYSCALL
(
sleep
),
SYSCALL
(
unlink
),
SYSCALL
(
wait
),
SYSCALL
(
write
),
SYSCALL
(
uptime
),
SYSCALL
(
map
),
SYSCALL
(
unmap
),
SYSCALL
(
halt
),
SYSCALL
(
socket
),
SYSCALL
(
bind
),
SYSCALL
(
listen
),
SYSCALL
(
accept
),
SYSCALL
(
pread
),
SYSCALL
(
kernlet
),
};
void
void
syscall
(
void
)
syscall
(
void
)
{
{
...
@@ -189,7 +156,7 @@ syscall(void)
...
@@ -189,7 +156,7 @@ syscall(void)
tf
=
myproc
()
->
tf
;
tf
=
myproc
()
->
tf
;
num
=
tf
->
rax
;
num
=
tf
->
rax
;
if
(
num
>=
0
&&
num
<
NELEM
(
syscalls
)
&&
syscalls
[
num
])
{
if
(
num
>=
0
&&
num
<
SYS_ncount
&&
syscalls
[
num
])
{
mtstart
(
syscalls
[
num
],
myproc
());
mtstart
(
syscalls
[
num
],
myproc
());
mtrec
();
mtrec
();
tf
->
rax
=
syscalls
[
num
](
tf
->
rdi
,
tf
->
rsi
,
tf
->
rdx
,
tf
->
rax
=
syscalls
[
num
](
tf
->
rdi
,
tf
->
rsi
,
tf
->
rdx
,
...
...
syscall.h
浏览文件 @
b2705655
...
@@ -29,3 +29,4 @@
...
@@ -29,3 +29,4 @@
#define SYS_accept 28
#define SYS_accept 28
#define SYS_pread 29
#define SYS_pread 29
#define SYS_kernlet 30
#define SYS_kernlet 30
#define SYS_ncount 31
/* total number of system calls */
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论