mirror of
https://github.com/postgres/postgres.git
synced 2025-06-16 06:01:02 +03:00
Verify range bounds to bms_add_range when necessary
Now that the bms_add_range boundary protections are gone, some alternative ones are needed in a few places. Author: Amit Langote <Langote_Amit_f8@lab.ntt.co.jp> Discussion: https://postgr.es/m/3437ccf8-a144-55ff-1e2f-fc16b437823b@lab.ntt.co.jp
This commit is contained in:
@ -131,6 +131,7 @@ ExecInitMergeAppend(MergeAppend *node, EState *estate, int eflags)
|
||||
{
|
||||
/* We'll need to initialize all subplans */
|
||||
nplans = list_length(node->mergeplans);
|
||||
Assert(nplans > 0);
|
||||
validsubplans = bms_add_range(NULL, 0, nplans - 1);
|
||||
}
|
||||
|
||||
@ -139,7 +140,10 @@ ExecInitMergeAppend(MergeAppend *node, EState *estate, int eflags)
|
||||
* immediately, preventing later calls to ExecFindMatchingSubPlans.
|
||||
*/
|
||||
if (!prunestate->do_exec_prune)
|
||||
{
|
||||
Assert(nplans > 0);
|
||||
mergestate->ms_valid_subplans = bms_add_range(NULL, 0, nplans - 1);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -149,6 +153,7 @@ ExecInitMergeAppend(MergeAppend *node, EState *estate, int eflags)
|
||||
* When run-time partition pruning is not enabled we can just mark all
|
||||
* subplans as valid; they must also all be initialized.
|
||||
*/
|
||||
Assert(nplans > 0);
|
||||
mergestate->ms_valid_subplans = validsubplans =
|
||||
bms_add_range(NULL, 0, nplans - 1);
|
||||
mergestate->ms_prune_state = NULL;
|
||||
|
Reference in New Issue
Block a user