Exit correctly from PrepareRedoRemove() when not found
authorSimon Riggs <simon@2ndQuadrant.com>
Tue, 18 Apr 2017 10:35:38 +0000 (11:35 +0100)
committerSimon Riggs <simon@2ndQuadrant.com>
Tue, 18 Apr 2017 10:35:38 +0000 (11:35 +0100)
Complex crash bug all started with this failure.
Diagnosed and fixed by Nikhil Sontakke, reviewed by me.

Reported-by: Jeff Janes
Author: Nikhil Sontakke
Discussion: https://postgr.es/m/CAMkU=1xBP8cqdS5eK8APHL=X6RHMMM2vG5g+QamduuTsyCwv9g@mail.gmail.com

src/backend/access/transam/twophase.c

index 6e6678cfff69df7a50b27a2a02064a523a6086ea..49b6429218786a292baa7bf0827447934f2cde75 100644 (file)
@@ -2375,6 +2375,7 @@ PrepareRedoRemove(TransactionId xid, bool giveWarning)
 {
    GlobalTransaction gxact = NULL;
    int         i;
+   bool        found = false;
 
    Assert(RecoveryInProgress());
 
@@ -2386,6 +2387,7 @@ PrepareRedoRemove(TransactionId xid, bool giveWarning)
        if (gxact->xid == xid)
        {
            Assert(gxact->inredo);
+           found = true;
            break;
        }
    }
@@ -2394,7 +2396,7 @@ PrepareRedoRemove(TransactionId xid, bool giveWarning)
    /*
     * Just leave if there is nothing, this is expected during WAL replay.
     */
-   if (gxact == NULL)
+   if (!found)
        return;
 
    /*