pg_controldata: Fix possible errors on corrupted pg_control
authorAlexander Korotkov <akorotkov@postgresql.org>
Tue, 4 Feb 2025 22:15:17 +0000 (00:15 +0200)
committerAlexander Korotkov <akorotkov@postgresql.org>
Tue, 4 Feb 2025 22:45:29 +0000 (00:45 +0200)
commitf1e0b078b2e3613d28dc10090d35cc3908bbbd09
treeaf8cdfbdca16e26f5304d604d846878d90c1e65d
parent8c2dd212d1bcefa8d2cbcbe53398de367c2d5f63
pg_controldata: Fix possible errors on corrupted pg_control

Protect against malformed timestamps.  Also protect against negative WalSegSz
as it triggers division by zero:

((0x100000000UL) / (WalSegSz)) can turn into zero in

XLogFileName(xlogfilename, ControlFile->checkPointCopy.ThisTimeLineID,
             segno, WalSegSz);

because if WalSegSz is -1 then by arithmetic rules in C we get
0x100000000UL / 0xFFFFFFFFFFFFFFFFUL == 0.

Author: Ilyasov Ian <ianilyasov@outlook.com>
Author: Anton Voloshin <a.voloshin@postgrespro.ru>
Backpatch-through: 13
src/bin/pg_controldata/pg_controldata.c