On Wed, 2023-03-01 at 11:51 +0100, Drouvot, Bertrand wrote: > > Why not "simply" call ConditionVariablePrepareToSleep() without any > call to ConditionVariableTimedSleep() later?
ConditionVariableSleep() re-inserts itself into the queue if it was previously removed. Without that, a single wakeup could remove it from the wait queue, and the effects of ConditionVariablePrepareToSleep() would be lost. > In that case the walsender will be put in the wait queue (thanks to > ConditionVariablePrepareToSleep()) > and will be waked up by the event on the socket, the timeout or the > CV broadcast I believe it will only be awakened once, and if it enters WalSndWait() again, future ConditionVariableBroadcast/Signal() calls won't wake it up any more. > (since IIUC they all rely on the same latch). Relying on that fact seems like too much action-at-a-distance to me. If we change the implementation of condition variables, then it would stop working. Also, since they are using the same latch, that means we are still waking up too frequently, right? We haven't really solved the problem. > That looks weird to use ConditionVariablePrepareToSleep() without > actually using ConditionVariableTimedSleep() > but it looks to me that it would achieve the same goal: having the > walsender being waked up > by the event on the socket, the timeout or the CV broadcast. I don't think it actually works, because something needs to keep re- inserting it into the queue after it gets removed. You could maybe hack it to put ConditionVariablePrepareToSleep() *in* the loop, and never sleep. But that just seems like too much of a hack, and I didn't really look at the details to see if that would actually work. To use condition variables properly, I think we'd need an API like ConditionVariableEventsSleep(), which takes a WaitEventSet and a timeout. I think this is what Andres was suggesting and seems like a good idea. I looked into it and I don't think it's too hard to implement -- we just need to WaitEventSetWait instead of WaitLatch. There are a few details to sort out, like how to enable callers to easily create the right WaitEventSet (it obviously needs to include MyLatch, for instance) and update it with the right socket events. -- Jeff Davis PostgreSQL Contributor Team - AWS