[ltt-dev] [UST PATCH] Fix the once in a while freeze of the tests
Mathieu Desnoyers
compudj at krystal.dyndns.org
Sat Feb 19 19:57:51 EST 2011
* 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.
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
More information about the lttng-dev
mailing list