sched/cputime: Push time to account_steal_time() in nsecs
authorFrederic Weisbecker <fweisbec@gmail.com>
Tue, 31 Jan 2017 03:09:38 +0000 (04:09 +0100)
committerIngo Molnar <mingo@kernel.org>
Wed, 1 Feb 2017 08:13:57 +0000 (09:13 +0100)
This is one more step toward converting cputime accounting to pure nsecs.

Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Fenghua Yu <fenghua.yu@intel.com>
Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Michael Ellerman <mpe@ellerman.id.au>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Rik van Riel <riel@redhat.com>
Cc: Stanislaw Gruszka <sgruszka@redhat.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Tony Luck <tony.luck@intel.com>
Cc: Wanpeng Li <wanpeng.li@hotmail.com>
Link: http://lkml.kernel.org/r/1485832191-26889-23-git-send-email-fweisbec@gmail.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
arch/powerpc/kernel/time.c
arch/s390/kernel/vtime.c
include/linux/kernel_stat.h
kernel/sched/cputime.c

index c3931d8161900fb5701a8bfcde1f4df120f8bf62..53e5982edacf9919a8126074824349ec29455f6e 100644 (file)
@@ -402,7 +402,7 @@ void vtime_flush(struct task_struct *tsk)
                account_guest_time(tsk, acct->gtime);
 
        if (acct->steal_time)
-               account_steal_time(acct->steal_time);
+               account_steal_time(cputime_to_nsecs(acct->steal_time));
 
        if (acct->idle_time)
                account_idle_time(acct->idle_time);
index ca206d1223025d3344f308ec5e86092db3266318..1e7023c6ef237e46359bbc248763f2b239092488 100644 (file)
@@ -188,7 +188,7 @@ static int do_account_vtime(struct task_struct *tsk)
        steal = S390_lowcore.steal_timer;
        if ((s64) steal > 0) {
                S390_lowcore.steal_timer = 0;
-               account_steal_time(steal);
+               account_steal_time(cputime_to_nsecs(steal));
        }
 
        return virt_timer_forward(user + guest + system + hardirq + softirq);
index b716001ac23e2ad4bd990df01d6f2cfc7a6c8c5b..1d55d10abf9dc95d5b2505d1641f839c90b8e90c 100644 (file)
@@ -83,7 +83,7 @@ extern void account_guest_time(struct task_struct *, cputime_t);
 extern void account_system_time(struct task_struct *, int, cputime_t);
 extern void account_system_index_time(struct task_struct *, cputime_t,
                                      enum cpu_usage_stat);
-extern void account_steal_time(cputime_t);
+extern void account_steal_time(u64);
 extern void account_idle_time(cputime_t);
 
 #ifdef CONFIG_VIRT_CPU_ACCOUNTING_NATIVE
index 55d31c35833afa2de918d1d87a83d80db5d5f9aa..9a8028760930ab371573f7ae277ad0ecfe83c2c7 100644 (file)
@@ -207,11 +207,11 @@ void account_system_time(struct task_struct *p, int hardirq_offset,
  * Account for involuntary wait time.
  * @cputime: the cpu time spent in involuntary wait
  */
-void account_steal_time(cputime_t cputime)
+void account_steal_time(u64 cputime)
 {
        u64 *cpustat = kcpustat_this_cpu->cpustat;
 
-       cpustat[CPUTIME_STEAL] += cputime_to_nsecs(cputime);
+       cpustat[CPUTIME_STEAL] += cputime;
 }
 
 /*
@@ -239,14 +239,15 @@ static __always_inline cputime_t steal_account_process_time(cputime_t maxtime)
 #ifdef CONFIG_PARAVIRT
        if (static_key_false(&paravirt_steal_enabled)) {
                cputime_t steal_cputime;
-               u64 steal;
+               u64 steal, rounded;
 
                steal = paravirt_steal_clock(smp_processor_id());
                steal -= this_rq()->prev_steal_time;
 
                steal_cputime = min(nsecs_to_cputime(steal), maxtime);
-               account_steal_time(steal_cputime);
-               this_rq()->prev_steal_time += cputime_to_nsecs(steal_cputime);
+               rounded = cputime_to_nsecs(steal_cputime);
+               account_steal_time(rounded);
+               this_rq()->prev_steal_time += rounded;
 
                return steal_cputime;
        }