diff options
author | Jean Pihet <jean.pihet@linaro.org> | 2014-07-07 09:45:08 -0400 |
---|---|---|
committer | Will Deacon <will.deacon@arm.com> | 2014-07-09 10:05:24 -0400 |
commit | a7cc91001e36a4a4152c3ada6c8fe38adc5badbc (patch) | |
tree | 32d10331079614332cf6cc465cd36d6872d873d5 | |
parent | 037e79aa958d325cfb3c733496af64199bba6b49 (diff) |
ARM: perf: Check that current->mm is alive before getting user callchain
An event may occur when an mm is already released.
As per commit 20afc60f892d285fde179ead4b24e6a7938c2f1b
'x86, perf: Check that current->mm is alive before getting user callchain'
Acked-by: Will Deacon <will.deacon@arm.com>
Signed-off-by: Jean Pihet <jean.pihet@linaro.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
-rw-r--r-- | arch/arm/kernel/perf_event.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/arch/arm/kernel/perf_event.c b/arch/arm/kernel/perf_event.c index 4238bcba9d60..6493c4c97d48 100644 --- a/arch/arm/kernel/perf_event.c +++ b/arch/arm/kernel/perf_event.c | |||
@@ -590,6 +590,10 @@ perf_callchain_user(struct perf_callchain_entry *entry, struct pt_regs *regs) | |||
590 | } | 590 | } |
591 | 591 | ||
592 | perf_callchain_store(entry, regs->ARM_pc); | 592 | perf_callchain_store(entry, regs->ARM_pc); |
593 | |||
594 | if (!current->mm) | ||
595 | return; | ||
596 | |||
593 | tail = (struct frame_tail __user *)regs->ARM_fp - 1; | 597 | tail = (struct frame_tail __user *)regs->ARM_fp - 1; |
594 | 598 | ||
595 | while ((entry->nr < PERF_MAX_STACK_DEPTH) && | 599 | while ((entry->nr < PERF_MAX_STACK_DEPTH) && |