Re: Add errdetail() with PID and UID about source of termination signal

Поиск
Список
Период
Сортировка
От Andrew Dunstan
Тема Re: Add errdetail() with PID and UID about source of termination signal
Дата
Msg-id acd7c8a3-9646-4023-8938-d49eb9c6a3f1@dunslane.net
обсуждение
Ответ на Re: Add errdetail() with PID and UID about source of termination signal  (Andres Freund <andres@anarazel.de>)
Ответы Re: Add errdetail() with PID and UID about source of termination signal
Re: Add errdetail() with PID and UID about source of termination signal
Список pgsql-hackers


On 2026-04-08 We 1:01 PM, Andres Freund wrote:
Hi,

Attached is a very rough first draft for how I think this needs to look like.

Basically, SIGNAL_INFO always will pass both the signal number and extended
information along to the signal handler. The extended information is a
postgres specific struct. If the platform can't provide the extended
information, the values are instead set to some default value indicating that
the information is not known.

With that die() (and also StatementCancelHandler, ...) can just set whatever
globals it wants, without pqsignal.c needing to know about it.

It also allows us to extend the amount of information in the future. E.g. I'd
like to log the reason for a segfault (could e.g. be an OOM kill or an umapped
region) to stderr.

The annoying thing about it is needing to change nearly all the existing
references to SIG_IGN/SIG_DFL, to avoid warnings due to mismatched types.


I agree that's annoying. The only way around it I found was via some casting to/from void* that I suspect you would find a cure worse than the disease.

I reworked your patch slightly. This version fixes the translatability issue you raised earlier, makes the TAP test from the original commit more robust, and  tries to resolve your XXX issue by moving the assignment of ProcDieSenderPid/Uid inside the "if (!proc_exit_inprogress)" block.


cheers


andrew



--
Andrew Dunstan
EDB: https://www.enterprisedb.com
Вложения

В списке pgsql-hackers по дате отправления: