Cygwin: pty: Make slave read() thread-safe.
- Currently slave read() is somehow not thread-safe. This patch fixes the issue.
This commit is contained in:
parent
0b64cc6812
commit
f186f61d60
|
@ -1241,6 +1241,7 @@ fhandler_pty_slave::read (void *ptr, size_t& len)
|
||||||
time_to_wait = !vtime ? INFINITE : 100 * vtime;
|
time_to_wait = !vtime ? INFINITE : 100 * vtime;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wait_retry:
|
||||||
while (len)
|
while (len)
|
||||||
{
|
{
|
||||||
switch (cygwait (input_available_event, time_to_wait))
|
switch (cygwait (input_available_event, time_to_wait))
|
||||||
|
@ -1319,6 +1320,11 @@ fhandler_pty_slave::read (void *ptr, size_t& len)
|
||||||
}
|
}
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
if (!IsEventSignalled (input_available_event))
|
||||||
|
{ /* Maybe another thread has processed input. */
|
||||||
|
ReleaseMutex (input_mutex);
|
||||||
|
goto wait_retry;
|
||||||
|
}
|
||||||
|
|
||||||
if (!bytes_available (bytes_in_pipe))
|
if (!bytes_available (bytes_in_pipe))
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue