Commit 53c7cff7 authored by Robert Haas's avatar Robert Haas

Ensure gatherstate->nextreader is properly initialized.

The previously code worked OK as long as a Gather node was never
rescanned, or if it was rescanned, as long as it got at least as
many workers on rescan as it had originally.  But if the number
of workers ever decreased on a rescan, then it could crash.

Andreas Seltenreich
parent 093129c9
...@@ -173,6 +173,7 @@ ExecGather(GatherState *node) ...@@ -173,6 +173,7 @@ ExecGather(GatherState *node)
if (pcxt->nworkers_launched > 0) if (pcxt->nworkers_launched > 0)
{ {
node->nreaders = 0; node->nreaders = 0;
node->nextreader = 0;
node->reader = node->reader =
palloc(pcxt->nworkers_launched * sizeof(TupleQueueReader *)); palloc(pcxt->nworkers_launched * sizeof(TupleQueueReader *));
...@@ -335,6 +336,7 @@ gather_readnext(GatherState *gatherstate) ...@@ -335,6 +336,7 @@ gather_readnext(GatherState *gatherstate)
CHECK_FOR_INTERRUPTS(); CHECK_FOR_INTERRUPTS();
/* Attempt to read a tuple, but don't block if none is available. */ /* Attempt to read a tuple, but don't block if none is available. */
Assert(gatherstate->nextreader < gatherstate->nreaders);
reader = gatherstate->reader[gatherstate->nextreader]; reader = gatherstate->reader[gatherstate->nextreader];
tup = TupleQueueReaderNext(reader, true, &readerdone); tup = TupleQueueReaderNext(reader, true, &readerdone);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment