Avoid memcpy() with a NULL source pointer and count == 0
authorAlvaro Herrera <alvherre@alvh.no-ip.org>
Tue, 1 Dec 2020 14:46:56 +0000 (11:46 -0300)
committerAlvaro Herrera <alvherre@alvh.no-ip.org>
Tue, 1 Dec 2020 14:46:56 +0000 (11:46 -0300)
commit677f74e5bb8360122ebf2f473d7169ed65ce4dba
treeb730cda0e3c0420e777a9bb6d6b944ff354ace2b
parent415dc2009683904f337a1837b6b4eb7f31c4dc55
Avoid memcpy() with a NULL source pointer and count == 0

When memcpy() is called on a pointer, the compiler is entitled to assume
that the pointer is not null, which can lead to optimizing nearby code
in potentially undesirable ways.  We still want such optimizations
(gcc's -fdelete-null-pointer-checks) in cases where they're valid.

Related: commit 13bba02271dc.

Backpatch to pg11, where this particular instance appeared.

Reported-by: Ranier Vilela <ranier.vf@gmail.com>
Reported-by: Zhihong Yu <zyu@yugabyte.com>
Discussion: https://postgr.es/m/CAEudQApUndmQkr5fLrCKXQ7+ib44i7S+Kk93pyVThS85PnG3bQ@mail.gmail.com
Discussion: https://postgr.es/m/CALNJ-vSdhwSM5f4tnNn1cdLHvXMVe_S+V3nR5GwNrmCPNB2VtQ@mail.gmail.com
src/backend/commands/indexcmds.c