aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBruce Momjian <bruce@momjian.us>2005-03-24 04:37:07 +0000
committerBruce Momjian <bruce@momjian.us>2005-03-24 04:37:07 +0000
commit291cd954fbfa48d8db79f22ffa8d596c837f7ee3 (patch)
treec5ee727969ee7d110179eddee8a963fcfe313a4c /src
parent3781b72c22f766b390d29c4b9c6adbdc6997c774 (diff)
downloadpostgresql-291cd954fbfa48d8db79f22ffa8d596c837f7ee3.tar.gz
postgresql-291cd954fbfa48d8db79f22ffa8d596c837f7ee3.zip
Change Win32 O_SYNC method to O_DSYNC because that is what the method
currently does. This is now the default Win32 wal sync method because we perfer o_datasync to fsync. Also, change Win32 fsync to a new wal sync method called fsync_writethrough because that is the behavior of _commit, which is what is used for fsync on Win32. Backpatch to 8.0.X.
Diffstat (limited to 'src')
-rw-r--r--src/backend/access/transam/xlog.c18
-rw-r--r--src/backend/utils/misc/postgresql.conf.sample3
-rw-r--r--src/include/port/win32.h5
-rw-r--r--src/port/open.c6
4 files changed, 24 insertions, 8 deletions
diff --git a/src/backend/access/transam/xlog.c b/src/backend/access/transam/xlog.c
index ec00dbd11f5..fad0927ac6f 100644
--- a/src/backend/access/transam/xlog.c
+++ b/src/backend/access/transam/xlog.c
@@ -7,7 +7,7 @@
* Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California
*
- * $PostgreSQL: pgsql/src/backend/access/transam/xlog.c,v 1.180 2004/12/31 21:59:30 pgsql Exp $
+ * $PostgreSQL: pgsql/src/backend/access/transam/xlog.c,v 1.180.4.1 2005/03/24 04:36:57 momjian Exp $
*
*-------------------------------------------------------------------------
*/
@@ -63,8 +63,13 @@
#endif
#endif
+#if defined(O_DSYNC)
#if defined(OPEN_SYNC_FLAG)
-#if defined(O_DSYNC) && (O_DSYNC != OPEN_SYNC_FLAG)
+#if O_DSYNC != OPEN_SYNC_FLAG
+#define OPEN_DATASYNC_FLAG O_DSYNC
+#endif
+#else /* !defined(OPEN_SYNC_FLAG) */
+/* Win32 only has O_DSYNC */
#define OPEN_DATASYNC_FLAG O_DSYNC
#endif
#endif
@@ -79,7 +84,11 @@
#define DEFAULT_SYNC_METHOD SYNC_METHOD_FDATASYNC
#define DEFAULT_SYNC_FLAGBIT 0
#else
+#ifndef FSYNC_IS_WRITE_THROUGH
#define DEFAULT_SYNC_METHOD_STR "fsync"
+#else
+#define DEFAULT_SYNC_METHOD_STR "fsync_writethrough"
+#endif
#define DEFAULT_SYNC_METHOD SYNC_METHOD_FSYNC
#define DEFAULT_SYNC_FLAGBIT 0
#endif
@@ -5154,7 +5163,12 @@ assign_xlog_sync_method(const char *method, bool doit, GucSource source)
int new_sync_method;
int new_sync_bit;
+#ifndef FSYNC_IS_WRITE_THROUGH
if (pg_strcasecmp(method, "fsync") == 0)
+#else
+ /* Win32 fsync() == _commit(0, which writes through a write cache */
+ if (pg_strcasecmp(method, "fsync_writethrough") == 0)
+#endif
{
new_sync_method = SYNC_METHOD_FSYNC;
new_sync_bit = 0;
diff --git a/src/backend/utils/misc/postgresql.conf.sample b/src/backend/utils/misc/postgresql.conf.sample
index 86640efa7da..6a3a699c1cc 100644
--- a/src/backend/utils/misc/postgresql.conf.sample
+++ b/src/backend/utils/misc/postgresql.conf.sample
@@ -111,7 +111,8 @@
#fsync = true # turns forced synchronization on or off
#wal_sync_method = fsync # the default varies across platforms:
- # fsync, fdatasync, open_sync, or open_datasync
+ # fsync, fdatasync, fsync_writethrough,
+ # open_sync, open_datasync
#wal_buffers = 8 # min 4, 8KB each
#commit_delay = 0 # range 0-100000, in microseconds
#commit_siblings = 5 # range 1-1000
diff --git a/src/include/port/win32.h b/src/include/port/win32.h
index f93058edc07..3a5df0eac84 100644
--- a/src/include/port/win32.h
+++ b/src/include/port/win32.h
@@ -1,4 +1,4 @@
-/* $PostgreSQL: pgsql/src/include/port/win32.h,v 1.42.4.1 2005/03/17 17:28:59 momjian Exp $ */
+/* $PostgreSQL: pgsql/src/include/port/win32.h,v 1.42.4.2 2005/03/24 04:37:01 momjian Exp $ */
/* undefine and redefine after #include */
#undef mkdir
@@ -17,6 +17,7 @@
#define fsync(a) _commit(a)
+#define FSYNC_IS_WRITE_THROUGH
#define ftruncate(a,b) chsize(a,b)
#define USES_WINSOCK
@@ -189,7 +190,7 @@ typedef int pid_t;
* to ensure that we don't collide with a future definition. It means
* we cannot use _O_NOINHERIT ourselves.
*/
-#define O_SYNC 0x0080
+#define O_DSYNC 0x0080
/*
* Supplement to <errno.h>.
diff --git a/src/port/open.c b/src/port/open.c
index 3ff6b0e2dda..fcf35ce2604 100644
--- a/src/port/open.c
+++ b/src/port/open.c
@@ -6,7 +6,7 @@
*
* Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
*
- * $PostgreSQL: pgsql/src/port/open.c,v 1.7.4.1 2005/03/17 17:28:59 momjian Exp $
+ * $PostgreSQL: pgsql/src/port/open.c,v 1.7.4.2 2005/03/24 04:37:07 momjian Exp $
*
*-------------------------------------------------------------------------
*/
@@ -63,7 +63,7 @@ win32_open(const char *fileName, int fileFlags,...)
/* Check that we can handle the request */
assert((fileFlags & ((O_RDONLY | O_WRONLY | O_RDWR) | O_APPEND |
(O_RANDOM | O_SEQUENTIAL | O_TEMPORARY) |
- _O_SHORT_LIVED | O_SYNC |
+ _O_SHORT_LIVED | O_DSYNC |
(O_CREAT | O_TRUNC | O_EXCL) | (O_TEXT | O_BINARY))) == fileFlags);
sa.nLength = sizeof(sa);
@@ -83,7 +83,7 @@ win32_open(const char *fileName, int fileFlags,...)
((fileFlags & O_SEQUENTIAL) ? FILE_FLAG_SEQUENTIAL_SCAN : 0) |
((fileFlags & _O_SHORT_LIVED) ? FILE_ATTRIBUTE_TEMPORARY : 0) |
((fileFlags & O_TEMPORARY) ? FILE_FLAG_DELETE_ON_CLOSE : 0)|
- ((fileFlags & O_SYNC) ? FILE_FLAG_WRITE_THROUGH : 0),
+ ((fileFlags & O_DSYNC) ? FILE_FLAG_WRITE_THROUGH : 0),
NULL)) == INVALID_HANDLE_VALUE)
{
switch (GetLastError())