From: Peter Eisentraut Date: Wed, 16 Dec 2009 23:05:00 +0000 (+0000) Subject: Don't unblock SIGQUIT in the SIGQUIT handler X-Git-Tag: REL8_5_ALPHA3~24 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=d6de43099ac0bddb4b1da40088487616da892164;p=postgresql Don't unblock SIGQUIT in the SIGQUIT handler This was possibly linked to a deadlock-like situation in glibc syslog code invoked by the ereport call in quickdie(). In any case, a signal handler should not unblock its own signal unless there is a specific reason to. --- diff --git a/src/backend/tcop/postgres.c b/src/backend/tcop/postgres.c index 884748c9b1..f2e892374b 100644 --- a/src/backend/tcop/postgres.c +++ b/src/backend/tcop/postgres.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $PostgreSQL: pgsql/src/backend/tcop/postgres.c,v 1.577 2009/12/16 22:55:33 petere Exp $ + * $PostgreSQL: pgsql/src/backend/tcop/postgres.c,v 1.578 2009/12/16 23:05:00 petere Exp $ * * NOTES * this is the "main" module of the postgres backend and @@ -2538,6 +2538,7 @@ drop_unnamed_stmt(void) void quickdie(SIGNAL_ARGS) { + sigaddset(&BlockSig, SIGQUIT); /* prevent nested calls */ PG_SETMASK(&BlockSig); /* diff --git a/src/include/libpq/pqsignal.h b/src/include/libpq/pqsignal.h index 6061898b36..90237f947a 100644 --- a/src/include/libpq/pqsignal.h +++ b/src/include/libpq/pqsignal.h @@ -7,7 +7,7 @@ * Portions Copyright (c) 1996-2009, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $PostgreSQL: pgsql/src/include/libpq/pqsignal.h,v 1.35 2009/12/16 22:55:34 petere Exp $ + * $PostgreSQL: pgsql/src/include/libpq/pqsignal.h,v 1.36 2009/12/16 23:05:00 petere Exp $ * * NOTES * This shouldn't be in libpq, but the monitor and some other @@ -38,6 +38,7 @@ extern int UnBlockSig, int pqsigsetmask(int mask); #endif +#define sigaddset(set, signum) (*(set) |= (sigmask(signum))) #define sigdelset(set, signum) (*(set) &= ~(sigmask(signum))) #endif /* not HAVE_SIGPROCMASK */