Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
7e84b1c2
提交
7e84b1c2
3月 15, 2012
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Start of some kernel code that looks for userspace work
上级
a778a729
显示空白字符变更
内嵌
并排
正在显示
5 个修改的文件
包含
59 行增加
和
2 行删除
+59
-2
uwq.hh
include/uwq.hh
+20
-0
vm.hh
include/vm.hh
+1
-1
idle.cc
kernel/idle.cc
+1
-1
uwq.cc
kernel/uwq.cc
+34
-0
vm.cc
kernel/vm.cc
+3
-0
没有找到文件。
include/uwq.hh
浏览文件 @
7e84b1c2
...
@@ -4,5 +4,25 @@ struct padded_length {
...
@@ -4,5 +4,25 @@ struct padded_length {
};
};
#if defined (XV6_KERNEL)
#if defined (XV6_KERNEL)
struct
uwq_length
{
uwq_length
(
padded_length
*
len
)
:
len_
(
len
)
{}
void
clear
()
{
for
(
int
i
=
0
;
i
<
NCPU
;
i
++
)
len_
[
i
].
v_
=
0
;
}
bool
haswork
()
{
for
(
int
i
=
0
;
i
<
NCPU
;
i
++
)
{
if
(
len_
[
i
].
v_
>
0
)
return
true
;
}
return
false
;
}
private
:
padded_length
*
len_
;
};
int
uwq_trywork
(
void
);
int
uwq_trywork
(
void
);
#endif
#endif
include/vm.hh
浏览文件 @
7e84b1c2
...
@@ -93,10 +93,10 @@ struct vmap {
...
@@ -93,10 +93,10 @@ struct vmap {
NEW_DELETE_OPS
(
vmap
)
NEW_DELETE_OPS
(
vmap
)
uptr
brk_
;
// Top of heap
uptr
brk_
;
// Top of heap
padded_length
*
const
uwq_len_
;
private
:
private
:
int
pagefault_wcow
(
vma
*
m
);
int
pagefault_wcow
(
vma
*
m
);
padded_length
*
const
uwq_len_
;
struct
spinlock
brklock_
;
struct
spinlock
brklock_
;
};
};
kernel/idle.cc
浏览文件 @
7e84b1c2
...
@@ -118,7 +118,7 @@ idleloop(void)
...
@@ -118,7 +118,7 @@ idleloop(void)
idlem
->
heir
=
p
;
idlem
->
heir
=
p
;
}
}
worked
=
uwq_trywork
();
// XXX(sbw)
worked = uwq_trywork();
worked
=
wq_trywork
();
worked
=
wq_trywork
();
// If we are no longer the idle thread, exit
// If we are no longer the idle thread, exit
...
...
kernel/uwq.cc
浏览文件 @
7e84b1c2
#include "types.h"
#include "types.h"
#include "amd64.h"
#include "kernel.hh"
#include "kernel.hh"
#include "cpu.hh"
#include "uwq.hh"
#include "uwq.hh"
#include "gc.hh"
#include "percpu.hh"
#include "spinlock.h"
#include "condvar.h"
#include "proc.hh"
#include "vm.hh"
int
int
uwq_trywork
(
void
)
uwq_trywork
(
void
)
{
{
u64
i
,
k
;
// A "random" victim CPU
k
=
rdtsc
();
for
(
i
=
0
;
i
<
NCPU
;
i
++
)
{
u64
j
=
(
i
+
k
)
%
NCPU
;
if
(
j
==
mycpuid
())
continue
;
struct
cpu
*
c
=
&
cpus
[
j
];
scoped_gc_epoch
();
struct
proc
*
p
=
c
->
proc
;
if
(
p
==
nullptr
||
p
->
vmap
==
nullptr
)
continue
;
padded_length
*
len
=
p
->
vmap
->
uwq_len_
;
if
(
len
==
nullptr
)
break
;
if
(
uwq_length
(
len
).
haswork
())
{
// XXX(sbw) start a worker thread..
break
;
}
}
return
0
;
return
0
;
}
}
kernel/vm.cc
浏览文件 @
7e84b1c2
...
@@ -14,6 +14,7 @@
...
@@ -14,6 +14,7 @@
#include "crange.hh"
#include "crange.hh"
#include "cpputil.hh"
#include "cpputil.hh"
#include "sperf.hh"
#include "sperf.hh"
#include "uwq.hh"
enum
{
vm_debug
=
0
};
enum
{
vm_debug
=
0
};
...
@@ -162,6 +163,8 @@ vmap::vmap() :
...
@@ -162,6 +163,8 @@ vmap::vmap() :
if
(
uwq_len_
==
nullptr
)
{
if
(
uwq_len_
==
nullptr
)
{
cprintf
(
"vmap::vmap: userwq out of memory
\n
"
);
cprintf
(
"vmap::vmap: userwq out of memory
\n
"
);
goto
err
;
goto
err
;
}
else
{
uwq_length
(
uwq_len_
).
clear
();
}
}
if
(
setupuvm
(
pml4
,
kshared
,
(
char
*
)
uwq_len_
))
{
if
(
setupuvm
(
pml4
,
kshared
,
(
char
*
)
uwq_len_
))
{
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论