]> granicus.if.org Git - postgresql/commitdiff
recoveryStopsHere() must check the resource manager ID.
authorRobert Haas <rhaas@postgresql.org>
Mon, 18 Apr 2011 12:27:19 +0000 (08:27 -0400)
committerRobert Haas <rhaas@postgresql.org>
Mon, 18 Apr 2011 12:27:19 +0000 (08:27 -0400)
Before commit c016ce728139be95bb0dc7c4e5640507334c2339, this wasn't
needed, but now that multiple resource manager IDs can percolate down
through here, we have to make sure we know which one we've got.
Otherwise, we can confuse (for example) an XLOG_XACT_COMMIT record
with an XLOG_CHECKPOINT_SHUTDOWN record.

Review by Jaime Casanova

src/backend/access/transam/xlog.c

index 742d8551f6a7d01f9c3284169901c9bb21222878..b0e4c41d6f1c8cc66889967743174e527bba2360 100644 (file)
@@ -5583,21 +5583,21 @@ recoveryStopsHere(XLogRecord *record, bool *includeThis)
        if (record->xl_rmid != RM_XACT_ID && record->xl_rmid != RM_XLOG_ID)
                return false;
        record_info = record->xl_info & ~XLR_INFO_MASK;
-       if (record_info == XLOG_XACT_COMMIT)
+       if (record->xl_rmid == RM_XACT_ID && record_info == XLOG_XACT_COMMIT)
        {
                xl_xact_commit *recordXactCommitData;
 
                recordXactCommitData = (xl_xact_commit *) XLogRecGetData(record);
                recordXtime = recordXactCommitData->xact_time;
        }
-       else if (record_info == XLOG_XACT_ABORT)
+       else if (record->xl_rmid == RM_XACT_ID && record_info == XLOG_XACT_ABORT)
        {
                xl_xact_abort *recordXactAbortData;
 
                recordXactAbortData = (xl_xact_abort *) XLogRecGetData(record);
                recordXtime = recordXactAbortData->xact_time;
        }
-       else if (record_info == XLOG_RESTORE_POINT)
+       else if (record->xl_rmid == RM_XLOG_ID && record_info == XLOG_RESTORE_POINT)
        {
                xl_restore_point *recordRestorePointData;