• Alvaro Herrera's avatar
    Fix old visibility bug in HeapTupleSatisfiesDirty · 706f9dd9
    Alvaro Herrera authored
    If a tuple is locked but not updated by a concurrent transaction,
    HeapTupleSatisfiesDirty would return that transaction's Xid in xmax,
    causing callers to wait on it, when it is not necessary (in fact, if the
    other transaction had used a multixact instead of a plain Xid to mark
    the tuple, HeapTupleSatisfiesDirty would have behave differently and
    *not* returned the Xmax).
    
    This bug was introduced in commit 3f7fbf85, dated December 1998,
    so it's almost 15 years old now.  However, it's hard to see this
    misbehave, because before we had NOWAIT the only consequence of this is
    that transactions would wait for slightly more time than necessary; so
    it's not surprising that this hasn't been reported yet.
    
    Craig Ringer and Andres Freund
    706f9dd9
tqual.c 43.4 KB