summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2018-10-15 14:01:38 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2018-10-15 14:01:38 -0400
commiteb01ea2a364404e69a0dbfe1545ba919c9943c63 (patch)
tree7b17fb33caf23a3f0cf138679802d6cfed2ec0c9 /src
parent7c525519d802766988f438eae9c30e3d67e1b71a (diff)
Check for stack overrun in standard_ProcessUtility().
ProcessUtility can recurse, and indeed can be driven to infinite recursion, so it ought to have a check_stack_depth() call. This covers the reported bug (portal trying to execute itself) and a bunch of other cases that could perhaps arise somewhere. Per bug #15428 from Malthe Borch. Back-patch to all supported branches. Discussion: https://postgr.es/m/15428-b3c2915ec470b033@postgresql.org
Diffstat (limited to 'src')
-rw-r--r--src/backend/tcop/utility.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/backend/tcop/utility.c b/src/backend/tcop/utility.c
index 5633d5046c2..872c2e9ce5a 100644
--- a/src/backend/tcop/utility.c
+++ b/src/backend/tcop/utility.c
@@ -333,6 +333,9 @@ standard_ProcessUtility(Node *parsetree,
{
bool isTopLevel = (context == PROCESS_UTILITY_TOPLEVEL);
+ /* This can recurse, so check for excessive recursion */
+ check_stack_depth();
+
check_xact_readonly(parsetree);
if (completionTag)