diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2020-01-20 12:57:17 -0500 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2020-01-20 12:57:17 -0500 |
commit | b1392a9502016fcd3c93ba18ab418e11424b711e (patch) | |
tree | 7005288ec2f63421ff6d76434a9f8e37d259299b /src/backend/access/gist/gistget.c | |
parent | 98f0d283774b68895bc41413d7dd9c19e5608231 (diff) | |
download | postgresql-b1392a9502016fcd3c93ba18ab418e11424b711e.tar.gz postgresql-b1392a9502016fcd3c93ba18ab418e11424b711e.zip |
Fix pg_dump's sigTermHandler() to use _exit() not exit().
sigTermHandler() tried to be careful to invoke only operations that
are safe to do in a signal handler. But for some reason we forgot
that exit(3) is not among those, because it calls atexit handlers
that might do various random things. (pg_dump itself installs no
atexit handlers, but e.g. OpenSSL does.) That led to crashes or
lockups when attempting to terminate a parallel dump or restore
via a signal.
Fix by calling _exit() instead.
Per bug #16199 from Raúl Marín. Back-patch to all supported branches.
Discussion: https://postgr.es/m/16199-cb2f121146a96f9b@postgresql.org
Diffstat (limited to 'src/backend/access/gist/gistget.c')
0 files changed, 0 insertions, 0 deletions