blob: 34197079f1887a6339e4211a9aac81b3b45b9688 [file] [log] [blame]
Bharata B Rao934352f2008-11-10 20:41:13 +05301CPU Accounting Controller
2-------------------------
3
4The CPU accounting controller is used to group tasks using cgroups and
5account the CPU usage of these groups of tasks.
6
7The CPU accounting controller supports multi-hierarchy groups. An accounting
8group accumulates the CPU usage of all of its child groups and the tasks
9directly present in its group.
10
11Accounting groups can be created by first mounting the cgroup filesystem.
12
Jörg Sommerf6e07d32011-06-15 12:59:45 -070013# mount -t cgroup -ocpuacct none /sys/fs/cgroup
Bharata B Rao934352f2008-11-10 20:41:13 +053014
Jörg Sommerf6e07d32011-06-15 12:59:45 -070015With the above step, the initial or the parent accounting group becomes
16visible at /sys/fs/cgroup. At bootup, this group includes all the tasks in
17the system. /sys/fs/cgroup/tasks lists the tasks in this cgroup.
18/sys/fs/cgroup/cpuacct.usage gives the CPU time (in nanoseconds) obtained
19by this group which is essentially the CPU time obtained by all the tasks
Bharata B Rao934352f2008-11-10 20:41:13 +053020in the system.
21
Jörg Sommerf6e07d32011-06-15 12:59:45 -070022New accounting groups can be created under the parent group /sys/fs/cgroup.
Bharata B Rao934352f2008-11-10 20:41:13 +053023
Jörg Sommerf6e07d32011-06-15 12:59:45 -070024# cd /sys/fs/cgroup
Bharata B Rao934352f2008-11-10 20:41:13 +053025# mkdir g1
26# echo $$ > g1
27
28The above steps create a new group g1 and move the current shell
29process (bash) into it. CPU time consumed by this bash and its children
30can be obtained from g1/cpuacct.usage and the same is accumulated in
Jörg Sommerf6e07d32011-06-15 12:59:45 -070031/sys/fs/cgroup/cpuacct.usage also.
Bharata B Raoef12fef2009-03-31 10:02:22 +053032
33cpuacct.stat file lists a few statistics which further divide the
34CPU time obtained by the cgroup into user and system times. Currently
35the following statistics are supported:
36
37user: Time spent by tasks of the cgroup in user mode.
38system: Time spent by tasks of the cgroup in kernel mode.
39
40user and system are in USER_HZ unit.
41
Mike Chanc69233f2010-05-10 17:54:48 -070042cpuacct.cpufreq file gives CPU time (in nanoseconds) spent at each CPU
43frequency. Platform hooks must be implemented inorder to properly track
44time at each CPU frequency.
45
Mike Chanbe17d1d2010-05-12 15:52:14 -070046cpuacct.power file gives CPU power consumed (in milliWatt seconds). Platform
47must provide and implement power callback functions.
48
Bharata B Raoef12fef2009-03-31 10:02:22 +053049cpuacct controller uses percpu_counter interface to collect user and
50system times. This has two side effects:
51
52- It is theoretically possible to see wrong values for user and system times.
53 This is because percpu_counter_read() on 32bit systems isn't safe
54 against concurrent writes.
55- It is possible to see slightly outdated values for user and system times
56 due to the batch processing nature of percpu_counter.