diff options
author | Peter Zijlstra <a.p.zijlstra@chello.nl> | 2010-10-14 22:32:45 +0200 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2010-10-18 19:58:59 +0200 |
commit | 7e54a5a0b655734326dc78c2b5efc1eb35497bb6 (patch) | |
tree | 71346dfdb01ef387ad1aaaccbf72b3127814ce92 /include | |
parent | 82cd6def9806dcb6a325fb6abbc1d61388a15f6a (diff) | |
download | linux-7e54a5a0b655734326dc78c2b5efc1eb35497bb6.tar.gz linux-7e54a5a0b655734326dc78c2b5efc1eb35497bb6.tar.bz2 linux-7e54a5a0b655734326dc78c2b5efc1eb35497bb6.zip |
perf: Optimize sw events
Acked-by: Frederic Weisbecker <fweisbec@gmail.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <new-submission>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/perf_event.h | 20 |
1 files changed, 11 insertions, 9 deletions
diff --git a/include/linux/perf_event.h b/include/linux/perf_event.h index 7f0e7f52af8b..3b80cbf509ef 100644 --- a/include/linux/perf_event.h +++ b/include/linux/perf_event.h @@ -1012,18 +1012,20 @@ static inline void perf_fetch_caller_regs(struct pt_regs *regs) perf_arch_fetch_caller_regs(regs, CALLER_ADDR0); } -static inline void +static __always_inline void perf_sw_event(u32 event_id, u64 nr, int nmi, struct pt_regs *regs, u64 addr) { - if (atomic_read(&perf_swevent_enabled[event_id])) { - struct pt_regs hot_regs; - - if (!regs) { - perf_fetch_caller_regs(&hot_regs); - regs = &hot_regs; - } - __perf_sw_event(event_id, nr, nmi, regs, addr); + struct pt_regs hot_regs; + + JUMP_LABEL(&perf_swevent_enabled[event_id], have_event); + return; + +have_event: + if (!regs) { + perf_fetch_caller_regs(&hot_regs); + regs = &hot_regs; } + __perf_sw_event(event_id, nr, nmi, regs, addr); } extern void perf_event_mmap(struct vm_area_struct *vma); |