[ltt-dev] [PATCH] lttng: fix net events to check for null n->dev

Mathieu Desnoyers compudj at krystal.dyndns.org
Fri Mar 27 13:52:39 EDT 2009


* Gregory Haskins (ghaskins at novell.com) wrote:
> Hi Mathieu, LTT devs,
>   I found that I needed this patch to allow LTT 0.116 to play nice with
>   v2.6.29.  I am not 100% sure that I am not papering over a legitimate
>   issue w.r.t napi->dev being legally NULL.  But FWIW, this patch allowed
>   me to get 0.116 up and running.  Note that I saw the same issue in 0.110
>   against 29-rc8, but I didnt persue since the newer trees were available.
>   I suspect the same patch would fix things there as well.
> 
>   FWIW: The devices in question seemed to be the built-in skb-queues that
>   are used as a psuedo device when you use netif_rx().  In these cases
>   dev == NULL (not sure if this is by design).  However, since this path
>   is probably not that common unless you are using something like tuntap,
>   I suspect it might be that this has just been a latent bug in LTT.
> 

Thanks a lot for the fix !

Will merge in LTTng 0.117.

Mathieu

> Regards,
> -Greg
> 
> -------------------
> lttng: fix net events to check for null n->dev
> 
> Applies to 29-v0.116
> 
> Certain napi structures may have a NULL device, and thus will crash when
> the net-tracer'er is installed.
> 
> Signed-off-by: Gregory Haskins <ghaskins at novell.com>
> ---
> 
>  ltt/probes/net-trace.c |    6 +++---
>  1 files changed, 3 insertions(+), 3 deletions(-)
> 
> diff --git a/ltt/probes/net-trace.c b/ltt/probes/net-trace.c
> index 80254bb..80d3d9c 100644
> --- a/ltt/probes/net-trace.c
> +++ b/ltt/probes/net-trace.c
> @@ -260,7 +260,7 @@ notrace void probe_net_napi_schedule(struct napi_struct *n)
>  	data.f1 = (unsigned long)n;
>  	data_len += sizeof(data.f1);
>  	/* No need to align for strings */
> -	strcpy(data.f2, n->dev->name);
> +	strcpy(data.f2, n->dev ? n->dev->name : "<unk>");
>  	data_len += strlen(data.f2) + 1;
>  
>  	marker = &GET_MARKER(net, napi_schedule);
> @@ -283,7 +283,7 @@ notrace void probe_net_napi_poll(struct napi_struct *n)
>  	data.f1 = (unsigned long)n;
>  	data_len += sizeof(data.f1);
>  	/* No need to align for strings */
> -	strcpy(data.f2, n->dev->name);
> +	strcpy(data.f2, n->dev ? n->dev->name : "<unk>");
>  	data_len += strlen(data.f2) + 1;
>  
>  	marker = &GET_MARKER(net, napi_poll);
> @@ -306,7 +306,7 @@ notrace void probe_net_napi_complete(struct napi_struct *n)
>  	data.f1 = (unsigned long)n;
>  	data_len += sizeof(data.f1);
>  	/* No need to align for strings */
> -	strcpy(data.f2, n->dev->name);
> +	strcpy(data.f2, n->dev ? n->dev->name : "<unk>");
>  	data_len += strlen(data.f2) + 1;
>  
>  	marker = &GET_MARKER(net, napi_complete);
> 
> 
> _______________________________________________
> 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