blob: a7f3d4a8f535d5995e7c07fca474ebf6ec8d3509 [file] [log] [blame]
Li Zefan60fed782013-03-29 14:36:43 +08001/* Time spent by the tasks of the cpu accounting group executing in ... */
2enum cpuacct_stat_index {
3 CPUACCT_STAT_USER, /* ... user mode */
4 CPUACCT_STAT_SYSTEM, /* ... kernel mode */
5
6 CPUACCT_STAT_NSTATS,
7};
8
9#ifdef CONFIG_CGROUP_CPUACCT
10
11#include <linux/cgroup.h>
12/* track cpu usage of a group of tasks and its child groups */
13struct cpuacct {
14 struct cgroup_subsys_state css;
15 /* cpuusage holds pointer to a u64-type object on every cpu */
16 u64 __percpu *cpuusage;
17 struct kernel_cpustat __percpu *cpustat;
18};
19
20extern struct cgroup_subsys cpuacct_subsys;
21extern struct cpuacct root_cpuacct;
22
23/* return cpu accounting group corresponding to this container */
24static inline struct cpuacct *cgroup_ca(struct cgroup *cgrp)
25{
26 return container_of(cgroup_subsys_state(cgrp, cpuacct_subsys_id),
27 struct cpuacct, css);
28}
29
30/* return cpu accounting group to which this task belongs */
31static inline struct cpuacct *task_ca(struct task_struct *tsk)
32{
33 return container_of(task_subsys_state(tsk, cpuacct_subsys_id),
34 struct cpuacct, css);
35}
36
37static inline struct cpuacct *parent_ca(struct cpuacct *ca)
38{
39 if (!ca || !ca->css.cgroup->parent)
40 return NULL;
41 return cgroup_ca(ca->css.cgroup->parent);
42}
43
44extern void cpuacct_charge(struct task_struct *tsk, u64 cputime);
45
46#else
47
48static inline void cpuacct_charge(struct task_struct *tsk, u64 cputime)
49{
50}
51
52#endif