Add a file to configure per-cgroup maximum number of available
aio requests.

Allow write the values, which are less then currently allocated
numbers of requests.

Show numbers of currently allocated and maximum available requests.

Signed-off-by: Kirill Tkhai <ktk...@virtuozzo.com>
---
 block/blk-cgroup.c |   40 ++++++++++++++++++++++++++++++++++++++++
 1 file changed, 40 insertions(+)

diff --git a/block/blk-cgroup.c b/block/blk-cgroup.c
index 9cc6e9574946..dc5600ef4523 100644
--- a/block/blk-cgroup.c
+++ b/block/blk-cgroup.c
@@ -981,12 +981,52 @@ static int blkcg_print_stat(struct seq_file *sf, void *v)
        return 0;
 }
 
+#ifdef CONFIG_AIO
+static int blkcg_write_aio_max_nr(struct cgroup_subsys_state *css,
+                                 struct cftype *cftype, u64 val)
+{
+       struct blkcg *blkg = css_to_blkcg(css);
+       int ret = 0;
+
+       percpu_down_read(&cgroup_threadgroup_rwsem);
+       spin_lock(&aio_nr_lock);
+       if (val >= blkg->blkg_aio_nr)
+               blkg->blkg_aio_max_nr = val;
+       else
+               ret = -EBUSY;
+       spin_unlock(&aio_nr_lock);
+       percpu_up_read(&cgroup_threadgroup_rwsem);
+       return ret;
+}
+
+static int blkcg_show_aio_nrs(struct seq_file *sf, void *v)
+{
+       struct blkcg *blkg = css_to_blkcg(seq_css(sf));
+       unsigned long max_nr, nr;
+
+       spin_lock(&aio_nr_lock);
+       max_nr = blkg->blkg_aio_max_nr;
+       nr = blkg->blkg_aio_nr;
+       spin_unlock(&aio_nr_lock);
+
+       seq_printf(sf, "used=%lu, max=%lu\n", nr, max_nr);
+       return 0;
+}
+#endif /* CONFIG_AIO */
+
 static struct cftype blkcg_files[] = {
        {
                .name = "stat",
                .flags = CFTYPE_NOT_ON_ROOT,
                .seq_show = blkcg_print_stat,
        },
+#ifdef CONFIG_AIO
+       {
+               .name = "aio_nr",
+               .write_u64 = blkcg_write_aio_max_nr,
+               .seq_show = blkcg_show_aio_nrs,
+       },
+#endif
        { }     /* terminate */
 };
 

Reply via email to