Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
c5705631
提交
c5705631
4月 01, 2012
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'scale-amd64' of
git+ssh://amsterdam.csail.mit.edu/home/am0/6.828/xv6
into scale-amd64
上级
a8028fca
c1d09e43
隐藏空白字符变更
内嵌
并排
正在显示
7 个修改的文件
包含
54 行增加
和
10 行删除
+54
-10
kernel.hh
include/kernel.hh
+1
-1
kmtrace.hh
include/kmtrace.hh
+25
-3
proc.hh
include/proc.hh
+1
-0
exec.cc
kernel/exec.cc
+8
-2
proc.cc
kernel/proc.cc
+13
-3
sysfile.cc
kernel/sysfile.cc
+1
-1
wq.cc
lib/wq.cc
+5
-0
没有找到文件。
include/kernel.hh
浏览文件 @
c5705631
...
...
@@ -81,7 +81,7 @@ int e1000tx(void *buf, u32 len);
void
e1000hwaddr
(
u8
*
hwaddr
);
// exec.c
int
exec
(
const
char
*
,
char
**
);
int
exec
(
const
char
*
,
char
**
,
void
*
ascope
);
// fs.c
int
namecmp
(
const
char
*
,
const
char
*
);
...
...
include/kmtrace.hh
浏览文件 @
c5705631
...
...
@@ -67,21 +67,43 @@ static inline void mtresume(struct proc *p)
class
mt_ascope
{
char
name
[
64
];
bool
active
;
public
:
explicit
mt_ascope
(
const
char
*
fmt
,
...)
{
va_list
ap
;
va_start
(
ap
,
fmt
);
vsnprintf
(
name
,
sizeof
(
name
)
-
1
,
fmt
,
ap
);
vopen
(
fmt
,
ap
);
va_end
(
ap
);
}
~
mt_ascope
()
{
close
();
}
void
open
(
const
char
*
fmt
,
...)
{
va_list
ap
;
va_start
(
ap
,
fmt
);
vopen
(
fmt
,
ap
);
va_end
(
ap
);
}
void
vopen
(
const
char
*
fmt
,
va_list
ap
)
{
vsnprintf
(
name
,
sizeof
(
name
)
-
1
,
fmt
,
ap
);
mtrace_ascope_register
(
0
,
name
);
active
=
true
;
}
~
mt_ascop
e
()
void
clos
e
()
{
mtrace_ascope_register
(
1
,
name
);
if
(
active
)
mtrace_ascope_register
(
1
,
name
);
active
=
false
;
}
};
...
...
include/proc.hh
浏览文件 @
c5705631
...
...
@@ -80,6 +80,7 @@ struct proc : public rcu_freed {
u64
user_fs_
;
u64
unmap_tlbreq_
;
int
exec_cpuid_
;
int
run_cpuid_
;
int
in_exec_
;
int
uaccess_
;
...
...
kernel/exec.cc
浏览文件 @
c5705631
...
...
@@ -14,6 +14,7 @@
#include "cpu.hh"
#include "wq.hh"
#include "sperf.hh"
#include "kmtrace.hh"
#define BRK (USERTOP >> 1)
...
...
@@ -149,7 +150,7 @@ exec_cleanup(vmap *oldvmap, uwq *olduwq)
}
int
exec
(
const
char
*
path
,
char
**
argv
)
exec
(
const
char
*
path
,
char
**
argv
,
void
*
ascopev
)
{
ANON_REGION
(
__func__
,
&
perfgroup
);
struct
inode
*
ip
=
nullptr
;
...
...
@@ -167,10 +168,15 @@ exec(const char *path, char **argv)
myproc
()
->
exec_cpuid_
=
mycpuid
();
mt_ascope
*
ascope
=
(
mt_ascope
*
)
ascopev
;
ascope
->
close
();
myproc
()
->
in_exec_
=
1
;
yield
();
myproc
()
->
in_exec_
=
0
;
ascope
->
open
(
"sys_exec2(%s)"
,
path
);
myproc
()
->
run_cpuid_
=
mycpuid
();
if
((
ip
=
namei
(
myproc
()
->
cwd
,
path
))
==
0
)
return
-
1
;
...
...
kernel/proc.cc
浏览文件 @
c5705631
...
...
@@ -14,6 +14,7 @@
#include "vm.hh"
#include "ns.hh"
#include "fcntl.h"
#include "wq.hh"
u64
proc_hash
(
const
u32
&
p
)
...
...
@@ -368,6 +369,8 @@ fork(int flags)
np
->
parent
=
myproc
();
*
np
->
tf
=
*
myproc
()
->
tf
;
np
->
cpu_pin
=
myproc
()
->
cpu_pin
;
np
->
exec_cpuid_
=
myproc
()
->
exec_cpuid_
;
np
->
run_cpuid_
=
myproc
()
->
run_cpuid_
;
// Clear %eax so that fork returns 0 in the child.
np
->
tf
->
rax
=
0
;
...
...
@@ -408,8 +411,6 @@ finishproc(struct proc *p)
p
->
uwq
->
dec
();
ksfree
(
slab_stack
,
p
->
kstack
);
p
->
kstack
=
0
;
if
(
!
xnspid
->
remove
(
p
->
pid
,
&
p
))
panic
(
"wait: ns_remove"
);
p
->
pid
=
0
;
p
->
parent
=
0
;
p
->
name
[
0
]
=
0
;
...
...
@@ -437,7 +438,16 @@ wait(void)
pid
=
p
->
pid
;
SLIST_REMOVE
(
&
myproc
()
->
childq
,
p
,
proc
,
child_next
);
release
(
&
myproc
()
->
lock
);
finishproc
(
p
);
cwork
*
w
=
new
cwork
();
assert
(
w
);
w
->
rip
=
(
void
*
)
finishproc
;
w
->
arg0
=
p
;
assert
(
wq_pushto
(
w
,
p
->
run_cpuid_
)
>=
0
);
if
(
!
xnspid
->
remove
(
pid
,
&
p
))
panic
(
"wait: ns_remove"
);
return
pid
;
}
release
(
&
p
->
lock
);
...
...
kernel/sysfile.cc
浏览文件 @
c5705631
...
...
@@ -449,7 +449,7 @@ sys_exec(const char *upath, u64 uargv)
goto
clean
;
}
argv
[
i
]
=
0
;
r
=
exec
(
path
,
argv
);
r
=
exec
(
path
,
argv
,
&
ascope
);
clean:
for
(
i
=
i
-
i
;
i
>=
0
;
i
--
)
kmfree
(
argv
[
i
],
len
);
...
...
lib/wq.cc
浏览文件 @
c5705631
...
...
@@ -9,6 +9,8 @@
#define NSLOTS (1 << WQSHIFT)
enum
{
wq_steal_others
=
1
};
class
wq
{
public
:
wq
();
...
...
@@ -187,6 +189,9 @@ wq::pop(int c)
inline
work
*
wq
::
steal
(
int
c
)
{
if
(
!
wq_steal_others
&&
(
c
!=
mycpuid
()))
return
0
;
struct
wqueue
*
q
=
&
q_
[
c
];
work
*
w
;
int
i
;
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论