Commit c9ae5cbb authored by Tom Lane's avatar Tom Lane

Install an error check into cancel_before_shmem_exit().

Historically, cancel_before_shmem_exit() just silently did nothing
if the specified callback wasn't the top-of-stack.  The folly of
ignoring this case was exposed by the bugs fixed in 30364019 and
bab15004, so let's make it throw elog(ERROR) instead.

There is a decent argument to be made that PG_ENSURE_ERROR_CLEANUP
should use some separate infrastructure, so it wouldn't break if
something inside the guarded code decides to register a new
before_shmem_exit callback.  However, a survey of the surviving
uses of before_shmem_exit() and PG_ENSURE_ERROR_CLEANUP doesn't
show any plausible conflicts of that sort today, so for now we'll
forgo the extra complexity.  (It will almost certainly become
necessary if anyone ever wants to wrap PG_ENSURE_ERROR_CLEANUP
around arbitrary user-defined actions, though.)

No backpatch, since this is developer support not a production issue.

Bharath Rupireddy, per advice from Andres Freund, Robert Haas, and myself

Discussion: https://postgr.es/m/CALj2ACWk7j4F2v2fxxYfrroOF=AdFNPr1WsV+AGtHAFQOqm_pw@mail.gmail.com
parent 5871f09c
...@@ -381,9 +381,9 @@ on_shmem_exit(pg_on_exit_callback function, Datum arg) ...@@ -381,9 +381,9 @@ on_shmem_exit(pg_on_exit_callback function, Datum arg)
* cancel_before_shmem_exit * cancel_before_shmem_exit
* *
* this function removes a previously-registered before_shmem_exit * this function removes a previously-registered before_shmem_exit
* callback. For simplicity, only the latest entry can be * callback. We only look at the latest entry for removal, as we
* removed. (We could work harder but there is no need for * expect callers to add and remove temporary before_shmem_exit
* current uses.) * callbacks in strict LIFO order.
* ---------------------------------------------------------------- * ----------------------------------------------------------------
*/ */
void void
...@@ -394,6 +394,9 @@ cancel_before_shmem_exit(pg_on_exit_callback function, Datum arg) ...@@ -394,6 +394,9 @@ cancel_before_shmem_exit(pg_on_exit_callback function, Datum arg)
== function && == function &&
before_shmem_exit_list[before_shmem_exit_index - 1].arg == arg) before_shmem_exit_list[before_shmem_exit_index - 1].arg == arg)
--before_shmem_exit_index; --before_shmem_exit_index;
else
elog(ERROR, "before_shmem_exit callback (%p,0x%llx) is not the latest entry",
function, (long long) arg);
} }
/* ---------------------------------------------------------------- /* ----------------------------------------------------------------
......
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