Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
3415014f
提交
3415014f
3月 22, 2012
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
proc allocation tweaks
上级
1e427f09
显示空白字符变更
内嵌
并排
正在显示
6 个修改的文件
包含
19 行增加
和
21 行删除
+19
-21
kernel.hh
include/kernel.hh
+0
-1
proc.hh
include/proc.hh
+7
-5
idle.cc
kernel/idle.cc
+3
-3
proc.cc
kernel/proc.cc
+7
-10
user.cc
kernel/user.cc
+1
-1
uwq.cc
kernel/uwq.cc
+1
-1
没有找到文件。
include/kernel.hh
浏览文件 @
3415014f
...
@@ -167,7 +167,6 @@ int piperead(struct pipe*, char*, int);
...
@@ -167,7 +167,6 @@ int piperead(struct pipe*, char*, int);
int
pipewrite
(
struct
pipe
*
,
char
*
,
int
);
int
pipewrite
(
struct
pipe
*
,
char
*
,
int
);
// proc.c
// proc.c
struct
proc
*
allocproc
(
void
);
struct
proc
*
copyproc
(
struct
proc
*
);
struct
proc
*
copyproc
(
struct
proc
*
);
void
finishproc
(
struct
proc
*
);
void
finishproc
(
struct
proc
*
);
void
exit
(
void
);
void
exit
(
void
);
...
...
include/proc.hh
浏览文件 @
3415014f
...
@@ -80,17 +80,19 @@ struct proc : public rcu_freed {
...
@@ -80,17 +80,19 @@ struct proc : public rcu_freed {
LIST_ENTRY
(
proc
)
cv_sleep
;
// Linked list of processes sleeping on a cv
LIST_ENTRY
(
proc
)
cv_sleep
;
// Linked list of processes sleeping on a cv
u64
user_fs_
;
u64
user_fs_
;
proc
(
int
npid
);
~
proc
(
void
);
virtual
void
do_gc
(
void
)
{
delete
this
;
}
virtual
void
do_gc
(
void
)
{
delete
this
;
}
NEW_DELETE_OPS
(
proc
)
void
set_state
(
enum
procstate
s
);
void
set_state
(
enum
procstate
s
);
enum
procstate
get_state
(
void
)
const
{
return
state_
;
}
enum
procstate
get_state
(
void
)
const
{
return
state_
;
}
int
set_cpu_pin
(
int
cpu
);
int
set_cpu_pin
(
int
cpu
);
static
proc
*
alloc
();
private
:
private
:
proc
(
int
npid
);
~
proc
(
void
);
proc
&
operator
=
(
const
proc
&
);
proc
(
const
proc
&
x
);
NEW_DELETE_OPS
(
proc
);
enum
procstate
state_
;
// Process state
enum
procstate
state_
;
// Process state
};
};
kernel/idle.cc
浏览文件 @
3415014f
...
@@ -108,7 +108,7 @@ idleloop(void)
...
@@ -108,7 +108,7 @@ idleloop(void)
// If we don't have an heir, try to allocate one
// If we don't have an heir, try to allocate one
if
(
idlem
->
heir
==
nullptr
)
{
if
(
idlem
->
heir
==
nullptr
)
{
struct
proc
*
p
;
struct
proc
*
p
;
p
=
allocpr
oc
();
p
=
proc
::
all
oc
();
if
(
p
==
nullptr
)
if
(
p
==
nullptr
)
break
;
break
;
snprintf
(
p
->
name
,
sizeof
(
p
->
name
),
"idleh_%u"
,
mycpu
()
->
id
);
snprintf
(
p
->
name
,
sizeof
(
p
->
name
),
"idleh_%u"
,
mycpu
()
->
id
);
...
@@ -135,9 +135,9 @@ idleloop(void)
...
@@ -135,9 +135,9 @@ idleloop(void)
void
void
initidle
(
void
)
initidle
(
void
)
{
{
struct
proc
*
p
=
allocpr
oc
();
struct
proc
*
p
=
proc
::
all
oc
();
if
(
!
p
)
if
(
!
p
)
panic
(
"initidle
allocpr
oc"
);
panic
(
"initidle
proc::all
oc"
);
SLIST_INIT
(
&
idlem
[
cpunum
()].
zombies
);
SLIST_INIT
(
&
idlem
[
cpunum
()].
zombies
);
initlock
(
&
idlem
[
cpunum
()].
lock
,
"idle_lock"
,
LOCKSTAT_IDLE
);
initlock
(
&
idlem
[
cpunum
()].
lock
,
"idle_lock"
,
LOCKSTAT_IDLE
);
...
...
kernel/proc.cc
浏览文件 @
3415014f
...
@@ -198,18 +198,15 @@ freeproc(struct proc *p)
...
@@ -198,18 +198,15 @@ freeproc(struct proc *p)
gc_delayed
(
p
);
gc_delayed
(
p
);
}
}
// Look in the process table for an UNUSED proc.
proc
*
// If found, change state to EMBRYO and initialize
proc
::
alloc
(
void
)
// state required to run in the kernel.
// Otherwise return 0.
struct
proc
*
allocproc
(
void
)
{
{
struct
proc
*
p
;
char
*
sp
;
char
*
sp
;
proc
*
p
;
p
=
new
proc
(
xnspid
->
allockey
());
p
=
new
proc
(
xnspid
->
allockey
());
if
(
p
==
0
)
return
0
;
if
(
p
==
nullptr
)
return
nullptr
;
p
->
cpuid
=
mycpu
()
->
id
;
p
->
cpuid
=
mycpu
()
->
id
;
initprocgc
(
p
);
initprocgc
(
p
);
...
@@ -344,7 +341,7 @@ fork(int flags)
...
@@ -344,7 +341,7 @@ fork(int flags)
// cprintf("%d: fork\n", myproc()->pid);
// cprintf("%d: fork\n", myproc()->pid);
// Allocate process.
// Allocate process.
if
((
np
=
allocpr
oc
())
==
0
)
if
((
np
=
proc
::
all
oc
())
==
0
)
return
-
1
;
return
-
1
;
if
(
flags
==
0
)
{
if
(
flags
==
0
)
{
...
@@ -466,7 +463,7 @@ threadalloc(void (*fn)(void *), void *arg)
...
@@ -466,7 +463,7 @@ threadalloc(void (*fn)(void *), void *arg)
{
{
struct
proc
*
p
;
struct
proc
*
p
;
p
=
allocpr
oc
();
p
=
proc
::
all
oc
();
if
(
p
==
nullptr
)
if
(
p
==
nullptr
)
return
0
;
return
0
;
...
...
kernel/user.cc
浏览文件 @
3415014f
...
@@ -20,7 +20,7 @@ inituser(void)
...
@@ -20,7 +20,7 @@ inituser(void)
extern
u8
_initcode_start
[];
extern
u8
_initcode_start
[];
extern
u64
_initcode_size
;
extern
u64
_initcode_size
;
p
=
allocpr
oc
();
p
=
proc
::
all
oc
();
p
->
ftable
=
new
filetable
();
p
->
ftable
=
new
filetable
();
if
(
p
->
ftable
==
nullptr
)
if
(
p
->
ftable
==
nullptr
)
panic
(
"userinit: new filetable"
);
panic
(
"userinit: new filetable"
);
...
...
kernel/uwq.cc
浏览文件 @
3415014f
...
@@ -264,7 +264,7 @@ uwq::allocworker(void)
...
@@ -264,7 +264,7 @@ uwq::allocworker(void)
if
(
uentry
==
0
)
if
(
uentry
==
0
)
return
nullptr
;
return
nullptr
;
proc
*
p
=
allocpr
oc
();
proc
*
p
=
proc
::
all
oc
();
if
(
p
==
nullptr
)
if
(
p
==
nullptr
)
return
nullptr
;
return
nullptr
;
safestrcpy
(
p
->
name
,
"uwq_worker"
,
sizeof
(
p
->
name
));
safestrcpy
(
p
->
name
,
"uwq_worker"
,
sizeof
(
p
->
name
));
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论