]> git.baikalelectronics.ru Git - kernel.git/commit
writeback: remove broken rbtree_postorder_for_each_entry_safe() usage in cgwb_bdi_des...
authorTejun Heo <tj@kernel.org>
Tue, 13 Oct 2015 22:14:19 +0000 (18:14 -0400)
committerJens Axboe <axboe@fb.com>
Wed, 21 Oct 2015 14:17:29 +0000 (08:17 -0600)
commit2937dcdc183d5956f784c42e9b4a7ad3840e3aae
treed7ed4b0682df716b85b14e09e3da6337b2ee9f1d
parented26d49c9c17c5c3c38ddabe6632ca3b88214f38
writeback: remove broken rbtree_postorder_for_each_entry_safe() usage in cgwb_bdi_destroy()

603b4a262702 ("writeback: don't drain bdi_writeback_congested on bdi
destruction") added rbtree_postorder_for_each_entry_safe() which is
used to remove all entries; however, according to Cody, the iterator
isn't safe against operations which may rebalance the tree.  Fix it by
switching to repeatedly removing rb_first() until empty.

Signed-off-by: Tejun Heo <tj@kernel.org>
Reported-by: Cody P Schafer <dev@codyps.com>
Fixes: 603b4a262702 ("writeback: don't drain bdi_writeback_congested on bdi destruction")
Link: http://lkml.kernel.org/g/1443997973-1700-1-git-send-email-dev@codyps.com
Signed-off-by: Jens Axboe <axboe@fb.com>
mm/backing-dev.c