]> git.ipfire.org Git - thirdparty/postgresql.git/commitdiff
Fix memory leaks in event trigger code.
authorRobert Haas <rhaas@postgresql.org>
Tue, 7 Aug 2012 20:59:42 +0000 (16:59 -0400)
committerRobert Haas <rhaas@postgresql.org>
Tue, 7 Aug 2012 21:00:16 +0000 (17:00 -0400)
Spotted by Jeff Davis.

src/backend/utils/cache/evtcache.c

index 565dc449d166985832272b4bd43d642e9afc20bf..fc9f694e5a78999e1b5be96a3b824ec2488b6cf0 100644 (file)
@@ -84,7 +84,7 @@ BuildEventTriggerCache(void)
                 * the cache failed, then there might be some junk lying around
                 * that we want to reclaim.
                 */
-               MemoryContextReset(EventTriggerCacheContext);
+               MemoryContextResetAndDeleteChildren(EventTriggerCacheContext);
        }
        else
        {
@@ -119,8 +119,9 @@ BuildEventTriggerCache(void)
        ctl.keysize = sizeof(EventTriggerEvent);
        ctl.entrysize = sizeof(EventTriggerCacheEntry);
        ctl.hash = tag_hash;
+       ctl.hcxt = EventTriggerCacheContext;
        cache = hash_create("Event Trigger Cache", 32, &ctl,
-                                               HASH_ELEM | HASH_FUNCTION);
+                                               HASH_ELEM | HASH_FUNCTION | HASH_CONTEXT);
 
        /*
         * Prepare to scan pg_event_trigger in name order.  We use an MVCC
@@ -237,6 +238,6 @@ DecodeTextArrayToCString(Datum array, char ***cstringp)
 static void
 InvalidateEventCacheCallback(Datum arg, int cacheid, uint32 hashvalue)
 {
-       MemoryContextReset(EventTriggerCacheContext);
+       MemoryContextResetAndDeleteChildren(EventTriggerCacheContext);
        EventTriggerCache = NULL;
 }