Commit eb8c9f0b authored by Michael Paquier's avatar Michael Paquier

Fix use of dangling pointer in heap_delete() when logging replica identity

When logging the replica identity of a deleted tuple, XLOG_HEAP_DELETE
records include references of the old tuple.  Its data is stored in an
intermediate variable used to register this information for the WAL
record, but this variable gets away from the stack when the record gets
actually inserted.

Spotted by clang's AddressSanitizer.

Author: Stas Kelvish
Discussion: https://postgr.es/m/085C8825-AD86-4E93-AF80-E26CDF03D1EA@postgrespro.ru
Backpatch-through: 9.4
parent f60a0e96
...@@ -3039,6 +3039,7 @@ l1: ...@@ -3039,6 +3039,7 @@ l1:
if (RelationNeedsWAL(relation)) if (RelationNeedsWAL(relation))
{ {
xl_heap_delete xlrec; xl_heap_delete xlrec;
xl_heap_header xlhdr;
XLogRecPtr recptr; XLogRecPtr recptr;
/* For logical decode we need combocids to properly decode the catalog */ /* For logical decode we need combocids to properly decode the catalog */
...@@ -3073,8 +3074,6 @@ l1: ...@@ -3073,8 +3074,6 @@ l1:
*/ */
if (old_key_tuple != NULL) if (old_key_tuple != NULL)
{ {
xl_heap_header xlhdr;
xlhdr.t_infomask2 = old_key_tuple->t_data->t_infomask2; xlhdr.t_infomask2 = old_key_tuple->t_data->t_infomask2;
xlhdr.t_infomask = old_key_tuple->t_data->t_infomask; xlhdr.t_infomask = old_key_tuple->t_data->t_infomask;
xlhdr.t_hoff = old_key_tuple->t_data->t_hoff; xlhdr.t_hoff = old_key_tuple->t_data->t_hoff;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment