aboutsummaryrefslogtreecommitdiff
path: root/src/port/open.c
diff options
context:
space:
mode:
authorBruce Momjian <bruce@momjian.us>2005-03-17 17:28:59 +0000
committerBruce Momjian <bruce@momjian.us>2005-03-17 17:28:59 +0000
commit7911e3a081ecebc116501da46806e32fa1a1c40a (patch)
tree364afc5717f218a34fbad9adadae74b7110d6329 /src/port/open.c
parent89ea098714e0df3bc35f9a69c291666e77cd84ff (diff)
downloadpostgresql-7911e3a081ecebc116501da46806e32fa1a1c40a.tar.gz
postgresql-7911e3a081ecebc116501da46806e32fa1a1c40a.zip
Backpatch to 8.0.X, already in HEAD:
Allow Win32 to support the O_SYNC open flag as an wal_sync_method method.
Diffstat (limited to 'src/port/open.c')
-rw-r--r--src/port/open.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/src/port/open.c b/src/port/open.c
index b61b66f493e..3ff6b0e2dda 100644
--- a/src/port/open.c
+++ b/src/port/open.c
@@ -6,13 +6,14 @@
*
* Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
*
- * $PostgreSQL: pgsql/src/port/open.c,v 1.7 2004/12/31 22:03:53 pgsql Exp $
+ * $PostgreSQL: pgsql/src/port/open.c,v 1.7.4.1 2005/03/17 17:28:59 momjian Exp $
*
*-------------------------------------------------------------------------
*/
#ifdef WIN32
+#include <postgres.h>
#include <windows.h>
#include <fcntl.h>
#include <errno.h>
@@ -62,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_SHORT_LIVED | O_SYNC |
(O_CREAT | O_TRUNC | O_EXCL) | (O_TEXT | O_BINARY))) == fileFlags);
sa.nLength = sizeof(sa);
@@ -81,7 +82,8 @@ win32_open(const char *fileName, int fileFlags,...)
((fileFlags & O_RANDOM) ? FILE_FLAG_RANDOM_ACCESS : 0) |
((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_TEMPORARY) ? FILE_FLAG_DELETE_ON_CLOSE : 0)|
+ ((fileFlags & O_SYNC) ? FILE_FLAG_WRITE_THROUGH : 0),
NULL)) == INVALID_HANDLE_VALUE)
{
switch (GetLastError())