aboutsummaryrefslogtreecommitdiff
path: root/src/backend/commands/async.c
diff options
context:
space:
mode:
authorRobert Haas <rhaas@postgresql.org>2013-12-18 12:57:20 -0500
committerRobert Haas <rhaas@postgresql.org>2013-12-18 13:09:09 -0500
commit001a573a2011d605f2a6e10aee9996de8581d099 (patch)
tree5bec5fa0c42508d9d17ae324191f8c6d3ca7e05d /src/backend/commands/async.c
parent613c6d26bd42dd8c2dd0664315be9551475b8864 (diff)
downloadpostgresql-001a573a2011d605f2a6e10aee9996de8581d099.tar.gz
postgresql-001a573a2011d605f2a6e10aee9996de8581d099.zip
Allow on-detach callbacks for dynamic shared memory segments.
Just as backends must clean up their shared memory state (releasing lwlocks, buffer pins, etc.) before exiting, they must also perform any similar cleanups related to dynamic shared memory segments they have mapped before unmapping those segments. So add a mechanism to ensure that. Existing on_shmem_exit hooks include both "user level" cleanup such as transaction abort and removal of leftover temporary relations and also "low level" cleanup that forcibly released leftover shared memory resources. On-detach callbacks should run after the first group but before the second group, so create a new before_shmem_exit function for registering the early callbacks and keep on_shmem_exit for the regular callbacks. (An earlier draft of this patch added an additional argument to on_shmem_exit, but that had a much larger footprint and probably a substantially higher risk of breaking third party code for no real gain.) Patch by me, reviewed by KaiGai Kohei and Andres Freund.
Diffstat (limited to 'src/backend/commands/async.c')
-rw-r--r--src/backend/commands/async.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/backend/commands/async.c b/src/backend/commands/async.c
index f4526a6c4d9..5311e1fe9a8 100644
--- a/src/backend/commands/async.c
+++ b/src/backend/commands/async.c
@@ -921,7 +921,7 @@ Exec_ListenPreCommit(void)
*/
if (!unlistenExitRegistered)
{
- on_shmem_exit(Async_UnlistenOnExit, 0);
+ before_shmem_exit(Async_UnlistenOnExit, 0);
unlistenExitRegistered = true;
}