Commit 7eb16ab1 authored by Tom Lane's avatar Tom Lane

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.
parent 01a0ca1b
...@@ -2367,6 +2367,9 @@ _SPI_error_callback(void *arg) ...@@ -2367,6 +2367,9 @@ _SPI_error_callback(void *arg)
const char *query = (const char *) arg; const char *query = (const char *) arg;
int syntaxerrposition; int syntaxerrposition;
if (query == NULL) /* in case arg wasn't set yet */
return;
/* /*
* If there is a syntax error position, convert to internal syntax error; * If there is a syntax error position, convert to internal syntax error;
* otherwise treat the query as an item of context stack * otherwise treat the query as an item of context stack
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment