diff --git a/src/backend/libpq/pqsignal.c b/src/backend/libpq/pqsignal.c index 4648fe455f7f77095dcaa079231f17d8924896cd..82cdf13c388d258d8932cb711c8baa5180aed523 100644 --- a/src/backend/libpq/pqsignal.c +++ b/src/backend/libpq/pqsignal.c @@ -9,7 +9,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/libpq/pqsignal.c,v 1.16 2000/06/28 03:31:41 tgl Exp $ + * $Header: /cvsroot/pgsql/src/backend/libpq/pqsignal.c,v 1.17 2000/06/29 02:17:42 tgl Exp $ * * NOTES * This shouldn't be in libpq, but the monitor and some other @@ -61,13 +61,35 @@ pqinitmask(void) #ifdef HAVE_SIGPROCMASK sigemptyset(&UnBlockSig); sigfillset(&BlockSig); + /* + * Unmark those signals that should never be blocked. + * Some of these signal names don't exist on all platforms. Most do, + * but might as well ifdef them all for consistency... + */ +#ifdef SIGTRAP + sigdelset(&BlockSig, SIGTRAP); +#endif +#ifdef SIGABRT sigdelset(&BlockSig, SIGABRT); +#endif +#ifdef SIGILL sigdelset(&BlockSig, SIGILL); +#endif +#ifdef SIGFPE + sigdelset(&BlockSig, SIGFPE); +#endif +#ifdef SIGSEGV sigdelset(&BlockSig, SIGSEGV); +#endif +#ifdef SIGBUS sigdelset(&BlockSig, SIGBUS); - sigdelset(&BlockSig, SIGTRAP); - sigdelset(&BlockSig, SIGCONT); +#endif +#ifdef SIGSYS sigdelset(&BlockSig, SIGSYS); +#endif +#ifdef SIGCONT + sigdelset(&BlockSig, SIGCONT); +#endif #else UnBlockSig = 0; BlockSig = sigmask(SIGHUP) | sigmask(SIGQUIT) |