bdi: remove BDI_CAP_CGROUP_WRITEBACK
Just checking SB_I_CGROUPWB for cgroup writeback support is enough. Either the file system allocates its own bdi (e.g. btrfs), in which case it is known to support cgroup writeback, or the bdi comes from the block layer, which always supports cgroup writeback. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Jan Kara <jack@suse.cz> Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:

committed by
Jens Axboe

parent
c2e4cd57cf
commit
ed7b6b4f6e
@@ -538,7 +538,6 @@ struct request_queue *blk_alloc_queue(int node_id)
|
|||||||
if (!q->stats)
|
if (!q->stats)
|
||||||
goto fail_stats;
|
goto fail_stats;
|
||||||
|
|
||||||
q->backing_dev_info->capabilities = BDI_CAP_CGROUP_WRITEBACK;
|
|
||||||
q->node = node_id;
|
q->node = node_id;
|
||||||
|
|
||||||
atomic_set(&q->nr_active_requests_shared_sbitmap, 0);
|
atomic_set(&q->nr_active_requests_shared_sbitmap, 0);
|
||||||
|
@@ -3091,7 +3091,6 @@ int __cold open_ctree(struct super_block *sb, struct btrfs_fs_devices *fs_device
|
|||||||
goto fail_sb_buffer;
|
goto fail_sb_buffer;
|
||||||
}
|
}
|
||||||
|
|
||||||
sb->s_bdi->capabilities |= BDI_CAP_CGROUP_WRITEBACK;
|
|
||||||
sb->s_bdi->ra_pages *= btrfs_super_num_devices(disk_super);
|
sb->s_bdi->ra_pages *= btrfs_super_num_devices(disk_super);
|
||||||
sb->s_bdi->ra_pages = max(sb->s_bdi->ra_pages, SZ_4M / PAGE_SIZE);
|
sb->s_bdi->ra_pages = max(sb->s_bdi->ra_pages, SZ_4M / PAGE_SIZE);
|
||||||
|
|
||||||
|
@@ -123,7 +123,6 @@ int bdi_set_max_ratio(struct backing_dev_info *bdi, unsigned int max_ratio);
|
|||||||
* BDI_CAP_NO_ACCT_WB: Don't automatically account writeback pages
|
* BDI_CAP_NO_ACCT_WB: Don't automatically account writeback pages
|
||||||
* BDI_CAP_STRICTLIMIT: Keep number of dirty pages below bdi threshold.
|
* BDI_CAP_STRICTLIMIT: Keep number of dirty pages below bdi threshold.
|
||||||
*
|
*
|
||||||
* BDI_CAP_CGROUP_WRITEBACK: Supports cgroup-aware writeback.
|
|
||||||
* BDI_CAP_SYNCHRONOUS_IO: Device is so fast that asynchronous IO would be
|
* BDI_CAP_SYNCHRONOUS_IO: Device is so fast that asynchronous IO would be
|
||||||
* inefficient.
|
* inefficient.
|
||||||
*/
|
*/
|
||||||
@@ -233,9 +232,9 @@ int inode_congested(struct inode *inode, int cong_bits);
|
|||||||
* inode_cgwb_enabled - test whether cgroup writeback is enabled on an inode
|
* inode_cgwb_enabled - test whether cgroup writeback is enabled on an inode
|
||||||
* @inode: inode of interest
|
* @inode: inode of interest
|
||||||
*
|
*
|
||||||
* cgroup writeback requires support from both the bdi and filesystem.
|
* Cgroup writeback requires support from the filesystem. Also, both memcg and
|
||||||
* Also, both memcg and iocg have to be on the default hierarchy. Test
|
* iocg have to be on the default hierarchy. Test whether all conditions are
|
||||||
* whether all conditions are met.
|
* met.
|
||||||
*
|
*
|
||||||
* Note that the test result may change dynamically on the same inode
|
* Note that the test result may change dynamically on the same inode
|
||||||
* depending on how memcg and iocg are configured.
|
* depending on how memcg and iocg are configured.
|
||||||
@@ -247,7 +246,6 @@ static inline bool inode_cgwb_enabled(struct inode *inode)
|
|||||||
return cgroup_subsys_on_dfl(memory_cgrp_subsys) &&
|
return cgroup_subsys_on_dfl(memory_cgrp_subsys) &&
|
||||||
cgroup_subsys_on_dfl(io_cgrp_subsys) &&
|
cgroup_subsys_on_dfl(io_cgrp_subsys) &&
|
||||||
bdi_cap_account_dirty(bdi) &&
|
bdi_cap_account_dirty(bdi) &&
|
||||||
(bdi->capabilities & BDI_CAP_CGROUP_WRITEBACK) &&
|
|
||||||
(inode->i_sb->s_iflags & SB_I_CGROUPWB);
|
(inode->i_sb->s_iflags & SB_I_CGROUPWB);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user