[ltt-dev] [UST PATCH] Fix missing data pointer
Mathieu Desnoyers
compudj at krystal.dyndns.org
Thu Sep 30 15:13:27 EDT 2010
* David Goulet (david.goulet at polymtl.ca) wrote:
> This applies to tracepoint using a marker (trace_mark_tp)
>
> At commit 9dec086e052cf7f583a3afaa3aab48a6de8d38ac,
> the tracepoint_probe_register/unregister_noupdate function has been
> changed with the addition of a void data pointer. In set_marker(),
> the call to that function was not updated with this new parameter.
> The effect was that on a second register_trace with an already
> registered probe, the data ptr was corrupted with false data and
> thus the probe checking failed to validate duplicates. So, the same
> data was reproduced for a single trace call. Same behavior for
> unregistering the marker, it was not found.
>
> NOTE : For now, this pointer is NULL because we don't have at this
> point tracing session.
>
> Signed-off-by: David Goulet <david.goulet at polymtl.ca>
Acked-by: Mathieu Desnoyers <mathieu.desnoyers at efficios.com>
> ---
> libust/marker.c | 6 +++---
> 1 files changed, 3 insertions(+), 3 deletions(-)
>
> diff --git a/libust/marker.c b/libust/marker.c
> index 0c85cc3..cb8ffc1 100644
> --- a/libust/marker.c
> +++ b/libust/marker.c
> @@ -594,11 +594,11 @@ static int set_marker(struct marker_entry *entry, struct marker *elem,
> //ust// BUG_ON(!ret);
> ret = tracepoint_probe_register_noupdate(
> elem->tp_name,
> - elem->tp_cb);
> + elem->tp_cb, NULL);
> } else {
> ret = tracepoint_probe_unregister_noupdate(
> elem->tp_name,
> - elem->tp_cb);
> + elem->tp_cb, NULL);
> /*
> * tracepoint_probe_update_all() must be called
> * before the module containing tp_cb is unloaded.
> @@ -630,7 +630,7 @@ static void disable_marker(struct marker *elem)
> * checking has been done in the __trace_mark_tp() macro.
> */
> ret = tracepoint_probe_unregister_noupdate(elem->tp_name,
> - elem->tp_cb);
> + elem->tp_cb, NULL);
> WARN_ON(ret);
> /*
> * tracepoint_probe_update_all() must be called
> --
> 1.7.3
>
>
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
>
--
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com
More information about the lttng-dev
mailing list