aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPeter Zijlstra <a.p.zijlstra@chello.nl>2009-06-22 08:34:35 -0400
committerIngo Molnar <mingo@elte.hu>2009-06-25 15:39:05 -0400
commit7f8b4e4e0988dadfd22330fd147ad2453e19f510 (patch)
treeb57c6b0fbfd3718dbc6f27bd7f422bb276c11469
parent41f95331b972a039f519ae0c70f051b7121f7346 (diff)
perf_counter: Add scale information to the mmap control page
Add the needed time scale to the self-profile mmap information. Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl> LKML-Reference: <new-submission> Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r--include/linux/perf_counter.h4
-rw-r--r--kernel/perf_counter.c6
2 files changed, 9 insertions, 1 deletions
diff --git a/include/linux/perf_counter.h b/include/linux/perf_counter.h
index 489d5cbfbcc..bcbf1c43ed4 100644
--- a/include/linux/perf_counter.h
+++ b/include/linux/perf_counter.h
@@ -232,12 +232,14 @@ struct perf_counter_mmap_page {
232 __u32 lock; /* seqlock for synchronization */ 232 __u32 lock; /* seqlock for synchronization */
233 __u32 index; /* hardware counter identifier */ 233 __u32 index; /* hardware counter identifier */
234 __s64 offset; /* add to hardware counter value */ 234 __s64 offset; /* add to hardware counter value */
235 __u64 time_enabled; /* time counter active */
236 __u64 time_running; /* time counter on cpu */
235 237
236 /* 238 /*
237 * Hole for extension of the self monitor capabilities 239 * Hole for extension of the self monitor capabilities
238 */ 240 */
239 241
240 __u64 __reserved[125]; /* align to 1k */ 242 __u64 __reserved[123]; /* align to 1k */
241 243
242 /* 244 /*
243 * Control data for the mmap() data buffer. 245 * Control data for the mmap() data buffer.
diff --git a/kernel/perf_counter.c b/kernel/perf_counter.c
index c2b19c11171..23614adab47 100644
--- a/kernel/perf_counter.c
+++ b/kernel/perf_counter.c
@@ -1782,6 +1782,12 @@ void perf_counter_update_userpage(struct perf_counter *counter)
1782 if (counter->state == PERF_COUNTER_STATE_ACTIVE) 1782 if (counter->state == PERF_COUNTER_STATE_ACTIVE)
1783 userpg->offset -= atomic64_read(&counter->hw.prev_count); 1783 userpg->offset -= atomic64_read(&counter->hw.prev_count);
1784 1784
1785 userpg->time_enabled = counter->total_time_enabled +
1786 atomic64_read(&counter->child_total_time_enabled);
1787
1788 userpg->time_running = counter->total_time_running +
1789 atomic64_read(&counter->child_total_time_running);
1790
1785 barrier(); 1791 barrier();
1786 ++userpg->lock; 1792 ++userpg->lock;
1787 preempt_enable(); 1793 preempt_enable();