From: Magnus Hagander Date: Tue, 21 Feb 2012 16:12:25 +0000 (+0100) Subject: Avoid double close of file handle in syslogger on win32 X-Git-Tag: REL9_0_7~11 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=d1ed3363f6077a0f616782ccb26c9571e7f3cae1;p=thirdparty%2Fpostgresql.git Avoid double close of file handle in syslogger on win32 This causes an exception when running under a debugger or in particular when running on a debug version of Windows. Patch from MauMau --- diff --git a/src/backend/postmaster/syslogger.c b/src/backend/postmaster/syslogger.c index 067f7efc646..20ed92d550b 100644 --- a/src/backend/postmaster/syslogger.c +++ b/src/backend/postmaster/syslogger.c @@ -593,8 +593,11 @@ SysLogger_Start(void) errmsg("could not redirect stderr: %m"))); close(fd); _setmode(_fileno(stderr), _O_BINARY); - /* Now we are done with the write end of the pipe. */ - CloseHandle(syslogPipe[1]); + /* + * Now we are done with the write end of the pipe. + * CloseHandle() must not be called because the preceding + * close() closes the underlying handle. + */ syslogPipe[1] = 0; #endif redirection_done = true;