[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, <t_traces.head, list)
> > _ltt_trace_stop(trace);
> > - tmp = ltt_traces.head;
> > - /* empty the original list head */
> > - INIT_LIST_HEAD(<t_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, <t_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