Prevent underflow in KeepLogSeg().
authorNathan Bossart <[email protected]>
Thu, 27 Apr 2023 20:43:48 +0000 (13:43 -0700)
committerNathan Bossart <[email protected]>
Thu, 27 Apr 2023 21:31:17 +0000 (14:31 -0700)
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

src/backend/access/transam/xlog.c

index 63481d826f74ad8c0889e0b69e4adb14b47805f2..bc5a8e05697ca035bb078034295110fb6c0cff65 100644 (file)
@@ -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);