mirror of
https://github.com/postgres/postgres.git
synced 2025-07-18 17:42:25 +03:00
Backport "Expose fsync_fname as a public API".
Backport commit b0a48e996b
back to 9.0
to allow back-patching another fix that uses fsync_fname.
This commit is contained in:
@ -38,7 +38,6 @@
|
||||
|
||||
|
||||
static void copy_file(char *fromfile, char *tofile);
|
||||
static void fsync_fname(char *fname, bool isdir);
|
||||
|
||||
|
||||
/*
|
||||
@ -214,59 +213,3 @@ copy_file(char *fromfile, char *tofile)
|
||||
|
||||
pfree(buffer);
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* fsync a file
|
||||
*
|
||||
* Try to fsync directories but ignore errors that indicate the OS
|
||||
* just doesn't allow/require fsyncing directories.
|
||||
*/
|
||||
static void
|
||||
fsync_fname(char *fname, bool isdir)
|
||||
{
|
||||
int fd;
|
||||
int returncode;
|
||||
|
||||
/*
|
||||
* Some OSs require directories to be opened read-only whereas other
|
||||
* systems don't allow us to fsync files opened read-only; so we need both
|
||||
* cases here
|
||||
*/
|
||||
if (!isdir)
|
||||
fd = BasicOpenFile(fname,
|
||||
O_RDWR | PG_BINARY,
|
||||
S_IRUSR | S_IWUSR);
|
||||
else
|
||||
fd = BasicOpenFile(fname,
|
||||
O_RDONLY | PG_BINARY,
|
||||
S_IRUSR | S_IWUSR);
|
||||
|
||||
/*
|
||||
* Some OSs don't allow us to open directories at all (Windows returns
|
||||
* EACCES)
|
||||
*/
|
||||
if (fd < 0 && isdir && (errno == EISDIR || errno == EACCES))
|
||||
return;
|
||||
|
||||
else if (fd < 0)
|
||||
ereport(ERROR,
|
||||
(errcode_for_file_access(),
|
||||
errmsg("could not open file \"%s\": %m", fname)));
|
||||
|
||||
returncode = pg_fsync(fd);
|
||||
|
||||
/* Some OSs don't allow us to fsync directories at all */
|
||||
if (returncode != 0 && isdir && errno == EBADF)
|
||||
{
|
||||
close(fd);
|
||||
return;
|
||||
}
|
||||
|
||||
if (returncode != 0)
|
||||
ereport(ERROR,
|
||||
(errcode_for_file_access(),
|
||||
errmsg("could not fsync file \"%s\": %m", fname)));
|
||||
|
||||
close(fd);
|
||||
}
|
||||
|
@ -1948,3 +1948,59 @@ RemovePgTempFilesInDir(const char *tmpdirname)
|
||||
|
||||
FreeDir(temp_dir);
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* fsync a file
|
||||
*
|
||||
* Try to fsync directories but ignore errors that indicate the OS
|
||||
* just doesn't allow/require fsyncing directories.
|
||||
*/
|
||||
void
|
||||
fsync_fname(char *fname, bool isdir)
|
||||
{
|
||||
int fd;
|
||||
int returncode;
|
||||
|
||||
/*
|
||||
* Some OSs require directories to be opened read-only whereas other
|
||||
* systems don't allow us to fsync files opened read-only; so we need both
|
||||
* cases here
|
||||
*/
|
||||
if (!isdir)
|
||||
fd = BasicOpenFile(fname,
|
||||
O_RDWR | PG_BINARY,
|
||||
S_IRUSR | S_IWUSR);
|
||||
else
|
||||
fd = BasicOpenFile(fname,
|
||||
O_RDONLY | PG_BINARY,
|
||||
S_IRUSR | S_IWUSR);
|
||||
|
||||
/*
|
||||
* Some OSs don't allow us to open directories at all (Windows returns
|
||||
* EACCES)
|
||||
*/
|
||||
if (fd < 0 && isdir && (errno == EISDIR || errno == EACCES))
|
||||
return;
|
||||
|
||||
else if (fd < 0)
|
||||
ereport(ERROR,
|
||||
(errcode_for_file_access(),
|
||||
errmsg("could not open file \"%s\": %m", fname)));
|
||||
|
||||
returncode = pg_fsync(fd);
|
||||
|
||||
/* Some OSs don't allow us to fsync directories at all */
|
||||
if (returncode != 0 && isdir && errno == EBADF)
|
||||
{
|
||||
close(fd);
|
||||
return;
|
||||
}
|
||||
|
||||
if (returncode != 0)
|
||||
ereport(ERROR,
|
||||
(errcode_for_file_access(),
|
||||
errmsg("could not fsync file \"%s\": %m", fname)));
|
||||
|
||||
close(fd);
|
||||
}
|
||||
|
@ -99,6 +99,7 @@ extern int pg_fsync_no_writethrough(int fd);
|
||||
extern int pg_fsync_writethrough(int fd);
|
||||
extern int pg_fdatasync(int fd);
|
||||
extern int pg_flush_data(int fd, off_t offset, off_t amount);
|
||||
extern void fsync_fname(char *fname, bool isdir);
|
||||
|
||||
/* Filename components for OpenTemporaryFile */
|
||||
#define PG_TEMP_FILES_DIR "pgsql_tmp"
|
||||
|
Reference in New Issue
Block a user