Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753439Ab0L0IvR (ORCPT ); Mon, 27 Dec 2010 03:51:17 -0500 Received: from cn.fujitsu.com ([222.73.24.84]:50856 "EHLO song.cn.fujitsu.com" rhost-flags-OK-FAIL-OK-OK) by vger.kernel.org with ESMTP id S1752862Ab0L0IvM (ORCPT ); Mon, 27 Dec 2010 03:51:12 -0500 Message-ID: <4D185388.4080104@cn.fujitsu.com> Date: Mon, 27 Dec 2010 16:51:20 +0800 From: Gui Jianfeng User-Agent: Thunderbird 2.0.0.24 (Windows/20100228) MIME-Version: 1.0 To: Vivek Goyal , Jens Axboe CC: Gui Jianfeng , linux kernel mailing list , Corrado Zoccolo , Chad Talbott , Nauman Rafique , Divyesh Shah , jmoyer@redhat.com, Shaohua Li Subject: [PATCH 6/6 v3] blkio-cgroup: Document for blkio.use_hierarchy interface References: <4D180ECE.4000305@cn.fujitsu.com> In-Reply-To: <4D180ECE.4000305@cn.fujitsu.com> X-MIMETrack: Itemize by SMTP Server on mailserver/fnst(Release 8.5.1FP4|July 25, 2010) at 2010-12-27 16:51:00, Serialize by Router on mailserver/fnst(Release 8.5.1FP4|July 25, 2010) at 2010-12-27 16:51:00, Serialize complete at 2010-12-27 16:51:00 Content-Transfer-Encoding: 7bit Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4161 Lines: 114 Document for blkio.use_hierarchy interface Signed-off-by: Gui Jianfeng --- Documentation/cgroups/blkio-controller.txt | 70 ++++++++++++++++++++-------- 1 files changed, 51 insertions(+), 19 deletions(-) diff --git a/Documentation/cgroups/blkio-controller.txt b/Documentation/cgroups/blkio-controller.txt index 4ed7b5c..bd01d6c 100644 --- a/Documentation/cgroups/blkio-controller.txt +++ b/Documentation/cgroups/blkio-controller.txt @@ -91,30 +91,51 @@ Throttling/Upper Limit policy Hierarchical Cgroups ==================== -- Currently none of the IO control policy supports hierarhical groups. But - cgroup interface does allow creation of hierarhical cgroups and internally - IO policies treat them as flat hierarchy. +- Cgroup interface allows creation of hierarchical cgroups. Currently, + internally IO policies are able to treat them as flat hierarchy or + hierarchical hierarchy. Both hierarchical bandwidth division and flat + bandwidth division are supported. "blkio.use_hierarchy" can be used to + switch between flat mode and hierarchical mode. - So this patch will allow creation of cgroup hierarhcy but at the backend - everything will be treated as flat. So if somebody created a hierarchy like - as follows. + Consider the following CGroup hierarchy: - root - / \ - test1 test2 - | - test3 + Root + / | \ + Grp1 Grp2 tsk1 + / \ + Grp3 tsk2 - CFQ and throttling will practically treat all groups at same level. + If blkio.use_hierarchy is disabled in all CGroups, CFQ will practically treat all groups + at the same level. - pivot - / | \ \ - root test1 test2 test3 + Pivot tree + / | | \ + Root Grp1 Grp2 Grp3 + / | + tsk1 tsk2 - Down the line we can implement hierarchical accounting/control support - and also introduce a new cgroup file "use_hierarchy" which will control - whether cgroup hierarchy is viewed as flat or hierarchical by the policy.. - This is how memory controller also has implemented the things. + If blkio.use_hierarchy is enabled in Grp1 and Grp3, CFQ will treat groups and tasks as the + same view in CGroup hierarchy, it looks as follows. + + + Pivot tree + / | \ + Root Grp1 Grp2 + / / \ + tsk1 Grp3 tsk2 + + Root, Grp1 and Grp2 are treated at the same level under Pivot tree. tsk1 stays under Root. + Grp3 and tsk2 are treated at the same level under Grp1. Below is the mapping between + task io priority and io weight: + + prio 0 1 2 3 4 5 6 7 + weight 1000 868 740 612 484 356 228 100 + + Note1: Regardless of the use_hierarchy setting in Root group, Root group is always put onto + Pivot tree. + + Note2: Currently, "blkio.use_hierarchy" only effects proportional bandwidth division. For + Throttling logic, it still continue to treat everything as flat. Various user visible config options =================================== @@ -169,6 +190,17 @@ Proportional weight policy files dev weight 8:16 300 +- blkio.use_hierarchy + - Switch between hierarchical mode and flat mode as stated above. + blkio.use_hierarchy == 1 means hierarchical mode is enabled. + blkio.use_hierarchy == 0 means flat mode is enabled. + You can set this interface only if there isn't any child CGroup under + this CGroup. If one CGroup's blkio.use_hierarchy is set, the created + children will inherit it. it's not allowed to unset it in children. + The default mode in Root CGroup is flat. + blkio.use_hierarchy only works for proportional bandwidth division + as of today and doesn't have any effect on throttling logic. + - blkio.time - disk time allocated to cgroup per device in milliseconds. First two fields specify the major and minor number of the device and -- 1.6.5.2 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/