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

Mathieu Desnoyers compudj at krystal.dyndns.org
Fri Jan 9 09:51:52 EST 2009


* 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 !

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




More information about the lttng-dev mailing list