/*
  * PgArchCanRestart
  *
- * Return true and archiver is allowed to restart if enough time has
- * passed since it was launched last to reach PGARCH_RESTART_INTERVAL.
+ * Return true, indicating archiver is allowed to restart, if enough time has
+ * passed since it was last launched to reach PGARCH_RESTART_INTERVAL.
  * Otherwise return false.
  *
  * This is a safety valve to protect against continuous respawn attempts if the
    time_t      curtime = time(NULL);
 
    /*
-    * Return false and don't restart archiver if too soon since last archiver
-    * start.
+    * If first time through, or time somehow went backwards, always update
+    * last_pgarch_start_time to match the current clock and allow archiver
+    * start.  Otherwise allow it only once enough time has elapsed.
     */
-   if ((unsigned int) (curtime - last_pgarch_start_time) <
-       (unsigned int) PGARCH_RESTART_INTERVAL)
-       return false;
-
-   last_pgarch_start_time = curtime;
-   return true;
+   if (last_pgarch_start_time == 0 ||
+       curtime < last_pgarch_start_time ||
+       curtime - last_pgarch_start_time >= PGARCH_RESTART_INTERVAL)
+   {
+       last_pgarch_start_time = curtime;
+       return true;
+   }
+   return false;
 }
 
 
         * SIGUSR2 arrives.  However, that means a random SIGTERM would
         * disable archiving indefinitely, which doesn't seem like a good
         * idea.  If more than 60 seconds pass since SIGTERM, exit anyway, so
-        * that the postmaster can start a new archiver if needed.
+        * that the postmaster can start a new archiver if needed.  Also exit
+        * if time unexpectedly goes backward.
         */
        if (ShutdownRequestPending)
        {
 
            if (last_sigterm_time == 0)
                last_sigterm_time = curtime;
-           else if ((unsigned int) (curtime - last_sigterm_time) >=
-                    (unsigned int) 60)
+           else if (curtime < last_sigterm_time ||
+                    curtime - last_sigterm_time >= 60)
                break;
        }
 
 
    {
        if (AbortStartTime != 0)
        {
+           time_t      curtime = time(NULL);
            int         seconds;
 
-           /* time left to abort; clamp to 0 in case it already expired */
-           seconds = SIGKILL_CHILDREN_AFTER_SECS -
-               (time(NULL) - AbortStartTime);
+           /*
+            * time left to abort; clamp to 0 if it already expired, or if
+            * time goes backwards
+            */
+           if (curtime < AbortStartTime ||
+               curtime - AbortStartTime >= SIGKILL_CHILDREN_AFTER_SECS)
+               seconds = 0;
+           else
+               seconds = SIGKILL_CHILDREN_AFTER_SECS -
+                   (curtime - AbortStartTime);
 
-           return Max(seconds * 1000, 0);
+           return seconds * 1000;
        }
        else
            return 60 * 1000;
 
 /*
  * SlotSyncWorkerCanRestart
  *
- * Returns true if enough time (SLOTSYNC_RESTART_INTERVAL_SEC) has passed
- * since it was launched last. Otherwise returns false.
+ * Return true, indicating worker is allowed to restart, if enough time has
+ * passed since it was last launched to reach SLOTSYNC_RESTART_INTERVAL_SEC.
+ * Otherwise return false.
  *
  * This is a safety valve to protect against continuous respawn attempts if the
  * worker is dying immediately at launch. Note that since we will retry to
 {
    time_t      curtime = time(NULL);
 
-   /* Return false if too soon since last start. */
-   if ((unsigned int) (curtime - SlotSyncCtx->last_start_time) <
-       (unsigned int) SLOTSYNC_RESTART_INTERVAL_SEC)
-       return false;
-
-   SlotSyncCtx->last_start_time = curtime;
-
-   return true;
+   /*
+    * If first time through, or time somehow went backwards, always update
+    * last_start_time to match the current clock and allow worker start.
+    * Otherwise allow it only once enough time has elapsed.
+    */
+   if (SlotSyncCtx->last_start_time == 0 ||
+       curtime < SlotSyncCtx->last_start_time ||
+       curtime - SlotSyncCtx->last_start_time >= SLOTSYNC_RESTART_INTERVAL_SEC)
+   {
+       SlotSyncCtx->last_start_time = curtime;
+       return true;
+   }
+   return false;
 }
 
 /*