Kernel: Make pipe check data every 100ms
This prevents dead lock if read-end does not detect data before blocking why write-end already notified.
This commit is contained in:
parent
3b7b6beca5
commit
49133dce48
|
@ -49,7 +49,7 @@ namespace Kernel
|
||||||
if (m_writing_count == 0)
|
if (m_writing_count == 0)
|
||||||
return 0;
|
return 0;
|
||||||
LockFreeGuard lock_free(m_mutex);
|
LockFreeGuard lock_free(m_mutex);
|
||||||
TRY(Thread::current().block_or_eintr_indefinite(m_thread_blocker));
|
TRY(Thread::current().block_or_eintr_or_timeout_ms(m_thread_blocker, 100, false));
|
||||||
}
|
}
|
||||||
|
|
||||||
const size_t to_copy = BAN::Math::min<size_t>(buffer.size(), m_buffer_size);
|
const size_t to_copy = BAN::Math::min<size_t>(buffer.size(), m_buffer_size);
|
||||||
|
@ -84,7 +84,7 @@ namespace Kernel
|
||||||
while (m_buffer.size() - m_buffer_size < buffer.size())
|
while (m_buffer.size() - m_buffer_size < buffer.size())
|
||||||
{
|
{
|
||||||
LockFreeGuard lock_free(m_mutex);
|
LockFreeGuard lock_free(m_mutex);
|
||||||
TRY(Thread::current().block_or_eintr_indefinite(m_thread_blocker));
|
TRY(Thread::current().block_or_eintr_or_timeout_ms(m_thread_blocker, 100, false));
|
||||||
}
|
}
|
||||||
|
|
||||||
const size_t to_copy = buffer.size();
|
const size_t to_copy = buffer.size();
|
||||||
|
|
Loading…
Reference in New Issue