<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">
From: Martin Schwidefsky &lt;schwidefsky@de.ibm.com&gt;

Use cputime type and operations in do_task_stat, process_ticks and
thread_ticks as well.

Signed-off-by: Martin Schwidefsky &lt;schwidefsky@de.ibm.com&gt;
Signed-off-by: Andrew Morton &lt;akpm@osdl.org&gt;
---

 25-akpm/fs/proc/array.c |   22 ++++++++++++----------
 kernel/posix-timers.c   |    0 
 2 files changed, 12 insertions(+), 10 deletions(-)

diff -puN fs/proc/array.c~cputime-missing-pieces fs/proc/array.c
--- 25/fs/proc/array.c~cputime-missing-pieces	2004-12-20 14:42:23.737006048 -0800
+++ 25-akpm/fs/proc/array.c	2004-12-20 14:42:23.742005288 -0800
@@ -315,8 +315,9 @@ static int do_task_stat(struct task_stru
 	int num_threads = 0;
 	struct mm_struct *mm;
 	unsigned long long start_time;
-	unsigned long cmin_flt = 0, cmaj_flt = 0, cutime = 0, cstime = 0;
-	unsigned long  min_flt = 0,  maj_flt = 0,  utime = 0,  stime = 0;
+	unsigned long cmin_flt = 0, cmaj_flt = 0;
+	unsigned long  min_flt = 0,  maj_flt = 0;
+	cputime_t cutime, cstime, utime, stime;
 	unsigned long rsslim = 0;
 	struct task_struct *t;
 	char tcomm[sizeof(task-&gt;comm)];
@@ -334,6 +335,7 @@ static int do_task_stat(struct task_stru
 
 	sigemptyset(&amp;sigign);
 	sigemptyset(&amp;sigcatch);
+	cutime = cstime = utime = stime = cputime_zero;
 	read_lock(&amp;tasklist_lock);
 	if (task-&gt;sighand) {
 		spin_lock_irq(&amp;task-&gt;sighand-&gt;siglock);
@@ -346,8 +348,8 @@ static int do_task_stat(struct task_stru
 			do {
 				min_flt += t-&gt;min_flt;
 				maj_flt += t-&gt;maj_flt;
-				utime += t-&gt;utime;
-				stime += t-&gt;stime;
+				utime = cputime_add(utime, t-&gt;utime);
+				stime = cputime_add(stime, t-&gt;stime);
 				t = next_thread(t);
 			} while (t != task);
 		}
@@ -369,8 +371,8 @@ static int do_task_stat(struct task_stru
 		if (whole) {
 			min_flt += task-&gt;signal-&gt;min_flt;
 			maj_flt += task-&gt;signal-&gt;maj_flt;
-			utime += task-&gt;signal-&gt;utime;
-			stime += task-&gt;signal-&gt;stime;
+			utime = cputime_add(utime, task-&gt;signal-&gt;utime);
+			stime = cputime_add(stime, task-&gt;signal-&gt;stime);
 		}
 	}
 	ppid = pid_alive(task) ? task-&gt;group_leader-&gt;real_parent-&gt;tgid : 0;
@@ -413,10 +415,10 @@ static int do_task_stat(struct task_stru
 		cmin_flt,
 		maj_flt,
 		cmaj_flt,
-		jiffies_to_clock_t(utime),
-		jiffies_to_clock_t(stime),
-		jiffies_to_clock_t(cutime),
-		jiffies_to_clock_t(cstime),
+		cputime_to_clock_t(utime),
+		cputime_to_clock_t(stime),
+		cputime_to_clock_t(cutime),
+		cputime_to_clock_t(cstime),
 		priority,
 		nice,
 		num_threads,
diff -puN kernel/posix-timers.c~cputime-missing-pieces kernel/posix-timers.c
_
</pre></body></html>