Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
ebea9405
提交
ebea9405
3月 14, 2012
创建
作者:
Silas Boyd-Wickizer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
XV6_USER wqs track q_ length in a user-kernel shared buffer
上级
702e5a07
隐藏空白字符变更
内嵌
并排
正在显示
6 个修改的文件
包含
54 行增加
和
11 行删除
+54
-11
memlayout.h
include/memlayout.h
+5
-5
wquser.hh
include/wquser.hh
+15
-2
hwvm.cc
kernel/hwvm.cc
+2
-2
Makefrag
lib/Makefrag
+2
-2
wq.cc
lib/wq.cc
+29
-0
param.h
param.h
+1
-0
没有找到文件。
include/memlayout.h
浏览文件 @
ebea9405
#define KBASE 0xFFFFFF0000000000ull
#define KCODE 0xFFFFFFFFC0000000ull
#define KSHARED 0xFFFFF00000000000ull
#define USERWQ 0xFFFFF00100000000ull
#define USERTOP 0x0000800000000000ull
#define KBASE
0xFFFFFF0000000000ull
#define KCODE
0xFFFFFFFFC0000000ull
#define KSHARED
0xFFFFF00000000000ull
#define USERWQ
LEN
0xFFFFF00100000000ull
#define USERTOP
0x0000800000000000ull
include/wquser.hh
浏览文件 @
ebea9405
...
...
@@ -11,6 +11,11 @@ typedef struct uspinlock wqlock_t;
static
pthread_key_t
idkey
;
static
volatile
int
exiting
;
struct
padded_length
{
volatile
u64
v_
__mpalign__
;;
__padout__
;
};
int
mycpuid
(
void
)
{
...
...
@@ -20,11 +25,19 @@ mycpuid(void)
static
inline
void
*
allocwq
(
unsigned
long
nbytes
)
{
return
malloc
(
nbytes
);
}
static
inline
padded_length
*
allocklen
(
unsigned
long
nbytes
)
{
static
bool
alloced
;
if
(
alloced
)
die
(
"allocwq: allocing more than once"
);
die
(
"allocklen: allocing more than once"
);
if
(
nbytes
>
USERWQSIZE
)
die
(
"allocklen: too large"
);
alloced
=
true
;
return
(
void
*
)
USERWQ
;
return
(
padded_length
*
)
USERWQLEN
;
}
static
inline
void
...
...
kernel/hwvm.cc
浏览文件 @
ebea9405
...
...
@@ -100,8 +100,8 @@ setupuvm(pgmap *pml4, char *kshared, char *uwq)
char
*
uvm
;
size_t
size
;
}
todo
[]
=
{
{
kshared
,
(
char
*
)
KSHARED
,
KSHAREDSIZE
},
{
uwq
,
(
char
*
)
USERWQ
,
PGROUNDUP
(
wq_size
())
}
{
kshared
,
(
char
*
)
KSHARED
,
KSHAREDSIZE
},
{
uwq
,
(
char
*
)
USERWQ
LEN
,
PGROUNDUP
(
wq_size
())
}
};
for
(
int
i
=
0
;
i
<
NELEM
(
todo
);
i
++
)
{
...
...
lib/Makefrag
浏览文件 @
ebea9405
$(O)/lib/%.o: CFLAGS:=$(CFLAGS)
$(O)/lib/%.o: CXXFLAGS:=$(CXXFLAGS)
$(O)/lib/%.o: CFLAGS:=$(CFLAGS)
-DXV6_USER
$(O)/lib/%.o: CXXFLAGS:=$(CXXFLAGS)
-DXV6_USER
ULIB = ulib.o usys.o printf.o umalloc.o uthread.o fmt.o stream.o ipc.o \
threads.o crt.o wq.o perf.o
...
...
lib/wq.cc
浏览文件 @
ebea9405
...
...
@@ -21,6 +21,8 @@ public:
private
:
work
*
steal
(
int
c
);
work
*
pop
(
int
c
);
void
inclen
(
int
c
);
void
declen
(
int
c
);
struct
wqueue
{
work
*
w
[
NSLOTS
];
...
...
@@ -38,6 +40,10 @@ private:
percpu
<
wqueue
>
q_
;
percpu
<
stat
>
stat_
;
#if defined(XV6_USER)
padded_length
*
len_
;
#endif
};
static
wq
*
wq_
;
...
...
@@ -103,6 +109,10 @@ wq::wq(void)
for
(
i
=
0
;
i
<
NCPU
;
i
++
)
wqlock_init
(
&
q_
[
i
].
lock
);
#if defined(XV6_USER)
len_
=
allocklen
(
NCPU
*
sizeof
(
padded_length
));
#endif
}
void
...
...
@@ -115,6 +125,22 @@ wq::dump(void)
stat_
[
i
].
pop
,
stat_
[
i
].
steal
);
}
inline
void
wq
::
inclen
(
int
c
)
{
#if defined(XV6_USER)
__sync_fetch_and_add
(
&
len_
[
c
].
v_
,
1
);
#endif
}
inline
void
wq
::
declen
(
int
c
)
{
#if defined(XV6_USER)
__sync_fetch_and_sub
(
&
len_
[
c
].
v_
,
1
);
#endif
}
int
wq
::
push
(
work
*
w
)
{
...
...
@@ -131,6 +157,7 @@ wq::push(work *w)
q_
->
w
[
i
]
=
w
;
barrier
();
q_
->
head
++
;
inclen
(
mycpuid
());
stat_
->
push
++
;
popcli
();
return
0
;
...
...
@@ -156,6 +183,7 @@ wq::pop(int c)
i
=
(
i
-
1
)
&
(
NSLOTS
-
1
);
w
=
q
->
w
[
i
];
q
->
head
--
;
declen
(
c
);
wqlock_release
(
&
q
->
lock
);
stat_
->
pop
++
;
...
...
@@ -179,6 +207,7 @@ wq::steal(int c)
i
=
i
&
(
NSLOTS
-
1
);
w
=
q
->
w
[
i
];
q
->
tail
++
;
declen
(
c
);
wqlock_release
(
&
q
->
lock
);
stat_
->
steal
++
;
...
...
param.h
浏览文件 @
ebea9405
...
...
@@ -23,6 +23,7 @@
#define VERIFYFREE 0 // Unreliable, e.g. vma's vmnode pointer gets reused
#define ALLOC_MEMSET DEBUG
#define KSHAREDSIZE (32 << 10)
#define USERWQSIZE (1 << 14)
#define WQSHIFT 7
#define CILKENABLE 0
#if defined(HW_josmp)
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论