Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
478a82b0
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
160
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
478a82b0
编写于
3月 18, 2006
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[PATCH] switch to use of ->key to get cfq_data by cfq_io_context
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
7670876d
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
15 addition
and
11 deletion
+15
-11
block/cfq-iosched.c
block/cfq-iosched.c
+15
-11
未找到文件。
block/cfq-iosched.c
浏览文件 @
478a82b0
...
...
@@ -1212,7 +1212,7 @@ static void cfq_free_io_context(struct cfq_io_context *cic)
*/
static
void
cfq_exit_single_io_context
(
struct
cfq_io_context
*
cic
)
{
struct
cfq_data
*
cfqd
=
cic
->
cfqq
->
cfqd
;
struct
cfq_data
*
cfqd
=
cic
->
key
;
request_queue_t
*
q
=
cfqd
->
queue
;
WARN_ON
(
!
irqs_disabled
());
...
...
@@ -1224,6 +1224,7 @@ static void cfq_exit_single_io_context(struct cfq_io_context *cic)
cfq_put_queue
(
cic
->
cfqq
);
cic
->
cfqq
=
NULL
;
cic
->
key
=
NULL
;
spin_unlock
(
q
->
queue_lock
);
}
...
...
@@ -1318,14 +1319,17 @@ static void cfq_init_prio_data(struct cfq_queue *cfqq)
cfq_clear_cfqq_prio_changed
(
cfqq
);
}
static
inline
void
changed_ioprio
(
struct
cfq_
queue
*
cfqq
)
static
inline
void
changed_ioprio
(
struct
cfq_
io_context
*
cic
)
{
if
(
cfqq
)
{
struct
cfq_data
*
cfqd
=
cfqq
->
cfqd
;
struct
cfq_data
*
cfqd
=
cic
->
key
;
struct
cfq_queue
*
cfqq
;
if
(
cfqd
)
{
spin_lock
(
cfqd
->
queue
->
queue_lock
);
cfq_mark_cfqq_prio_changed
(
cfqq
);
cfq_init_prio_data
(
cfqq
);
cfqq
=
cic
->
cfqq
;
if
(
cfqq
)
{
cfq_mark_cfqq_prio_changed
(
cfqq
);
cfq_init_prio_data
(
cfqq
);
}
spin_unlock
(
cfqd
->
queue
->
queue_lock
);
}
}
...
...
@@ -1337,10 +1341,10 @@ static int cfq_ioc_set_ioprio(struct io_context *ioc, unsigned int ioprio)
{
struct
cfq_io_context
*
cic
=
ioc
->
cic
;
changed_ioprio
(
cic
->
cfqq
);
changed_ioprio
(
cic
);
list_for_each_entry
(
cic
,
&
cic
->
list
,
list
)
changed_ioprio
(
cic
->
cfqq
);
changed_ioprio
(
cic
);
return
0
;
}
...
...
@@ -1429,10 +1433,10 @@ cfq_get_io_context(struct cfq_data *cfqd, pid_t pid, gfp_t gfp_mask)
* manually increment generic io_context usage count, it
* cannot go away since we are already holding one ref to it
*/
ioc
->
cic
=
cic
;
ioc
->
set_ioprio
=
cfq_ioc_set_ioprio
;
cic
->
ioc
=
ioc
;
cic
->
key
=
cfqd
;
ioc
->
set_ioprio
=
cfq_ioc_set_ioprio
;
ioc
->
cic
=
cic
;
}
else
{
struct
cfq_io_context
*
__cic
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录