mirror of
https://github.com/postgres/postgres.git
synced 2026-02-28 12:20:43 -05:00
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
This commit is contained in:
parent
99a1554a26
commit
ede6b19624
2 changed files with 2 additions and 2 deletions
|
|
@ -2944,7 +2944,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;
|
||||
|
||||
|
|
|
|||
|
|
@ -696,7 +696,7 @@ fsync_fname_ext(const char *fname, bool isdir)
|
|||
* Some OSes don't allow us to fsync directories at all, so we can ignore
|
||||
* those errors. Anything else needs to be reported.
|
||||
*/
|
||||
if (returncode != 0 && !(isdir && errno == EBADF))
|
||||
if (returncode != 0 && !(isdir && (errno == EBADF || errno == EINVAL)))
|
||||
fprintf(stderr, _("%s: could not fsync file \"%s\": %s\n"),
|
||||
progname, fname, strerror(errno));
|
||||
|
||||
|
|
|
|||
Loading…
Reference in a new issue