The previous coding attempts to destroy the DSM in this case, but
child nodes might have stored data there and still be holding onto
pointers in this case.  So don't do that.
Also, free the reader array instead of leaking it.
Extracted from two different patch versions both by Amit Kapila.
 
            /* No workers?  Then never mind. */
            if (!got_any_worker)
-               ExecShutdownGather(node);
+               ExecShutdownGatherWorkers(node);
        }
 
        /* Run plan locally if no workers or not single-copy. */
 
        for (i = 0; i < node->nreaders; ++i)
            DestroyTupleQueueReader(node->reader[i]);
+
+       pfree(node->reader);
        node->reader = NULL;
    }