diff options
author | Thomas Munro <tmunro@postgresql.org> | 2023-01-26 14:50:07 +1300 |
---|---|---|
committer | Thomas Munro <tmunro@postgresql.org> | 2023-01-26 14:55:03 +1300 |
commit | b55303792afe9e4008815bfd87a51758f5736854 (patch) | |
tree | ab074f49612f90189c1e41914379f49686e31855 /src/backend/executor/nodeFunctionscan.c | |
parent | 92fc1278786f3b135da19d11538e9d9b30f4b04a (diff) | |
download | postgresql-b55303792afe9e4008815bfd87a51758f5736854.tar.gz postgresql-b55303792afe9e4008815bfd87a51758f5736854.zip |
Fix rare sharedtuplestore.c corruption.
If the final chunk of an oversized tuple being written out to disk was
exactly 32760 bytes, it would be corrupted due to a fencepost bug.
Bug #17619. Back-patch to 11 where the code arrived.
While testing that (see test module in archives), I (tmunro) noticed
that the per-participant page counter was not initialized to zero as it
should have been; that wasn't a live bug when it was written since DSM
memory was originally always zeroed, but since 14
min_dynamic_shared_memory might be configured and it supplies non-zeroed
memory, so that is also fixed here.
Author: Dmitry Astapov <dastapov@gmail.com>
Discussion: https://postgr.es/m/17619-0de62ceda812b8b5%40postgresql.org
Diffstat (limited to 'src/backend/executor/nodeFunctionscan.c')
0 files changed, 0 insertions, 0 deletions