Fix corner-case coredump in _SPI_error_callback().
authorTom Lane
Mon, 11 Dec 2017 21:33:20 +0000 (16:33 -0500)
committerTom Lane
Mon, 11 Dec 2017 21:33:54 +0000 (16:33 -0500)
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.

src/backend/executor/spi.c

index e6c8ad3e883943db111d1bb1fb477410d140f77f..1332e76b0444dea8aa616de54a194782c22bf6f0 100644 (file)
@@ -2407,6 +2407,9 @@ _SPI_error_callback(void *arg)
    const char *query = (const char *) arg;
    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;
     * otherwise treat the query as an item of context stack