[ltt-dev] [UST PATCH] Fix the once in a while freeze of the tests
Mathieu Desnoyers
compudj at krystal.dyndns.org
Sun Feb 20 10:17:45 EST 2011
* Mathieu Desnoyers (compudj at krystal.dyndns.org) wrote:
> * Yannick Brosseau (yannick.brosseau at gmail.com) wrote:
> > Sometimes, the thread in the read function would lock the pipe so the
> > setlinebuf would freeze on it. Set the linebuf before we create the
> > thread to fix this deadlock
>
> Can you update the description to show which locks are involved in this
> deadlock scenario ? E.g.
>
> - CPU A - CPU B
>
> function function
> lock A (taken) lock B (taken)
> lock B (waiting)
> lock A (waiting) <-- deadlock
>
> Or show it with the lock chain dependency analysis. But it's important
> to have this information along with this kind of fix.
Hrm, ok I looked at tap.c, and it's not a deadlock at all: it's rather
that the _tap_comment_stdout thread can start using pipe_r_file when it
is still uninitialized.
I'll update the comment and pull the patch.
Thanks,
Mathieu
>
> Thanks,
>
> Mathieu
> >
> > Signed-off-by: Yannick Brosseau <yannick.brosseau at gmail.com>
> > ---
> > tests/tap.c | 5 ++++-
> > 1 files changed, 4 insertions(+), 1 deletions(-)
> >
> > diff --git a/tests/tap.c b/tests/tap.c
> > index a54fd17..4bb695e 100644
> > --- a/tests/tap.c
> > +++ b/tests/tap.c
> > @@ -58,6 +58,9 @@ static void tap_comment_stdout(void)
> > goto close_pipe;
> > }
> >
> > + /* Set it before we create the reading thread */
> > + setlinebuf(pipe_r_file);
> > +
> > stdout_fileno = fileno(stdout);
> > if (stdout_fileno < 0) {
> > perror("# Couldn't get fileno for stdout!?");
> > @@ -112,7 +115,7 @@ static void tap_comment_stdout(void)
> >
> > setlinebuf(stdout);
> > setlinebuf(stderr);
> > - setlinebuf(pipe_r_file);
> > +
> >
> > return;
> >
> > --
> > 1.7.2.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
>
> _______________________________________________
> 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