Commit 8528e3d8 authored by Tom Lane's avatar Tom Lane

Fix failure to check for open() or fsync() failures.

While it seems OK to not be concerned about fsync() failure for a
pre-existing signal file, it's not OK to not even check for open()
failure.  This at least causes complaints from static analyzers,
and I think on some platforms passing -1 to fsync() or close() might
trigger assertion-type failures.  Also add (void) casts to make clear
that we're ignoring fsync's result intentionally.

Oversights in commit 2dedf4d9, noted by Coverity.
parent e9fcfed3
...@@ -5327,7 +5327,8 @@ readRecoverySignalFile(void) ...@@ -5327,7 +5327,8 @@ readRecoverySignalFile(void)
/* /*
* Check for recovery signal files and if found, fsync them since they * Check for recovery signal files and if found, fsync them since they
* represent server state information. * represent server state information. We don't sweat too much about the
* possibility of fsync failure, however.
* *
* If present, standby signal file takes precedence. If neither is present * If present, standby signal file takes precedence. If neither is present
* then we won't enter archive recovery. * then we won't enter archive recovery.
...@@ -5338,8 +5339,11 @@ readRecoverySignalFile(void) ...@@ -5338,8 +5339,11 @@ readRecoverySignalFile(void)
fd = BasicOpenFilePerm(STANDBY_SIGNAL_FILE, O_RDWR | PG_BINARY | get_sync_bit(sync_method), fd = BasicOpenFilePerm(STANDBY_SIGNAL_FILE, O_RDWR | PG_BINARY | get_sync_bit(sync_method),
S_IRUSR | S_IWUSR); S_IRUSR | S_IWUSR);
pg_fsync(fd); if (fd >= 0)
close(fd); {
(void) pg_fsync(fd);
close(fd);
}
standby_signal_file_found = true; standby_signal_file_found = true;
} }
else if (stat(RECOVERY_SIGNAL_FILE, &stat_buf) == 0) else if (stat(RECOVERY_SIGNAL_FILE, &stat_buf) == 0)
...@@ -5348,8 +5352,11 @@ readRecoverySignalFile(void) ...@@ -5348,8 +5352,11 @@ readRecoverySignalFile(void)
fd = BasicOpenFilePerm(RECOVERY_SIGNAL_FILE, O_RDWR | PG_BINARY | get_sync_bit(sync_method), fd = BasicOpenFilePerm(RECOVERY_SIGNAL_FILE, O_RDWR | PG_BINARY | get_sync_bit(sync_method),
S_IRUSR | S_IWUSR); S_IRUSR | S_IWUSR);
pg_fsync(fd); if (fd >= 0)
close(fd); {
(void) pg_fsync(fd);
close(fd);
}
recovery_signal_file_found = true; recovery_signal_file_found = true;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment