Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
4bb3c5f4
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
4bb3c5f4
编写于
2月 18, 2015
作者:
P
Paul E. McKenney
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
rcu: Add rcu_expedite_gp() and rcu_unexpedite_gp() to rcutorture
Signed-off-by:
N
Paul E. McKenney
<
paulmck@linux.vnet.ibm.com
>
上级
0d39482c
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
25 addition
and
0 deletion
+25
-0
kernel/rcu/rcutorture.c
kernel/rcu/rcutorture.c
+25
-0
未找到文件。
kernel/rcu/rcutorture.c
浏览文件 @
4bb3c5f4
...
...
@@ -853,6 +853,8 @@ rcu_torture_fqs(void *arg)
static
int
rcu_torture_writer
(
void
*
arg
)
{
bool
can_expedite
=
!
rcu_gp_is_expedited
();
int
expediting
=
0
;
unsigned
long
gp_snap
;
bool
gp_cond1
=
gp_cond
,
gp_exp1
=
gp_exp
,
gp_normal1
=
gp_normal
;
bool
gp_sync1
=
gp_sync
;
...
...
@@ -865,6 +867,12 @@ rcu_torture_writer(void *arg)
int
nsynctypes
=
0
;
VERBOSE_TOROUT_STRING
(
"rcu_torture_writer task started"
);
pr_alert
(
"%s"
TORTURE_FLAG
" Grace periods expedited from boot/sysfs for %s,
\n
"
,
torture_type
,
cur_ops
->
name
);
pr_alert
(
"%s"
TORTURE_FLAG
" Testing of dynamic grace-period expediting diabled.
\n
"
,
torture_type
);
/* Initialize synctype[] array. If none set, take default. */
if
(
!
gp_cond1
&&
!
gp_exp1
&&
!
gp_normal1
&&
!
gp_sync
)
...
...
@@ -949,9 +957,26 @@ rcu_torture_writer(void *arg)
}
}
rcutorture_record_progress
(
++
rcu_torture_current_version
);
/* Cycle through nesting levels of rcu_expedite_gp() calls. */
if
(
can_expedite
&&
!
(
torture_random
(
&
rand
)
&
0xff
&
(
!!
expediting
-
1
)))
{
WARN_ON_ONCE
(
expediting
==
0
&&
rcu_gp_is_expedited
());
if
(
expediting
>=
0
)
rcu_expedite_gp
();
else
rcu_unexpedite_gp
();
if
(
++
expediting
>
3
)
expediting
=
-
expediting
;
}
rcu_torture_writer_state
=
RTWS_STUTTER
;
stutter_wait
(
"rcu_torture_writer"
);
}
while
(
!
torture_must_stop
());
/* Reset expediting back to unexpedited. */
if
(
expediting
>
0
)
expediting
=
-
expediting
;
while
(
can_expedite
&&
expediting
++
<
0
)
rcu_unexpedite_gp
();
WARN_ON_ONCE
(
can_expedite
&&
rcu_gp_is_expedited
());
rcu_torture_writer_state
=
RTWS_STOPPING
;
torture_kthread_stopping
(
"rcu_torture_writer"
);
return
0
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录