summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNathan Bossart <nathan@postgresql.org>2023-04-27 13:43:48 -0700
committerNathan Bossart <nathan@postgresql.org>2023-04-27 14:31:17 -0700
commitb72623671d9c0ead4ac219c69762246073fe2185 (patch)
tree782f73dee2dac1f8cf9289f0d3e8f9654e8ab9cb
parentdb93e739ac61332126207b16f14da93f8ecac594 (diff)
downloadpostgresql-b72623671d9c0ead4ac219c69762246073fe2185.tar.gz
Prevent underflow in KeepLogSeg().
The call to XLogGetReplicationSlotMinimumLSN() might return a greater LSN than the one given to the function. Subsequent segment number calculations might then underflow, which could result in unexpected behavior when removing or recyling WAL files. This was introduced with max_slot_wal_keep_size in c655077639. To fix, skip the block of code for replication slots if the LSN is greater. Reported-by: Xu Xingwang Author: Kyotaro Horiguchi Reviewed-by: Junwang Zhao Discussion: https://postgr.es/m/17903-4288d439dee856c6%40postgresql.org Backpatch-through: 13
-rw-r--r--src/backend/access/transam/xlog.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/backend/access/transam/xlog.c b/src/backend/access/transam/xlog.c
index 63481d826f..bc5a8e0569 100644
--- a/src/backend/access/transam/xlog.c
+++ b/src/backend/access/transam/xlog.c
@@ -7459,7 +7459,7 @@ KeepLogSeg(XLogRecPtr recptr, XLogSegNo *logSegNo)
* max_slot_wal_keep_size.
*/
keep = XLogGetReplicationSlotMinimumLSN();
- if (keep != InvalidXLogRecPtr)
+ if (keep != InvalidXLogRecPtr && keep < recptr)
{
XLByteToSeg(keep, segno, wal_segment_size);