• Tom Lane's avatar
    Only install a portal's ResourceOwner if it actually has one. · 629b3e96
    Tom Lane authored
    In most scenarios a portal without a ResourceOwner is dead and not subject
    to any further execution, but a portal for a cursor WITH HOLD remains in
    existence with no ResourceOwner after the creating transaction is over.
    In this situation, if we attempt to "execute" the portal directly to fetch
    data from it, we were setting CurrentResourceOwner to NULL, leading to a
    segfault if the datatype output code did anything that required a resource
    owner (such as trying to fetch system catalog entries that weren't already
    cached).  The case appears to be impossible to provoke with stock libpq,
    but psqlODBC at least is able to cause it when working with held cursors.
    
    Simplest fix is to just skip the assignment to CurrentResourceOwner, so
    that any resources used by the data output operations will be managed by
    the transaction-level resource owner instead.  For consistency I changed
    all the places that install a portal's resowner as current, even though
    some of them are probably not reachable with a held cursor's portal.
    
    Per report from Joshua Berry (with thanks to Hiroshi Inoue for developing
    a self-contained test case).  Back-patch to all supported versions.
    629b3e96
portalcmds.c 12.2 KB