diff options
author | Frederic Weisbecker <fweisbec@gmail.com> | 2012-11-19 11:00:24 -0500 |
---|---|---|
committer | Frederic Weisbecker <fweisbec@gmail.com> | 2012-11-20 09:42:51 -0500 |
commit | 1b2852b152be5150fbef7b585388ec43cf6f4415 (patch) | |
tree | 8c07b611d7fe2051f4fb5c4fe75cf30f902d2f6c /arch/ia64 | |
parent | 1017769bd0073f0a73e066377cd79a10cf0a33ab (diff) |
vtime: Warn if irqs aren't disabled on system time accounting APIs
System time accounting APIs such as vtime_account_system() and
vtime_account_idle() need to be irqsafe. Current callers include
irq entry, exit and kvm, all of which have been checked against that
requirement. Now it's better to grow that with an automatic check
in case we have further callers or we missed something.
Suggested-by: Steven Rostedt <rostedt@goodmis.org>
Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Paul Gortmaker <paul.gortmaker@windriver.com>
Cc: Tony Luck <tony.luck@intel.com>
Cc: Fenghua Yu <fenghua.yu@intel.com>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
Diffstat (limited to 'arch/ia64')
-rw-r--r-- | arch/ia64/kernel/time.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/ia64/kernel/time.c b/arch/ia64/kernel/time.c index c9a7d2ebe089..b1995efbfd21 100644 --- a/arch/ia64/kernel/time.c +++ b/arch/ia64/kernel/time.c | |||
@@ -119,6 +119,8 @@ static cputime_t vtime_delta(struct task_struct *tsk) | |||
119 | cputime_t delta_stime; | 119 | cputime_t delta_stime; |
120 | __u64 now; | 120 | __u64 now; |
121 | 121 | ||
122 | WARN_ON_ONCE(!irqs_disabled()); | ||
123 | |||
122 | now = ia64_get_itc(); | 124 | now = ia64_get_itc(); |
123 | 125 | ||
124 | delta_stime = cycle_to_cputime(ti->ac_stime + (now - ti->ac_stamp)); | 126 | delta_stime = cycle_to_cputime(ti->ac_stime + (now - ti->ac_stamp)); |