Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
Skip to content

Commit 4d67357

Browse files
committed
Tolerate EINVAL when calling fsync() on a directory.
Previously, we tolerated EBADF as a way for the operating system to indicate that it doesn't support fsync() on a directory. Tolerate EINVAL too, for older versions of Linux CIFS. Bug #15636. Back-patch all the way. Reported-by: John Klann Discussion: https://postgr.es/m/15636-d380890dafd78fc6@postgresql.org
1 parent 30dcb62 commit 4d67357

File tree

2 files changed

+2
-2
lines changed

2 files changed

+2
-2
lines changed

src/backend/storage/file/fd.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -3538,7 +3538,7 @@ fsync_fname_ext(const char *fname, bool isdir, bool ignore_perm, int elevel)
35383538
* Some OSes don't allow us to fsync directories at all, so we can ignore
35393539
* those errors. Anything else needs to be logged.
35403540
*/
3541-
if (returncode != 0 && !(isdir && errno == EBADF))
3541+
if (returncode != 0 && !(isdir && (errno == EBADF || errno == EINVAL)))
35423542
{
35433543
int save_errno;
35443544

src/common/file_utils.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -299,7 +299,7 @@ fsync_fname(const char *fname, bool isdir, const char *progname)
299299
* Some OSes don't allow us to fsync directories at all, so we can ignore
300300
* those errors. Anything else needs to be reported.
301301
*/
302-
if (returncode != 0 && !(isdir && errno == EBADF))
302+
if (returncode != 0 && !(isdir && (errno == EBADF || errno == EINVAL)))
303303
{
304304
fprintf(stderr, _("%s: could not fsync file \"%s\": %s\n"),
305305
progname, fname, strerror(errno));

0 commit comments

Comments
 (0)