login
Login
/
Register
Search
Search this site:
Forums
News
Blogs
Features
Site
Home
»
Mailing list archives
»
linux-kernel
»
2010
»
November
»
11
Re: [PATCH 2/2] tracing - fix recursive user stack trace
view
thread
Previous message: [
thread
] [
date
] [
author
]
Next message: [
thread
] [
date
] [
author
]
[view in full thread]
From: Steven Rostedt
Subject:
Re: [PATCH 2/2] tracing - fix recursive user stack trace
Date: Thursday, November 11, 2010 - 2:57 pm
On Thu, 2010-11-11 at 08:13 +0800, Li Zefan wrote:
quoted text
> Jiri Olsa wrote: > > The user stack trace can fault when examining the trace. Which > > would call the do_page_fault handler, which would trace again, > > which would do the user stack trace, which would fault and call > > do_page_fault again ... > > > > Thus this is causing a recursive bug. We need to have a recursion > > detector here. > > > > I guess this is from what I reported to Redhat, triggered by > the ftrace stress test. ;) > > This patch should be the first patch, otherwise you introduce > a regression. Though it merely a problem in this case, better > avoid it.
Yeah, this should go into urgent, and the other patch can be queued for 38.
quoted text
> > A nitpick below: > > > > > Signed-off-by: Steven Rostedt <srostedt@redhat.com> > > Signed-off-by: Jiri Olsa <jolsa@redhat.com> > > --- > > kernel/trace/trace.c | 19 +++++++++++++++++++ > > 1 files changed, 19 insertions(+), 0 deletions(-) > > > > diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c > > index 82d9b81..0215e87 100644 > > --- a/kernel/trace/trace.c > > +++ b/kernel/trace/trace.c > > @@ -1284,6 +1284,8 @@ void trace_dump_stack(void) > > __ftrace_trace_stack(global_trace.buffer, flags, 3, preempt_count()); > > } > > > > +static DEFINE_PER_CPU(int, user_stack_count); > > + > > void > > ftrace_trace_userstack(struct ring_buffer *buffer, unsigned long flags, int pc) > > { > > @@ -1302,6 +1304,18 @@ ftrace_trace_userstack(struct ring_buffer *buffer, unsigned long flags, int pc) > > if (unlikely(in_nmi())) > > return; > > > > + /* > > + * prevent recursion, since the user stack tracing may > > + * trigger other kernel events. > > + */ > > + preempt_disable(); > > + if (__get_cpu_var(user_stack_count)) > > + goto out; > > + > > + __get_cpu_var(user_stack_count)++; > > + > > + > > + > > redundant blank lines.
I can pull this patch with the fix. Thanks! -- Steve
quoted text
> > > event = trace_buffer_lock_reserve(buffer, TRACE_USER_STACK, > > sizeof(*entry), flags, pc); > > if (!event) > > @@ -1319,6 +1333,11 @@ ftrace_trace_userstack(struct ring_buffer *buffer, unsigned long flags, int pc) > > save_stack_trace_user(&trace); > > if (!filter_check_discard(call, entry, buffer, event)) > > ring_buffer_unlock_commit(buffer, event); > > + > > + __get_cpu_var(user_stack_count)--; > > + > > + out: > > + preempt_enable(); > > } > > > > #ifdef UNUSED
--
unsubscribe notice
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to
majordomo@vger.kernel.org
More majordomo info at
http://vger.kernel.org/majordomo-info.html
Please read the FAQ at
http://www.tux.org/lkml/
Previous message: [
thread
] [
date
] [
author
]
Next message: [
thread
] [
date
] [
author
]
Messages in current thread:
[PATCH 2/2] tracing - fix recursive user stack trace
, Jiri Olsa
, (Wed Nov 10, 4:56 am)
Re: [PATCH 2/2] tracing - fix recursive user stack trace
, Li Zefan
, (Wed Nov 10, 5:13 pm)
Re: [PATCH 2/2] tracing - fix recursive user stack trace
, Steven Rostedt
, (Thu Nov 11, 2:57 pm)
[tip:perf/core] tracing: Fix recursive user stack trace
, tip-bot for Steven R ...
, (Thu Nov 18, 7:05 am)
Navigation
Mailing list archives
Recent posts
Popular discussions
linux-kernel
:
Mel Gorman
Re: [PATCH 1/4] vmstat: remove zone->lock from walk_zones_in_node
Guenter Roeck
Re: [lm-sensors] Location for thermal drivers
David Woodhouse
Re: RFC: Moving firmware blobs out of the kernel.
Siddha, Suresh B
Re: [PATCH 2.6.21 review I] [11/25] x86: default to physical mode on hotplug CPU k...
Peter Zijlstra
Re: [patch 4/6] mm: merge populate and nopage into fault (fixes nonlinear)
git-commits-head
:
Linux Kernel Mailing List
[MIPS] Fix potential latency problem due to non-atomic cpu_wait.
Linux Kernel Mailing List
USB: rename USB_SPEED_VARIABLE to USB_SPEED_WIRELESS
Linux Kernel Mailing List
lib/vsprintf.c: fix bug omitting minus sign of numbers (module_param)
Linux Kernel Mailing List
[Bluetooth] Initiate authentication during connection establishment
Linux Kernel Mailing List
[POWERPC] 4xx: Add ppc40x_defconfig
linux-netdev
:
MERCEDES
Your mail id has won 950,000.00 in the MERCEDES Benz Online Promo.for claims send:
David Miller
Re: [PATCH] xen/netfront: do not mark packets of length < MSS as GSO
David Miller
Re: skb_segment() questions
Shan Wei
[RFC PATCH net-next 2/5]IPv6:netfilter: Send an ICMPv6 "Fragment Reassembly Timeou...
Stanislaw Gruszka
[PATCH 1/4] bnx2x: use smp_mb() to keep ordering of read write operations
git
:
Nicolas Sebrecht
git-svn died of signal 11 (was "3 failures on test t9100 (svn)")
Junio C Hamano
Re: [PATCH 2/2] Add url.<base>.pushInsteadOf: URL rewriting for push only
Martin Langhoff
Re: [PATCH] GIT commit statistics.
Alexandre Julliard
[PATCH] gitweb: Put back shortlog instead of graphiclog in the project list.
Josh Triplett
[PATCH 2/2] Add url.<base>.pushInsteadOf: URL rewriting for push only
openbsd-misc
:
Taisto Qvist XX
Re: AMD GEODE LX-800 just works with kernel from install42.iso and kernelpanics wi...
Nico Meijer
Re: gOS Develop Kit with VIA pc-1 Processor Platform VIA C7-D
Andreas Bihlmaier
Re: jetway board sensors (Fintek F71805F)
admin
Drive a 2009 car from R799p/m
Antti Harri
Re: how to create a sha256 hash
Colocation donated by:
Syndicate