[ltt-dev] [PATCH] lttng: Fix list-break bug

Mathieu Desnoyers compudj at krystal.dyndns.org
Fri Jan 9 10:17:20 EST 2009


* Mathieu Desnoyers (compudj at krystal.dyndns.org) wrote:
> * Gui Jianfeng (guijianfeng at cn.fujitsu.com) wrote:
> > Hi Mathieu
> > When removing ltt-tracer module, OOPS happens.
> > Because "tmp = ltt_traces.head;" breaks the list.
> > This patch fix it.
> > 
> 
> Will merge, thanks !
> 

It's now in LTTng 0.72 for 2.6.27.10.

Mathieu

> Mathieu
> 
> > Signed-off-by: Gui Jianfeng <guijianfeng at cn.fujitsu.com>
> > ---
> >  ltt/ltt-tracer.c |    6 +-----
> >  1 files changed, 1 insertions(+), 5 deletions(-)
> > 
> > diff --git a/ltt/ltt-tracer.c b/ltt/ltt-tracer.c
> > index af14135..ceb0c04 100644
> > --- a/ltt/ltt-tracer.c
> > +++ b/ltt/ltt-tracer.c
> > @@ -1159,20 +1159,16 @@ static void __exit ltt_exit(void)
> >  {
> >  	struct ltt_trace_struct *trace;
> >  	struct list_head *pos, *n;
> > -	struct list_head tmp;
> >  
> >  	ltt_lock_traces();
> >  	/* Stop each trace, currently being read by RCU read-side */
> >  	list_for_each_entry_rcu(trace, &ltt_traces.head, list)
> >  		_ltt_trace_stop(trace);
> > -	tmp = ltt_traces.head;
> > -	/* empty the original list head */
> > -	INIT_LIST_HEAD(&ltt_traces.head);
> >  	/* Wait for quiescent state. Readers have preemption disabled. */
> >  	synchronize_sched();
> >  	/* Safe iteration is now permitted. It does not have to be RCU-safe
> >  	 * because no readers are left. */
> > -	list_for_each_safe(pos, n, &tmp) {
> > +	list_for_each_safe(pos, n, &ltt_traces.head) {
> >  		trace = container_of(pos, struct ltt_trace_struct, list);
> >  		/* _ltt_trace_destroy does a synchronize_sched() */
> >  		_ltt_trace_destroy(trace);
> > -- 
> > 1.5.4.rc3
> > 
> > -- 
> > Regards
> > Gui Jianfeng
> > 
> > 
> > _______________________________________________
> > ltt-dev mailing list
> > ltt-dev at lists.casi.polymtl.ca
> > http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
> > 
> 
> -- 
> Mathieu Desnoyers
> OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F  BA06 3F25 A8FE 3BAE 9A68
> 
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
> 

-- 
Mathieu Desnoyers
OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F  BA06 3F25 A8FE 3BAE 9A68




More information about the lttng-dev mailing list