提交 d3738123 编写于 作者: J Jens Axboe

blk-stat: don't use this_cpu_ptr() in a preemptable section

If PREEMPT_RCU is enabled, rcu_read_lock() isn't strong enough
for us to use this_cpu_ptr() in that section. Use the safer
get/put_cpu_ptr() variants instead.
Reported-by: NMike Galbraith <efault@gmx.de>
Fixes: 34dbad5d ("blk-stat: convert to callback-based statistics reporting")
Signed-off-by: NJens Axboe <axboe@fb.com>
上级 340ff321
...@@ -96,13 +96,16 @@ void blk_stat_add(struct request *rq) ...@@ -96,13 +96,16 @@ void blk_stat_add(struct request *rq)
rcu_read_lock(); rcu_read_lock();
list_for_each_entry_rcu(cb, &q->stats->callbacks, list) { list_for_each_entry_rcu(cb, &q->stats->callbacks, list) {
if (blk_stat_is_active(cb)) { if (!blk_stat_is_active(cb))
continue;
bucket = cb->bucket_fn(rq); bucket = cb->bucket_fn(rq);
if (bucket < 0) if (bucket < 0)
continue; continue;
stat = &this_cpu_ptr(cb->cpu_stat)[bucket];
stat = &get_cpu_ptr(cb->cpu_stat)[bucket];
__blk_stat_add(stat, value); __blk_stat_add(stat, value);
} put_cpu_ptr(cb->cpu_stat);
} }
rcu_read_unlock(); rcu_read_unlock();
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册