Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
2624d3d1
提交
2624d3d1
3月 31, 2012
创建
作者:
Nickolai Zeldovich
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
close and re-open sys_exec() scope after migration
上级
c99d71b6
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
33 行增加
和
7 行删除
+33
-7
kernel.hh
include/kernel.hh
+1
-1
kmtrace.hh
include/kmtrace.hh
+25
-3
exec.cc
kernel/exec.cc
+6
-2
sysfile.cc
kernel/sysfile.cc
+1
-1
没有找到文件。
include/kernel.hh
浏览文件 @
2624d3d1
...
...
@@ -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
浏览文件 @
2624d3d1
...
...
@@ -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
;
}
};
...
...
kernel/exec.cc
浏览文件 @
2624d3d1
...
...
@@ -14,6 +14,7 @@
#include "cpu.hh"
#include "wq.hh"
#include "cilk.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
)
{
struct
inode
*
ip
=
nullptr
;
struct
vmap
*
vmp
=
nullptr
;
...
...
@@ -166,10 +167,13 @@ 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
);
if
((
ip
=
namei
(
myproc
()
->
cwd
,
path
))
==
0
)
return
-
1
;
...
...
kernel/sysfile.cc
浏览文件 @
2624d3d1
...
...
@@ -447,7 +447,7 @@ sys_exec(const char *upath, u64 uargv)
if
(
argcheckstr
(
argv
[
i
])
<
0
)
return
-
1
;
}
return
exec
(
path
,
argv
);
return
exec
(
path
,
argv
,
&
ascope
);
}
long
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论