about summary refs log tree commit diff
path: root/db2/os/os_fsync.c
diff options
context:
space:
mode:
Diffstat (limited to 'db2/os/os_fsync.c')
-rw-r--r--db2/os/os_fsync.c42
1 files changed, 26 insertions, 16 deletions
diff --git a/db2/os/os_fsync.c b/db2/os/os_fsync.c
index e1f271a75c..61a504f84d 100644
--- a/db2/os/os_fsync.c
+++ b/db2/os/os_fsync.c
@@ -8,34 +8,21 @@
 #include "config.h"
 
 #ifndef lint
-static const char sccsid[] = "@(#)os_fsync.c	10.5 (Sleepycat) 4/19/98";
+static const char sccsid[] = "@(#)os_fsync.c	10.7 (Sleepycat) 10/12/98";
 #endif /* not lint */
 
 #ifndef NO_SYSTEM_INCLUDES
 #include <sys/types.h>
 
 #include <errno.h>
+#include <fcntl.h>			/* XXX: Required by __hp3000s900 */
 #include <unistd.h>
 #endif
 
 #include "db_int.h"
-
-/*
- * __db_fsync --
- *	Flush a file descriptor.
- *
- * PUBLIC: int __db_fsync __P((int));
- */
-int
-__db_fsync(fd)
-	int fd;
-{
-	return (__os_fsync(fd) ? errno : 0);
-}
+#include "os_jump.h"
 
 #ifdef __hp3000s900
-#include <fcntl.h>
-
 int
 __mpe_fsync(fd)
 	int fd;
@@ -47,3 +34,26 @@ __mpe_fsync(fd)
 	return (0);
 }
 #endif
+
+#ifdef __hp3000s900
+#define	fsync(fd)	__mpe_fsync(fd);
+#endif
+#ifdef _WIN32
+#define	fsync(fd)	_commit(fd);
+#endif
+
+/*
+ * __os_fsync --
+ *	Flush a file descriptor.
+ *
+ * PUBLIC: int __os_fsync __P((int));
+ */
+int
+__os_fsync(fd)
+	int fd;
+{
+	int ret;
+
+	ret = __db_jump.j_fsync != NULL ?  __db_jump.j_fsync(fd) : fsync(fd);
+	return (ret == 0 ? 0 : errno);
+}