diff options
author | Tom Lane | 2006-12-08 00:40:33 +0000 |
---|---|---|
committer | Tom Lane | 2006-12-08 00:40:33 +0000 |
commit | 3647ff3b3a3436ca67104a0a0f8f4b8c57b7f911 (patch) | |
tree | b3bf3953888202bebf8f8ed9336c113915ee9ca6 | |
parent | 373bd34e739026e100a231f345bf4d90c900df90 (diff) |
Avoid double free of _SPI_current->tuptable. AtEOSubXact_SPI() now tries to
release it in a subtransaction abort, but this neglects possibility that
someone outside SPI already did. Fix is for spi.c to forget about a tuptable
as soon as it's handed it back to the caller.
Per bug #2817 from Michael Andreen.
-rw-r--r-- | src/backend/executor/spi.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/src/backend/executor/spi.c b/src/backend/executor/spi.c index d4fa794bc3d..53c3afa0f57 100644 --- a/src/backend/executor/spi.c +++ b/src/backend/executor/spi.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $PostgreSQL: pgsql/src/backend/executor/spi.c,v 1.165 2006/11/21 22:35:29 tgl Exp $ + * $PostgreSQL: pgsql/src/backend/executor/spi.c,v 1.165.2.1 2006/12/08 00:40:33 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -1543,6 +1543,9 @@ fail: SPI_lastoid = my_lastoid; SPI_tuptable = my_tuptable; + /* tuptable now is caller's responsibility, not SPI's */ + _SPI_current->tuptable = NULL; + return my_res; } @@ -1695,6 +1698,9 @@ _SPI_cursor_operation(Portal portal, bool forward, long count, SPI_processed = _SPI_current->processed; SPI_tuptable = _SPI_current->tuptable; + /* tuptable now is caller's responsibility, not SPI's */ + _SPI_current->tuptable = NULL; + /* Pop the SPI stack */ _SPI_end_call(true); } |