]> granicus.if.org Git - postgresql/commit
Improve memory management for PL/Tcl functions.
authorTom Lane <tgl@sss.pgh.pa.us>
Wed, 31 Aug 2016 21:27:09 +0000 (17:27 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Wed, 31 Aug 2016 21:27:09 +0000 (17:27 -0400)
commitd062245b5bd591edf6f78bab8d6b8bb3ff69c7a6
tree0bde2e34100d5f29b1199516278b661263dc630c
parent65a588b4c3b06aefe0b00d6222598d4cff3542c2
Improve memory management for PL/Tcl functions.

Formerly, the memory used to represent a PL/Tcl function was allocated with
malloc() or in TopMemoryContext, and we'd leak it all if the function got
redefined during the session.  Instead, create a per-function context and
keep everything in or under that context.  Add a reference-counting
mechanism (like the one plpgsql has long had) so that we can safely clean
up an old function definition, either immediately if it's not being
executed or at the end of the outermost execution.

Currently, we only detect that a cached function is obsolete when we next
attempt to call that function.  So this covers the updated-definition case
but leaves cruft around after DROP FUNCTION.  It's not clear whether it's
worth installing a syscache invalidation callback to watch for drops;
none of the other PLs do, so for now we won't do it here either.

Michael Paquier and Tom Lane

Discussion: <CAB7nPqSOyAsHC6jL24J1B+oK3p=yyNoFU0Vs_B6fd2kdd5g5WQ@mail.gmail.com>
src/pl/tcl/pltcl.c