mirror of
https://github.com/postgres/postgres.git
synced 2025-05-06 19:59:18 +03:00
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.
This commit is contained in:
parent
055532badd
commit
c26d46ff6d
@ -2450,6 +2450,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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user