Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
cad97516
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
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看板
提交
cad97516
编写于
1月 14, 2007
作者:
J
Jens Axboe
提交者:
Jens Axboe
2月 11, 2007
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
elevator: abstract out the activate and deactivate functions
Signed-off-by:
N
Jens Axboe
<
jens.axboe@oracle.com
>
上级
958b7f37
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
20 addition
and
9 deletion
+20
-9
block/elevator.c
block/elevator.c
+20
-9
未找到文件。
block/elevator.c
浏览文件 @
cad97516
...
@@ -269,6 +269,22 @@ void elevator_exit(elevator_t *e)
...
@@ -269,6 +269,22 @@ void elevator_exit(elevator_t *e)
EXPORT_SYMBOL
(
elevator_exit
);
EXPORT_SYMBOL
(
elevator_exit
);
static
void
elv_activate_rq
(
request_queue_t
*
q
,
struct
request
*
rq
)
{
elevator_t
*
e
=
q
->
elevator
;
if
(
e
->
ops
->
elevator_activate_req_fn
)
e
->
ops
->
elevator_activate_req_fn
(
q
,
rq
);
}
static
void
elv_deactivate_rq
(
request_queue_t
*
q
,
struct
request
*
rq
)
{
elevator_t
*
e
=
q
->
elevator
;
if
(
e
->
ops
->
elevator_deactivate_req_fn
)
e
->
ops
->
elevator_deactivate_req_fn
(
q
,
rq
);
}
static
inline
void
__elv_rqhash_del
(
struct
request
*
rq
)
static
inline
void
__elv_rqhash_del
(
struct
request
*
rq
)
{
{
hlist_del_init
(
&
rq
->
hash
);
hlist_del_init
(
&
rq
->
hash
);
...
@@ -498,16 +514,14 @@ void elv_merge_requests(request_queue_t *q, struct request *rq,
...
@@ -498,16 +514,14 @@ void elv_merge_requests(request_queue_t *q, struct request *rq,
void
elv_requeue_request
(
request_queue_t
*
q
,
struct
request
*
rq
)
void
elv_requeue_request
(
request_queue_t
*
q
,
struct
request
*
rq
)
{
{
elevator_t
*
e
=
q
->
elevator
;
/*
/*
* it already went through dequeue, we need to decrement the
* it already went through dequeue, we need to decrement the
* in_flight count again
* in_flight count again
*/
*/
if
(
blk_account_rq
(
rq
))
{
if
(
blk_account_rq
(
rq
))
{
q
->
in_flight
--
;
q
->
in_flight
--
;
if
(
blk_sorted_rq
(
rq
)
&&
e
->
ops
->
elevator_deactivate_req_fn
)
if
(
blk_sorted_rq
(
rq
))
e
->
ops
->
elevator_deactivate_req_fn
(
q
,
rq
);
e
lv_deactivate_rq
(
q
,
rq
);
}
}
rq
->
cmd_flags
&=
~
REQ_STARTED
;
rq
->
cmd_flags
&=
~
REQ_STARTED
;
...
@@ -700,16 +714,13 @@ struct request *elv_next_request(request_queue_t *q)
...
@@ -700,16 +714,13 @@ struct request *elv_next_request(request_queue_t *q)
while
((
rq
=
__elv_next_request
(
q
))
!=
NULL
)
{
while
((
rq
=
__elv_next_request
(
q
))
!=
NULL
)
{
if
(
!
(
rq
->
cmd_flags
&
REQ_STARTED
))
{
if
(
!
(
rq
->
cmd_flags
&
REQ_STARTED
))
{
elevator_t
*
e
=
q
->
elevator
;
/*
/*
* This is the first time the device driver
* This is the first time the device driver
* sees this request (possibly after
* sees this request (possibly after
* requeueing). Notify IO scheduler.
* requeueing). Notify IO scheduler.
*/
*/
if
(
blk_sorted_rq
(
rq
)
&&
if
(
blk_sorted_rq
(
rq
))
e
->
ops
->
elevator_activate_req_fn
)
elv_activate_rq
(
q
,
rq
);
e
->
ops
->
elevator_activate_req_fn
(
q
,
rq
);
/*
/*
* just mark as started even if we don't start
* just mark as started even if we don't start
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录