Fix potential data corruption during freeze
authorTeodor Sigaev
Thu, 6 Jul 2017 14:20:37 +0000 (17:20 +0300)
committerTeodor Sigaev
Thu, 6 Jul 2017 14:20:37 +0000 (17:20 +0300)
Fix oversight in 3b97e6823b94 bug fix. Bitwise AND is used instead of OR and
it cleans all bits in t_infomask heap tuple field.

Backpatch to 9.3

src/backend/access/heap/heapam.c

index d5275be5c0a8bf8173c3f68ce2f6e919715238f3..f6007a436ce0eca00fdc3893e05f25a8fe5c87b2 100644 (file)
@@ -5929,7 +5929,7 @@ heap_prepare_freeze_tuple(HeapTupleHeader tuple, TransactionId cutoff_xid,
            frz->t_infomask &= ~HEAP_XMAX_BITS;
            frz->xmax = newxmax;
            if (flags & FRM_MARK_COMMITTED)
-               frz->t_infomask &= HEAP_XMAX_COMMITTED;
+               frz->t_infomask |= HEAP_XMAX_COMMITTED;
            changed = true;
        }
        else if (flags & FRM_RETURN_IS_MULTI)