Fix bug in KnownAssignedXidsMany(). I saw this when looking at the

assertion failure reported by Erik Rijkers, but this alone doesn't explain
the failure.
This commit is contained in:
Heikki Linnakangas 2010-03-11 09:26:59 +00:00
parent daaeac88aa
commit e0f9e2b648
1 changed files with 3 additions and 2 deletions

View File

@ -37,7 +37,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/storage/ipc/procarray.c,v 1.60 2010/02/26 02:01:00 momjian Exp $ * $PostgreSQL: pgsql/src/backend/storage/ipc/procarray.c,v 1.61 2010/03/11 09:26:59 heikki Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
@ -448,6 +448,7 @@ ProcArrayApplyRecoveryInfo(RunningTransactions running)
/* /*
* Remove stale transactions, if any. * Remove stale transactions, if any.
*/ */
Assert(TransactionIdIsValid(running->oldestRunningXid));
ExpireOldKnownAssignedTransactionIds(running->oldestRunningXid); ExpireOldKnownAssignedTransactionIds(running->oldestRunningXid);
StandbyReleaseOldLocks(running->oldestRunningXid); StandbyReleaseOldLocks(running->oldestRunningXid);
@ -2518,7 +2519,7 @@ KnownAssignedXidsRemoveMany(TransactionId xid, bool keepPreparedXacts)
if (!TransactionIdIsValid(xid) || TransactionIdPrecedes(removeXid, xid)) if (!TransactionIdIsValid(xid) || TransactionIdPrecedes(removeXid, xid))
{ {
if (keepPreparedXacts && StandbyTransactionIdIsPrepared(xid)) if (keepPreparedXacts && StandbyTransactionIdIsPrepared(removeXid))
continue; continue;
else else
{ {