Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
b002deab
提交
b002deab
3月 01, 2012
创建
作者:
Nickolai Zeldovich
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
%fs for userspace tls
上级
ff1eef00
隐藏空白字符变更
内嵌
并排
正在显示
11 个修改的文件
包含
52 行增加
和
7 行删除
+52
-7
usertests.cc
bin/usertests.cc
+30
-0
kern_c.h
include/kern_c.h
+1
-0
proc.hh
include/proc.hh
+1
-0
syscall.h
include/syscall.h
+2
-1
user.h
include/user.h
+3
-2
bootdata.c
kernel/bootdata.c
+1
-0
hwvm.cc
kernel/hwvm.cc
+1
-0
proc.cc
kernel/proc.cc
+2
-1
sysproc.cc
kernel/sysproc.cc
+9
-0
trap.cc
kernel/trap.cc
+1
-3
usys.S
lib/usys.S
+1
-0
没有找到文件。
bin/usertests.cc
浏览文件 @
b002deab
...
...
@@ -1597,6 +1597,35 @@ preads(void)
fprintf
(
1
,
"concurrent preads OK
\n
"
);
}
void
tls_test
(
void
)
{
u64
buf
[
128
];
for
(
int
i
=
0
;
i
<
sizeof
(
buf
)
/
sizeof
(
buf
[
0
]);
i
++
)
buf
[
i
]
=
0x11deadbeef2200
+
i
;
for
(
int
i
=
0
;
i
<
sizeof
(
buf
)
/
sizeof
(
buf
[
0
])
-
1
;
i
++
)
{
setfs
((
uptr
)
&
buf
[
i
]);
u64
x
;
u64
exp
=
0x11deadbeef2200
+
i
;
__asm
volatile
(
"movq %%fs:0, %0"
:
"=r"
(
x
));
if
(
x
!=
buf
[
i
]
||
x
!=
exp
)
fprintf
(
2
,
"tls_test: 0x%lx != 0x%lx
\n
"
,
x
,
buf
[
0
]);
getpid
();
// make sure syscalls don't trash %fs
__asm
volatile
(
"movq %%fs:0, %0"
:
"=r"
(
x
));
if
(
x
!=
buf
[
i
]
||
x
!=
exp
)
fprintf
(
2
,
"tls_test: 0x%lx != 0x%lx again
\n
"
,
x
,
buf
[
0
]);
__asm
volatile
(
"movq %%fs:8, %0"
:
"=r"
(
x
));
if
(
x
!=
buf
[
i
+
1
]
||
x
!=
exp
+
1
)
fprintf
(
2
,
"tls_test: 0x%lx != 0x%lx next
\n
"
,
x
,
buf
[
0
]);
}
fprintf
(
1
,
"tls_test ok
\n
"
);
}
int
main
(
int
argc
,
char
*
argv
[])
{
...
...
@@ -1644,6 +1673,7 @@ main(int argc, char *argv[])
bigdir
();
// slow
exectest
();
tls_test
();
exit
();
}
include/kern_c.h
浏览文件 @
b002deab
...
...
@@ -50,6 +50,7 @@ long sys_accept(int, void*, void*);
long
sys_pread
(
int
fd
,
void
*
ubuf
,
size_t
count
,
off_t
offset
);
long
sys_async
(
int
,
size_t
,
off_t
,
u32
,
u32
);
long
sys_script
(
void
*
addr
,
u64
len
,
u64
chunk
);
long
sys_setfs
(
u64
base
);
extern
long
(
*
syscalls
[])(
u64
,
u64
,
u64
,
u64
,
u64
);
// other exported/imported functions
...
...
include/proc.hh
浏览文件 @
b002deab
...
...
@@ -71,6 +71,7 @@ struct proc : public rcu_freed {
u64
cv_wakeup
;
// Wakeup time for this process
LIST_ENTRY
(
proc
)
cv_waiters
;
// Linked list of processes waiting for oncv
LIST_ENTRY
(
proc
)
cv_sleep
;
// Linked list of processes sleeping on a cv
u64
user_fs_
;
proc
(
int
npid
);
~
proc
(
void
);
...
...
include/syscall.h
浏览文件 @
b002deab
...
...
@@ -30,4 +30,5 @@
#define SYS_pread 29
#define SYS_async 30
#define SYS_script 31
#define SYS_ncount 32
/* total number of system calls */
#define SYS_setfs 32
#define SYS_ncount 33
/* total number of system calls */
include/user.h
浏览文件 @
b002deab
...
...
@@ -12,7 +12,7 @@ int read(int, void*, int);
int
close
(
int
);
int
kill
(
int
);
int
exec
(
const
char
*
,
const
char
**
);
int
open
(
const
char
*
,
int
);
int
open
at
(
int
dirfd
,
const
char
*
pathname
,
int
omode
);
int
mknod
(
const
char
*
,
short
,
short
);
int
unlink
(
const
char
*
);
int
fstat
(
int
fd
,
struct
stat
*
);
...
...
@@ -30,7 +30,7 @@ void halt(void);
ssize_t
pread
(
int
,
void
*
,
size_t
,
off_t
);
int
async
(
int
,
size_t
,
off_t
,
u32
,
u32
);
int
script
(
void
*
addr
,
u64
len
,
u64
chunk
);
int
openat
(
int
dirfd
,
const
char
*
pathname
,
int
omod
e
);
int
setfs
(
u64
bas
e
);
// ulib.c
int
stat
(
char
*
,
struct
stat
*
);
...
...
@@ -39,6 +39,7 @@ void *memmove(void*, const void*, int);
char
*
strchr
(
const
char
*
,
char
c
);
int
strcmp
(
const
char
*
,
const
char
*
);
int
strncmp
(
const
char
*
p
,
const
char
*
q
,
u32
n
);
int
open
(
const
char
*
,
int
);
char
*
gets
(
char
*
,
int
max
);
unsigned
int
strlen
(
const
char
*
);
...
...
kernel/bootdata.c
浏览文件 @
b002deab
...
...
@@ -60,5 +60,6 @@ long (*syscalls[])(u64, u64, u64, u64, u64) = {
SYSCALL
(
pread
),
SYSCALL
(
async
),
SYSCALL
(
script
),
SYSCALL
(
setfs
),
};
kernel/hwvm.cc
浏览文件 @
b002deab
...
...
@@ -127,6 +127,7 @@ switchvm(struct proc *p)
lcr3
(
v2p
(
p
->
vmap
->
pml4
));
// switch to new address space
else
switchkvm
();
writemsr
(
MSR_FS_BASE
,
p
->
user_fs_
);
popcli
();
}
...
...
kernel/proc.cc
浏览文件 @
b002deab
...
...
@@ -33,7 +33,8 @@ proc::proc(int npid) :
rcu_freed
(
"proc"
),
vmap
(
0
),
brk
(
0
),
kstack
(
0
),
pid
(
npid
),
parent
(
0
),
tf
(
0
),
context
(
0
),
killed
(
0
),
cwd
(
0
),
tsc
(
0
),
curcycles
(
0
),
cpuid
(
0
),
epoch
(
0
),
on_runq
(
-
1
),
cpu_pin
(
0
),
runq
(
0
),
oncv
(
0
),
cv_wakeup
(
0
),
state_
(
EMBRYO
)
on_runq
(
-
1
),
cpu_pin
(
0
),
runq
(
0
),
oncv
(
0
),
cv_wakeup
(
0
),
user_fs_
(
0
),
state_
(
EMBRYO
)
{
snprintf
(
lockname
,
sizeof
(
lockname
),
"cv:proc:%d"
,
pid
);
initlock
(
&
lock
,
lockname
+
3
,
LOCKSTAT_PROC
);
...
...
kernel/sysproc.cc
浏览文件 @
b002deab
...
...
@@ -123,3 +123,12 @@ sys_halt(void)
outb
(
0x8900
,
s
[
i
]);
return
0
;
}
long
sys_setfs
(
u64
base
)
{
proc
*
p
=
myproc
();
p
->
user_fs_
=
base
;
switchvm
(
p
);
return
0
;
}
kernel/trap.cc
浏览文件 @
b002deab
...
...
@@ -20,8 +20,6 @@ extern u64 trapentry[];
u64
sysentry_c
(
u64
a0
,
u64
a1
,
u64
a2
,
u64
a3
,
u64
a4
,
u64
num
)
{
u64
r
;
writegs
(
KDSEG
);
writemsr
(
MSR_GS_BASE
,
(
u64
)
&
cpus
[
cpunum
()].
cpu
);
...
...
@@ -34,7 +32,7 @@ sysentry_c(u64 a0, u64 a1, u64 a2, u64 a3, u64 a4, u64 num)
trapframe
*
tf
=
(
trapframe
*
)
(
myproc
()
->
kstack
+
KSTACKSIZE
-
sizeof
(
*
tf
));
myproc
()
->
tf
=
tf
;
r
=
syscall
(
a0
,
a1
,
a2
,
a3
,
a4
,
num
);
u64
r
=
syscall
(
a0
,
a1
,
a2
,
a3
,
a4
,
num
);
if
(
myproc
()
->
killed
)
{
mtstart
(
trap
,
myproc
());
...
...
lib/usys.S
浏览文件 @
b002deab
...
...
@@ -47,3 +47,4 @@ SYSCALL(accept)
SYSCALL(pread)
SYSCALL(async)
SYSCALL(script)
SYSCALL(setfs)
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论