Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
7465d7ac
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
7465d7ac
编写于
9月 17, 2020
作者:
M
Mike Snitzer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
dm: eliminate need for start_io_acct() forward declaration
Signed-off-by:
N
Mike Snitzer
<
snitzer@redhat.com
>
上级
9679b5a7
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
38 addition
and
40 deletion
+38
-40
drivers/md/dm.c
drivers/md/dm.c
+38
-40
未找到文件。
drivers/md/dm.c
浏览文件 @
7465d7ac
...
...
@@ -591,7 +591,44 @@ static int dm_blk_ioctl(struct block_device *bdev, fmode_t mode,
return
r
;
}
static
void
start_io_acct
(
struct
dm_io
*
io
);
u64
dm_start_time_ns_from_clone
(
struct
bio
*
bio
)
{
struct
dm_target_io
*
tio
=
container_of
(
bio
,
struct
dm_target_io
,
clone
);
struct
dm_io
*
io
=
tio
->
io
;
return
jiffies_to_nsecs
(
io
->
start_time
);
}
EXPORT_SYMBOL_GPL
(
dm_start_time_ns_from_clone
);
static
void
start_io_acct
(
struct
dm_io
*
io
)
{
struct
mapped_device
*
md
=
io
->
md
;
struct
bio
*
bio
=
io
->
orig_bio
;
io
->
start_time
=
bio_start_io_acct
(
bio
);
if
(
unlikely
(
dm_stats_used
(
&
md
->
stats
)))
dm_stats_account_io
(
&
md
->
stats
,
bio_data_dir
(
bio
),
bio
->
bi_iter
.
bi_sector
,
bio_sectors
(
bio
),
false
,
0
,
&
io
->
stats_aux
);
}
static
void
end_io_acct
(
struct
dm_io
*
io
)
{
struct
mapped_device
*
md
=
io
->
md
;
struct
bio
*
bio
=
io
->
orig_bio
;
unsigned
long
duration
=
jiffies
-
io
->
start_time
;
bio_end_io_acct
(
bio
,
io
->
start_time
);
if
(
unlikely
(
dm_stats_used
(
&
md
->
stats
)))
dm_stats_account_io
(
&
md
->
stats
,
bio_data_dir
(
bio
),
bio
->
bi_iter
.
bi_sector
,
bio_sectors
(
bio
),
true
,
duration
,
&
io
->
stats_aux
);
/* nudge anyone waiting on suspend queue */
if
(
unlikely
(
wq_has_sleeper
(
&
md
->
wait
)))
wake_up
(
&
md
->
wait
);
}
static
struct
dm_io
*
alloc_io
(
struct
mapped_device
*
md
,
struct
bio
*
bio
)
{
...
...
@@ -657,45 +694,6 @@ static void free_tio(struct dm_target_io *tio)
bio_put
(
&
tio
->
clone
);
}
u64
dm_start_time_ns_from_clone
(
struct
bio
*
bio
)
{
struct
dm_target_io
*
tio
=
container_of
(
bio
,
struct
dm_target_io
,
clone
);
struct
dm_io
*
io
=
tio
->
io
;
return
jiffies_to_nsecs
(
io
->
start_time
);
}
EXPORT_SYMBOL_GPL
(
dm_start_time_ns_from_clone
);
static
void
start_io_acct
(
struct
dm_io
*
io
)
{
struct
mapped_device
*
md
=
io
->
md
;
struct
bio
*
bio
=
io
->
orig_bio
;
io
->
start_time
=
bio_start_io_acct
(
bio
);
if
(
unlikely
(
dm_stats_used
(
&
md
->
stats
)))
dm_stats_account_io
(
&
md
->
stats
,
bio_data_dir
(
bio
),
bio
->
bi_iter
.
bi_sector
,
bio_sectors
(
bio
),
false
,
0
,
&
io
->
stats_aux
);
}
static
void
end_io_acct
(
struct
dm_io
*
io
)
{
struct
mapped_device
*
md
=
io
->
md
;
struct
bio
*
bio
=
io
->
orig_bio
;
unsigned
long
duration
=
jiffies
-
io
->
start_time
;
bio_end_io_acct
(
bio
,
io
->
start_time
);
if
(
unlikely
(
dm_stats_used
(
&
md
->
stats
)))
dm_stats_account_io
(
&
md
->
stats
,
bio_data_dir
(
bio
),
bio
->
bi_iter
.
bi_sector
,
bio_sectors
(
bio
),
true
,
duration
,
&
io
->
stats_aux
);
/* nudge anyone waiting on suspend queue */
if
(
unlikely
(
wq_has_sleeper
(
&
md
->
wait
)))
wake_up
(
&
md
->
wait
);
}
/*
* Add the bio to the list of deferred io.
*/
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录