diff options
author | Andres Freund <andres@anarazel.de> | 2022-05-02 18:25:00 -0700 |
---|---|---|
committer | Andres Freund <andres@anarazel.de> | 2022-05-02 18:25:00 -0700 |
commit | 8f1537d10e83ad9c23ed2772cc28f74582b237ea (patch) | |
tree | efbc6a60cd90466453c03c294d5bfe4438b29074 /src/interfaces/libpq/test/libpq_testclient.c | |
parent | 21e184403bf92c52191d1f03dd6566a3d54dc907 (diff) | |
download | postgresql-8f1537d10e83ad9c23ed2772cc28f74582b237ea.tar.gz postgresql-8f1537d10e83ad9c23ed2772cc28f74582b237ea.zip |
Fix possibility of self-deadlock in ResolveRecoveryConflictWithBufferPin().
The tests added in 9f8a050f68d failed nearly reliably on FreeBSD in CI, and
occasionally on the buildfarm. That turns out to be caused not by a bug in the
test, but by a longstanding bug in recovery conflict handling.
The standby timeout handler, used by ResolveRecoveryConflictWithBufferPin(),
executed SendRecoveryConflictWithBufferPin() inside a signal handler. A bad
idea, because the deadlock timeout handler (or a spurious latch set) could
have interrupted ProcWaitForSignal(). If unlucky that could cause a
self-deadlock on ProcArrayLock, if the deadlock check is in
SendRecoveryConflictWithBufferPin()->CancelDBBackends().
To fix, set a flag in StandbyTimeoutHandler(), and check the flag in
ResolveRecoveryConflictWithBufferPin().
Subsequently the recovery conflict tests will be backpatched.
Discussion: https://postgr.es/m/20220413002626.udl7lll7f3o7nre7@alap3.anarazel.de
Backpatch: 10-
Diffstat (limited to 'src/interfaces/libpq/test/libpq_testclient.c')
0 files changed, 0 insertions, 0 deletions