Content-Length: 260002 | pFad | http://github.com/postgrespro/postgres_cluster/commit/7eb16ab17d5c01b293aad35f0843e5f3a9a64080

AE Fix corner-case coredump in _SPI_error_callback(). · postgrespro/postgres_cluster@7eb16ab · GitHub
Skip to content

Commit 7eb16ab

Browse files
committed
Fix corner-case coredump in _SPI_error_callback().
I noticed that _SPI_execute_plan initially sets spierrcontext.arg = NULL, and only fills it in some time later. If an error were to happen in between, _SPI_error_callback would try to dereference the null pointer. This is unlikely --- there's not much between those points except push-snapshot calls --- but it's clearly not impossible. Tweak the callback to do nothing if the pointer isn't set yet. It's been like this for awhile, so back-patch to all supported branches.
1 parent 01a0ca1 commit 7eb16ab

File tree

1 file changed

+3
-0
lines changed
  • src/backend/executor

1 file changed

+3
-0
lines changed

src/backend/executor/spi.c

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2367,6 +2367,9 @@ _SPI_error_callback(void *arg)
23672367
const char *query = (const char *) arg;
23682368
int syntaxerrposition;
23692369

2370+
if (query == NULL) /* in case arg wasn't set yet */
2371+
return;
2372+
23702373
/*
23712374
* If there is a syntax error position, convert to internal syntax error;
23722375
* otherwise treat the query as an item of context stack

0 commit comments

Comments
 (0)








ApplySandwichStrip

pFad - (p)hone/(F)rame/(a)nonymizer/(d)eclutterfier!      Saves Data!


--- a PPN by Garber Painting Akron. With Image Size Reduction included!

Fetched URL: http://github.com/postgrespro/postgres_cluster/commit/7eb16ab17d5c01b293aad35f0843e5f3a9a64080

Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy