From: Angelo Ruocco <angeloruocc...@gmail.com>

Some of the files exposed in a cgroup by cfq have the same meaning as
the files exposed by bfq and throttle.

This commit allows these files to be shared.

Signed-off-by: Angelo Ruocco <angeloruocc...@gmail.com>
Signed-off-by: Paolo Valente <paolo.vale...@linaro.org>
---
 block/cfq-iosched.c | 49 +++++++++++++++++++++++++++++++++++++++++++++++--
 1 file changed, 47 insertions(+), 2 deletions(-)

diff --git a/block/cfq-iosched.c b/block/cfq-iosched.c
index af0c59c2dcde..f046039bdfc6 100644
--- a/block/cfq-iosched.c
+++ b/block/cfq-iosched.c
@@ -2016,7 +2016,8 @@ static struct cftype cfq_blkcg_legacy_files[] = {
        },
        {
                .name = "weight",
-               .flags = CFTYPE_NOT_ON_ROOT,
+               .owner_name = "cfq",
+               .flags = CFTYPE_NOT_ON_ROOT | CFTYPE_SHARES_FILE,
                .seq_show = cfq_print_weight,
                .write_u64 = cfq_set_weight,
        },
@@ -2035,40 +2036,56 @@ static struct cftype cfq_blkcg_legacy_files[] = {
        /* statistics, covers only the tasks in the cfqg */
        {
                .name = "time",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.time),
                .seq_show_cft = cfqg_print_stat,
        },
        {
                .name = "sectors",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .seq_show = cfqg_print_stat_sectors,
        },
        {
                .name = "io_service_bytes",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = (unsigned long)&blkcg_policy_cfq,
                .seq_show_cft = blkg_print_stat_bytes,
        },
        {
                .name = "io_serviced",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = (unsigned long)&blkcg_policy_cfq,
                .seq_show_cft = blkg_print_stat_ios,
        },
        {
                .name = "io_service_time",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.service_time),
                .seq_show_cft = cfqg_print_rwstat,
        },
        {
                .name = "io_wait_time",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.wait_time),
                .seq_show_cft = cfqg_print_rwstat,
        },
        {
                .name = "io_merged",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.merged),
                .seq_show_cft = cfqg_print_rwstat,
        },
        {
                .name = "io_queued",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.queued),
                .seq_show_cft = cfqg_print_rwstat,
        },
@@ -2076,70 +2093,97 @@ static struct cftype cfq_blkcg_legacy_files[] = {
        /* the same statictics which cover the cfqg and its descendants */
        {
                .name = "time_recursive",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.time),
                .seq_show_cft = cfqg_print_stat_recursive,
        },
        {
                .name = "sectors_recursive",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .seq_show = cfqg_print_stat_sectors_recursive,
        },
        {
                .name = "io_service_bytes_recursive",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = (unsigned long)&blkcg_policy_cfq,
                .seq_show_cft = blkg_print_stat_bytes_recursive,
        },
        {
                .name = "io_serviced_recursive",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = (unsigned long)&blkcg_policy_cfq,
                .seq_show_cft = blkg_print_stat_ios_recursive,
        },
        {
                .name = "io_service_time_recursive",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.service_time),
                .seq_show_cft = cfqg_print_rwstat_recursive,
        },
        {
                .name = "io_wait_time_recursive",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.wait_time),
                .seq_show_cft = cfqg_print_rwstat_recursive,
        },
        {
                .name = "io_merged_recursive",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.merged),
                .seq_show_cft = cfqg_print_rwstat_recursive,
        },
        {
                .name = "io_queued_recursive",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.queued),
                .seq_show_cft = cfqg_print_rwstat_recursive,
        },
 #ifdef CONFIG_DEBUG_BLK_CGROUP
        {
                .name = "avg_queue_size",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .seq_show = cfqg_print_avg_queue_size,
        },
        {
                .name = "group_wait_time",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.group_wait_time),
                .seq_show_cft = cfqg_print_stat,
        },
        {
                .name = "idle_time",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.idle_time),
                .seq_show_cft = cfqg_print_stat,
        },
        {
                .name = "empty_time",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.empty_time),
                .seq_show_cft = cfqg_print_stat,
        },
        {
                .name = "dequeue",
+               .owner_name = "cfq",
+               .flags = CFTYPE_SHARES_FILE,
                .private = offsetof(struct cfq_group, stats.dequeue),
                .seq_show_cft = cfqg_print_stat,
        },
        {
                .name = "unaccounted_time",
+               .owner_name = "cfq",
                .private = offsetof(struct cfq_group, stats.unaccounted_time),
                .seq_show_cft = cfqg_print_stat,
        },
@@ -2181,7 +2225,8 @@ static ssize_t cfq_set_weight_on_dfl(struct 
kernfs_open_file *of,
 static struct cftype cfq_blkcg_files[] = {
        {
                .name = "weight",
-               .flags = CFTYPE_NOT_ON_ROOT,
+               .owner_name = "cfq",
+               .flags = CFTYPE_NOT_ON_ROOT | CFTYPE_SHARES_FILE,
                .seq_show = cfq_print_weight_on_dfl,
                .write = cfq_set_weight_on_dfl,
        },
-- 
2.16.1

Reply via email to