summaryrefslogtreecommitdiffstats
path: root/fs/proc/uptime.c
diff options
context:
space:
mode:
authorMichael Abbott <michael.abbott@diamond.ac.uk>2009-09-24 10:15:19 +0200
committerMartin Schwidefsky <schwidefsky@de.ibm.com>2009-09-24 10:16:24 +0200
commit96830a57de1197519b62af6a4c9ceea556c18c3d (patch)
treefc92ae39a4d06e3fb2970e9fc5f6e7a46abf1df0 /fs/proc/uptime.c
parent94a8d5caba74211ec76dac80fc6e2d5c391530df (diff)
downloadop-kernel-dev-96830a57de1197519b62af6a4c9ceea556c18c3d.zip
op-kernel-dev-96830a57de1197519b62af6a4c9ceea556c18c3d.tar.gz
[PATCH] Fix idle time field in /proc/uptime
Git commit 79741dd changes idle cputime accounting, but unfortunately the /proc/uptime file hasn't caught up. Here the idle time calculation from /proc/stat is copied over. Signed-off-by: Michael Abbott <michael.abbott@diamond.ac.uk> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'fs/proc/uptime.c')
-rw-r--r--fs/proc/uptime.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/fs/proc/uptime.c b/fs/proc/uptime.c
index 0c10a0b..766b1d4 100644
--- a/fs/proc/uptime.c
+++ b/fs/proc/uptime.c
@@ -4,13 +4,18 @@
#include <linux/sched.h>
#include <linux/seq_file.h>
#include <linux/time.h>
+#include <linux/kernel_stat.h>
#include <asm/cputime.h>
static int uptime_proc_show(struct seq_file *m, void *v)
{
struct timespec uptime;
struct timespec idle;
- cputime_t idletime = cputime_add(init_task.utime, init_task.stime);
+ int i;
+ cputime_t idletime = cputime_zero;
+
+ for_each_possible_cpu(i)
+ idletime = cputime64_add(idletime, kstat_cpu(i).cpustat.idle);
do_posix_clock_monotonic_gettime(&uptime);
monotonic_to_bootbased(&uptime);
OpenPOWER on IntegriCloud