*
  *
  * IDENTIFICATION
- *   $PostgreSQL: pgsql/src/backend/utils/init/miscinit.c,v 1.166.2.1 2009/12/09 21:58:17 tgl Exp $
+ *   $PostgreSQL: pgsql/src/backend/utils/init/miscinit.c,v 1.166.2.2 2010/08/16 17:33:07 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
         * admin) but has left orphan backends behind.  Check for this by
         * looking to see if there is an associated shmem segment that is
         * still in use.
+        *
+        * Note: because postmaster.pid is written in two steps, we might not
+        * find the shmem ID values in it; we can't treat that as an error.
         */
        if (isDDLock)
        {
                (errcode_for_file_access(),
                 errmsg("could not write lock file \"%s\": %m", filename)));
    }
-   if (close(fd))
+   if (pg_fsync(fd) != 0)
+   {
+       int         save_errno = errno;
+
+       close(fd);
+       unlink(filename);
+       errno = save_errno;
+       ereport(FATAL,
+               (errcode_for_file_access(),
+                errmsg("could not write lock file \"%s\": %m", filename)));
+   }
+   if (close(fd) != 0)
    {
        int         save_errno = errno;
 
        close(fd);
        return;
    }
-   if (close(fd))
+   if (pg_fsync(fd) != 0)
+   {
+       ereport(LOG,
+               (errcode_for_file_access(),
+                errmsg("could not write to file \"%s\": %m",
+                       DIRECTORY_LOCK_FILE)));
+   }
+   if (close(fd) != 0)
    {
        ereport(LOG,
                (errcode_for_file_access(),