mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	De-pessimize ConditionVariableCancelSleep().
Commitb91dd9dewas concerned with a theoretical problem with our non-atomic condition variable operations. If you stop sleeping, and then cancel the sleep in a separate step, you might be signaled in between, and that could be lost. That doesn't matter for callers of ConditionVariableBroadcast(), but callers of ConditionVariableSignal() might be upset if a signal went missing like this. Commitbc971f4025interacted badly with that logic, because it doesn't use ConditionVariableSleep(), which would normally put us back in the wait list. ConditionVariableCancelSleep() would be confused and think we'd received an extra signal, and try to forward it to another backend, resulting in wakeup storms. New idea: ConditionVariableCancelSleep() can just return true if we've been signaled. Hypothetical users of ConditionVariableSignal() would then still have a way to deal with rare lost signals if they are concerned about that problem. Back-patch to 16, wherebc971f4025arrived. Reported-by: Tomas Vondra <tomas.vondra@enterprisedb.com> Reviewed-by: Andres Freund <andres@anarazel.de> Discussion: https://postgr.es/m/2840876b-4cfe-240f-0a7e-29ffd66711e7%40enterprisedb.com
This commit is contained in:
		| @@ -56,7 +56,7 @@ extern void ConditionVariableInit(ConditionVariable *cv); | ||||
| extern void ConditionVariableSleep(ConditionVariable *cv, uint32 wait_event_info); | ||||
| extern bool ConditionVariableTimedSleep(ConditionVariable *cv, long timeout, | ||||
| 										uint32 wait_event_info); | ||||
| extern void ConditionVariableCancelSleep(void); | ||||
| extern bool ConditionVariableCancelSleep(void); | ||||
|  | ||||
| /* | ||||
|  * Optionally, ConditionVariablePrepareToSleep can be called before entering | ||||
|   | ||||
		Reference in New Issue
	
	Block a user