summaryrefslogtreecommitdiff
path: root/src/backend/optimizer/path/costsize.c
diff options
context:
space:
mode:
authorJeff Davis <jdavis@postgresql.org>2022-04-30 08:28:33 -0700
committerJeff Davis <jdavis@postgresql.org>2022-04-30 09:05:32 -0700
commited57cac84d1c5642737dab1e4c4b8cb4f0c4305f (patch)
tree5d76763674be588a0fd4f16f9d19bc157bf31324 /src/backend/optimizer/path/costsize.c
parentccd10a9bfa54c1aad3561232bf24222f1b455e1c (diff)
pg_walinspect: fix case where flush LSN is in the middle of a record.
Instability in the test for pg_walinspect revealed that pg_get_wal_records_info_till_end_of_wal(x) would try to decode all the records with a start LSN earlier than the flush LSN, even though that might include a partial record at the end of the range. In that case, read_local_xlog_page_no_wait() would return NULL when it tried to read past the flush LSN, which would be interpreted as an error by the caller. That caused a test failure only on a BF animal that had been restarted recently, but could be expected to happen in the wild quite easily depending on the alignment of various parameters. Fix by using private data in read_local_xlog_page_no_wait() to signal end-of-wal to the caller, so that it can be properly distinguished from a real error. Discussion: https://postgr.es/m/Ymd/e5eeZMNAkrXo%40paquier.xyz Discussion: https://postgr.es/m/111657.1650910309@sss.pgh.pa.us Authors: Thomas Munro, Bharath Rupireddy.
Diffstat (limited to 'src/backend/optimizer/path/costsize.c')
0 files changed, 0 insertions, 0 deletions