Fixed logger thread timing logic

This commit is contained in:
SChernykh 2022-04-24 16:22:22 +02:00
parent b2f86a5f6b
commit a78ddb50d5

View file

@ -152,10 +152,13 @@ private:
do { do {
uv_mutex_lock(&m_mutex); uv_mutex_lock(&m_mutex);
if (m_readPos == m_writePos.load()) {
// Nothing to do, wait for the signal
uv_cond_wait(&m_cond, &m_mutex); uv_cond_wait(&m_cond, &m_mutex);
}
uv_mutex_unlock(&m_mutex); uv_mutex_unlock(&m_mutex);
for (uint32_t writePos = m_writePos.load(); m_readPos < writePos; writePos = m_writePos.load()) { for (uint32_t writePos = m_writePos.load(); m_readPos != writePos; writePos = m_writePos.load()) {
// We have at least one log slot pending, possibly more than one // We have at least one log slot pending, possibly more than one
// Process everything in a loop before reading m_writePos again // Process everything in a loop before reading m_writePos again
do { do {