pgsql: Fix mislabeling of PROC_QUEUE->links as PGPROC, fixing UBSan on
От | Andres Freund |
---|---|
Тема | pgsql: Fix mislabeling of PROC_QUEUE->links as PGPROC, fixing UBSan on |
Дата | |
Msg-id | E1owVpR-000vY4-Jg@gemulon.postgresql.org обсуждение исходный текст |
Список | pgsql-committers |
Fix mislabeling of PROC_QUEUE->links as PGPROC, fixing UBSan on 32bit ProcSleep() used a PGPROC* variable to point to PROC_QUEUE->links.next, because that does "the right thing" with SHMQueueInsertBefore(). While that largely works, it's certainly not correct and unnecessary - we can just use SHM_QUEUE* to point to the insertion point. Noticed when testing a 32bit of postgres with undefined behavior sanitizer. UBSan noticed that sometimes the supposed PGPROC wasn't sufficiently aligned (required since 46d6e5f5679, ensured indirectly, via ShmemAllocRaw() guaranteeing cacheline alignment). For now fix this by using a SHM_QUEUE* for the insertion point. Subsequently we should replace all the use of PROC_QUEUE and SHM_QUEUE with ilist.h, but that's a larger change that we don't want to backpatch. Backpatch to all supported versions - it's useful to be able to run postgres under UBSan. Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us> Discussion: https://postgr.es/m/20221117014230.op5kmgypdv2dtqsf@awork3.anarazel.de Backpatch: 11- Branch ------ REL_12_STABLE Details ------- https://git.postgresql.org/pg/commitdiff/4cbcb7ed85b0e235300059dbbbdb83aec4ec8eaf Modified Files -------------- src/backend/storage/lmgr/proc.c | 24 ++++++++++++++---------- 1 file changed, 14 insertions(+), 10 deletions(-)
В списке pgsql-committers по дате отправления: