[ltt-dev] [UST PATCH] Fix the once in a while freeze of the tests

Yannick Brosseau yannick.brosseau at gmail.com
Sun Feb 20 10:45:09 EST 2011


On 2011-02-20 10:17, Mathieu Desnoyers wrote:
> * 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 found a lock in the calls to fgets and setlinebuf, deep in the glibc.
If what you says is true, the fix I've proposed is not right. Its the
pthread_create that should be moved.





More information about the lttng-dev mailing list