aboutsummaryrefslogtreecommitdiff
path: root/src/backend/utils/adt/arrayfuncs.c
diff options
context:
space:
mode:
authorThomas Munro <tmunro@postgresql.org>2025-03-13 15:43:34 +1300
committerThomas Munro <tmunro@postgresql.org>2025-03-13 15:43:34 +1300
commit75da2bece670059f3c1a3628dfbc3d24cc9638b8 (patch)
tree85b0766df59540ecadd94781d46c7547221e2f16 /src/backend/utils/adt/arrayfuncs.c
parentd4f79865d4207bd93fa00f521638c289f036e276 (diff)
downloadpostgresql-75da2bece670059f3c1a3628dfbc3d24cc9638b8.tar.gz
postgresql-75da2bece670059f3c1a3628dfbc3d24cc9638b8.zip
Fix read_stream.c for changing io_combine_limit.
In a couple of places, read_stream.c assumed that io_combine_limit would be stable during the lifetime of a stream. That is not true in at least one unusual case: streams held by CURSORs where you could change the GUC between FETCH commands, with unpredictable results. Fix, by storing stream->io_combine_limit and referring only to that after construction. This mirrors the treatment of the other important setting {effective,maintenance}_io_concurrency, which is stored in stream->max_ios. One of the cases was the queue overflow space, which was sized for io_combine_limit and could be overrun if the GUC was increased. Since that coding was a little hard to follow, also introduce a variable for better readability instead of open-coding the arithmetic. Doing so revealed an off-by-one thinko while clamping max_pinned_buffers to INT16_MAX, though that wasn't a live bug due to the current limits on GUC values. Back-patch to 17. Discussion: https://postgr.es/m/CA%2BhUKG%2B2T9p-%2BzM6Eeou-RAJjTML6eit1qn26f9twznX59qtCA%40mail.gmail.com
Diffstat (limited to 'src/backend/utils/adt/arrayfuncs.c')
0 files changed, 0 insertions, 0 deletions