diff options
author | Thomas Munro <tmunro@postgresql.org> | 2019-02-24 23:59:26 +1300 |
---|---|---|
committer | Thomas Munro <tmunro@postgresql.org> | 2019-02-25 00:02:15 +1300 |
commit | 0ec89a0f6752d55efee4377928087b1865d7ac5e (patch) | |
tree | 1bc9cd3a3d8d147678a072bf14b139e620dddb21 /src/backend/storage/file/fd.c | |
parent | 0fe3f6dd45c95f82bf6dcd98b4f9e029ce433ce0 (diff) | |
download | postgresql-0ec89a0f6752d55efee4377928087b1865d7ac5e.tar.gz postgresql-0ec89a0f6752d55efee4377928087b1865d7ac5e.zip |
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
Diffstat (limited to 'src/backend/storage/file/fd.c')
-rw-r--r-- | src/backend/storage/file/fd.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/src/backend/storage/file/fd.c b/src/backend/storage/file/fd.c index c255583026f..ba7f3d96ae0 100644 --- a/src/backend/storage/file/fd.c +++ b/src/backend/storage/file/fd.c @@ -2945,7 +2945,7 @@ fsync_fname_ext(const char *fname, bool isdir, bool ignore_perm, int elevel) * Some OSes don't allow us to fsync directories at all, so we can ignore * those errors. Anything else needs to be logged. */ - if (returncode != 0 && !(isdir && errno == EBADF)) + if (returncode != 0 && !(isdir && (errno == EBADF || errno == EINVAL))) { int save_errno; |