aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/tsacct.c
diff options
context:
space:
mode:
authorJay Lan <jlan@engr.sgi.com>2006-10-01 02:28:59 -0400
committerLinus Torvalds <torvalds@g5.osdl.org>2006-10-01 03:39:29 -0400
commit8f0ab5147951267134612570604cf8341901a80c (patch)
treed394edb3ab69396128e7971136f05fd71d863ece /kernel/tsacct.c
parent9acc1853519a0473620d424105f9d49ea5b4e62e (diff)
[PATCH] csa: convert CONFIG tag for extended accounting routines
There were a few accounting data/macros that are used in CSA but are #ifdef'ed inside CONFIG_BSD_PROCESS_ACCT. This patch is to change those ifdef's from CONFIG_BSD_PROCESS_ACCT to CONFIG_TASK_XACCT. A few defines are moved from kernel/acct.c and include/linux/acct.h to kernel/tsacct.c and include/linux/tsacct_kern.h. Signed-off-by: Jay Lan <jlan@sgi.com> Cc: Shailabh Nagar <nagar@watson.ibm.com> Cc: Balbir Singh <balbir@in.ibm.com> Cc: Jes Sorensen <jes@sgi.com> Cc: Chris Sturtivant <csturtiv@sgi.com> Cc: Tony Ernst <tee@sgi.com> Cc: Guillaume Thouvenin <guillaume.thouvenin@bull.net> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'kernel/tsacct.c')
-rw-r--r--kernel/tsacct.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/kernel/tsacct.c b/kernel/tsacct.c
index 410483490cf6..47c71daa416f 100644
--- a/kernel/tsacct.c
+++ b/kernel/tsacct.c
@@ -88,4 +88,34 @@ void xacct_add_tsk(struct taskstats *stats, struct task_struct *p)
88 stats->read_syscalls = p->syscr; 88 stats->read_syscalls = p->syscr;
89 stats->write_syscalls = p->syscw; 89 stats->write_syscalls = p->syscw;
90} 90}
91
92
93/**
94 * acct_update_integrals - update mm integral fields in task_struct
95 * @tsk: task_struct for accounting
96 */
97void acct_update_integrals(struct task_struct *tsk)
98{
99 if (likely(tsk->mm)) {
100 long delta =
101 cputime_to_jiffies(tsk->stime) - tsk->acct_stimexpd;
102
103 if (delta == 0)
104 return;
105 tsk->acct_stimexpd = tsk->stime;
106 tsk->acct_rss_mem1 += delta * get_mm_rss(tsk->mm);
107 tsk->acct_vm_mem1 += delta * tsk->mm->total_vm;
108 }
109}
110
111/**
112 * acct_clear_integrals - clear the mm integral fields in task_struct
113 * @tsk: task_struct whose accounting fields are cleared
114 */
115void acct_clear_integrals(struct task_struct *tsk)
116{
117 tsk->acct_stimexpd = 0;
118 tsk->acct_rss_mem1 = 0;
119 tsk->acct_vm_mem1 = 0;
120}
91#endif 121#endif