• Peter Eisentraut's avatar
    Fix crash when canceling parallel query · ad9a2747
    Peter Eisentraut authored
    elog(FATAL) would end up calling PortalCleanup(), which would call
    executor shutdown code, which could fail and crash, especially under
    parallel query.  This was introduced by
    8561e484, which did not want to mark an
    active portal as failed by a normal transaction abort anymore.  But we
    do need to do that for an elog(FATAL) exit.  Introduce a variable
    shmem_exit_inprogress similar to the existing proc_exit_inprogress, so
    we can tell whether we are in the FATAL exit scenario.
    Reported-by: default avatarAndres Freund <andres@anarazel.de>
    ad9a2747
ipc.h 2.72 KB