[lttng-dev] [PATCH lttng-tools 03/10] Fix: kernel tracing: flush after stop

Jérémie Galarneau jeremie.galarneau at efficios.com
Thu May 19 04:09:50 UTC 2016


Good catch, merged!

Thanks,
Jérémie

On Wed, May 18, 2016 at 2:04 PM, Mathieu Desnoyers
<mathieu.desnoyers at efficios.com> wrote:
> We should flush the last packet after stop, not before. Otherwise, we
> may end up with events written immediately after the flush, which
> defeats the purpose of flushing.
>
> Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers at efficios.com>
> ---
>  src/bin/lttng-sessiond/cmd.c | 20 ++++++++++----------
>  1 file changed, 10 insertions(+), 10 deletions(-)
>
> diff --git a/src/bin/lttng-sessiond/cmd.c b/src/bin/lttng-sessiond/cmd.c
> index 16d8ba2..d57edcd 100644
> --- a/src/bin/lttng-sessiond/cmd.c
> +++ b/src/bin/lttng-sessiond/cmd.c
> @@ -2437,7 +2437,15 @@ int cmd_stop_trace(struct ltt_session *session)
>         if (ksession && ksession->active) {
>                 DBG("Stop kernel tracing");
>
> -               /* Flush metadata if exist */
> +               ret = kernel_stop_session(ksession);
> +               if (ret < 0) {
> +                       ret = LTTNG_ERR_KERN_STOP_FAIL;
> +                       goto error;
> +               }
> +
> +               kernel_wait_quiescent(kernel_tracer_fd);
> +
> +               /* Flush metadata after stopping (if exists) */
>                 if (ksession->metadata_stream_fd >= 0) {
>                         ret = kernel_metadata_flush_buffer(ksession->metadata_stream_fd);
>                         if (ret < 0) {
> @@ -2445,7 +2453,7 @@ int cmd_stop_trace(struct ltt_session *session)
>                         }
>                 }
>
> -               /* Flush all buffers before stopping */
> +               /* Flush all buffers after stopping */
>                 cds_list_for_each_entry(kchan, &ksession->channel_list.head, list) {
>                         ret = kernel_flush_buffer(kchan);
>                         if (ret < 0) {
> @@ -2453,14 +2461,6 @@ int cmd_stop_trace(struct ltt_session *session)
>                         }
>                 }
>
> -               ret = kernel_stop_session(ksession);
> -               if (ret < 0) {
> -                       ret = LTTNG_ERR_KERN_STOP_FAIL;
> -                       goto error;
> -               }
> -
> -               kernel_wait_quiescent(kernel_tracer_fd);
> -
>                 ksession->active = 0;
>         }
>
> --
> 2.1.4
>



-- 
Jérémie Galarneau
EfficiOS Inc.
http://www.efficios.com


More information about the lttng-dev mailing list