aboutsummaryrefslogtreecommitdiffstats
path: root/block/blk-throttle.c
diff options
context:
space:
mode:
authorVivek Goyal <vgoyal@redhat.com>2011-03-02 19:05:33 -0500
committerJens Axboe <jaxboe@fusionio.com>2011-03-02 19:06:49 -0500
commitda527770007fce8e4541947d47918248286da875 (patch)
treefc518172887409133e8dea827067209adfdb1c3c /block/blk-throttle.c
parentcd25f54961273c2e4cbd47441e04832468382a5e (diff)
block: Move blk_throtl_exit() call to blk_cleanup_queue()
Move blk_throtl_exit() in blk_cleanup_queue() as blk_throtl_exit() is written in such a way that it needs queue lock. In blk_release_queue() there is no gurantee that ->queue_lock is still around. Initially blk_throtl_exit() was in blk_cleanup_queue() but Ingo reported one problem. https://lkml.org/lkml/2010/10/23/86 And a quick fix moved blk_throtl_exit() to blk_release_queue(). commit 7ad58c028652753814054f4e3ac58f925e7343f4 Author: Jens Axboe <jaxboe@fusionio.com> Date: Sat Oct 23 20:40:26 2010 +0200 block: fix use-after-free bug in blk throttle code This patch reverts above change and does not try to shutdown the throtl work in blk_sync_queue(). By avoiding call to throtl_shutdown_timer_wq() from blk_sync_queue(), we should also avoid the problem reported by Ingo. blk_sync_queue() seems to be used only by md driver and it seems to be using it to make sure q->unplug_fn is not called as md registers its own unplug functions and it is about to free up the data structures used by unplug_fn(). Block throttle does not call back into unplug_fn() or into md. So there is no need to cancel blk throttle work. In fact I think cancelling block throttle work is bad because it might happen that some bios are throttled and scheduled to be dispatched later with the help of pending work and if work is cancelled, these bios might never be dispatched. Block layer also uses blk_sync_queue() during blk_cleanup_queue() and blk_release_queue() time. That should be safe as we are also calling blk_throtl_exit() which should make sure all the throttling related data structures are cleaned up. Signed-off-by: Vivek Goyal <vgoyal@redhat.com> Signed-off-by: Jens Axboe <jaxboe@fusionio.com>
Diffstat (limited to 'block/blk-throttle.c')
-rw-r--r--block/blk-throttle.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/block/blk-throttle.c b/block/blk-throttle.c
index a89043a3caa4..c0f623742165 100644
--- a/block/blk-throttle.c
+++ b/block/blk-throttle.c
@@ -965,7 +965,7 @@ static void throtl_update_blkio_group_write_iops(void *key,
965 throtl_schedule_delayed_work(td->queue, 0); 965 throtl_schedule_delayed_work(td->queue, 0);
966} 966}
967 967
968void throtl_shutdown_timer_wq(struct request_queue *q) 968static void throtl_shutdown_wq(struct request_queue *q)
969{ 969{
970 struct throtl_data *td = q->td; 970 struct throtl_data *td = q->td;
971 971
@@ -1099,7 +1099,7 @@ void blk_throtl_exit(struct request_queue *q)
1099 1099
1100 BUG_ON(!td); 1100 BUG_ON(!td);
1101 1101
1102 throtl_shutdown_timer_wq(q); 1102 throtl_shutdown_wq(q);
1103 1103
1104 spin_lock_irq(q->queue_lock); 1104 spin_lock_irq(q->queue_lock);
1105 throtl_release_tgs(td); 1105 throtl_release_tgs(td);
@@ -1129,7 +1129,7 @@ void blk_throtl_exit(struct request_queue *q)
1129 * update limits through cgroup and another work got queued, cancel 1129 * update limits through cgroup and another work got queued, cancel
1130 * it. 1130 * it.
1131 */ 1131 */
1132 throtl_shutdown_timer_wq(q); 1132 throtl_shutdown_wq(q);
1133 throtl_td_free(td); 1133 throtl_td_free(td);
1134} 1134}
1135 1135