summaryrefslogtreecommitdiff
path: root/usr
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2015-05-22 18:23:24 -0400
committerJens Axboe <axboe@fb.com>2015-06-02 08:38:13 -0600
commit970fb01ad3a773b5612a9bba6b366abcefc18eaf (patch)
tree933b21007334e1aa1f984e20a0e5e6aef4d41dee /usr
parent2bc00aef030f4f75550d5c88062ce1830e40097f (diff)
downloadlwn-970fb01ad3a773b5612a9bba6b366abcefc18eaf.tar.gz
lwn-970fb01ad3a773b5612a9bba6b366abcefc18eaf.zip
writeback: add dirty_throttle_control->wb_bg_thresh
wb_bg_thresh is currently treated as a second-class citizen. It's only used when BDI_CAP_STRICTLIMIT is set and balance_dirty_pages() doesn't calculate it unless the cap is set. When the cap is set, the calculated value is not passed around but instead recalculated whenever it's used. wb_position_ratio() calculates it by scaling wb_thresh proportional to bg_thresh / thresh. wb_update_dirty_ratelimit() uses wb_dirty_limit() on bg_thresh, which should generally lead to a similar result as the proportional scaling but can also be way off in the presence of max/min_ratio settings. Avoiding wb_bg_thresh calculation saves us one u64 multiplication and divsion when BDI_CAP_STRICTLIMIT is not set. Given that balance_dirty_pages() is already ratelimited, this doesn't justify the incurred extra complexity. This patch adds wb_bg_thresh to dirty_throttle_control and makes wb_dirty_limits() always calculate it and updates the users to use the pre-calculated value. Signed-off-by: Tejun Heo <tj@kernel.org> Cc: Jens Axboe <axboe@kernel.dk> Cc: Jan Kara <jack@suse.cz> Cc: Wu Fengguang <fengguang.wu@intel.com> Cc: Greg Thelen <gthelen@google.com> Signed-off-by: Jens Axboe <axboe@fb.com>
Diffstat (limited to 'usr')
0 files changed, 0 insertions, 0 deletions