diff options
| author | Paul Mundt <lethal@linux-sh.org> | 2010-10-12 17:55:26 -0400 |
|---|---|---|
| committer | Paul Mundt <lethal@linux-sh.org> | 2010-10-12 17:55:26 -0400 |
| commit | ace2dc7d12693545b67f15ab8cdb3d255c937713 (patch) | |
| tree | 18fa828ebe254e0137ec96a9e1cd4e146c6a7119 /arch/sh/math-emu | |
| parent | 5a30d7bfcd33c03f1f67d3e1c317eb5d6a6bc811 (diff) | |
sh: wire up perf alignment and emulation faults.
This plugs in the alignment and emulation fault reporting for perf sw
events.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh/math-emu')
| -rw-r--r-- | arch/sh/math-emu/math.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/sh/math-emu/math.c b/arch/sh/math-emu/math.c index 1fcdb1220975..f76a5090d5d1 100644 --- a/arch/sh/math-emu/math.c +++ b/arch/sh/math-emu/math.c | |||
| @@ -12,6 +12,7 @@ | |||
| 12 | #include <linux/types.h> | 12 | #include <linux/types.h> |
| 13 | #include <linux/sched.h> | 13 | #include <linux/sched.h> |
| 14 | #include <linux/signal.h> | 14 | #include <linux/signal.h> |
| 15 | #include <linux/perf_event.h> | ||
| 15 | 16 | ||
| 16 | #include <asm/system.h> | 17 | #include <asm/system.h> |
| 17 | #include <asm/uaccess.h> | 18 | #include <asm/uaccess.h> |
| @@ -619,6 +620,8 @@ int do_fpu_inst(unsigned short inst, struct pt_regs *regs) | |||
| 619 | struct task_struct *tsk = current; | 620 | struct task_struct *tsk = current; |
| 620 | struct sh_fpu_soft_struct *fpu = &(tsk->thread.xstate->softfpu); | 621 | struct sh_fpu_soft_struct *fpu = &(tsk->thread.xstate->softfpu); |
| 621 | 622 | ||
| 623 | perf_sw_event(PERF_COUNT_SW_EMULATION_FAULTS, 1, 0, regs, 0); | ||
| 624 | |||
| 622 | if (!(task_thread_info(tsk)->status & TS_USEDFPU)) { | 625 | if (!(task_thread_info(tsk)->status & TS_USEDFPU)) { |
| 623 | /* initialize once. */ | 626 | /* initialize once. */ |
| 624 | fpu_init(fpu); | 627 | fpu_init(fpu); |
