]> granicus.if.org Git - postgresql/commitdiff
Install Windows crash dump handler before all else.
authorNoah Misch <noah@leadboat.com>
Sun, 12 Nov 2017 22:31:00 +0000 (14:31 -0800)
committerNoah Misch <noah@leadboat.com>
Sun, 12 Nov 2017 22:31:00 +0000 (14:31 -0800)
Apart from calling write_stderr() on failure, the handler depends on no
PostgreSQL facilities.  We have experienced crashes before reaching the
former call site.  Given such an early crash, this change cannot hurt
and may produce a helpful dump.  Absent an early crash, this change has
no effect.  Back-patch to 9.3 (all supported versions).

Takayuki Tsunakawa

Discussion: https://postgr.es/m/0A3221C70F24FB45833433255569204D1F80CD13@G01JPEXMBYT05

src/backend/main/main.c

index 87b7d3bf65cd6a3513c7c607ce4b450a753ecb31..f9d673f881c1da14f9e2252817b74b4b0219bfac 100644 (file)
@@ -61,6 +61,14 @@ main(int argc, char *argv[])
 {
        bool            do_check_root = true;
 
+       /*
+        * If supported on the current platform, set up a handler to be called if
+        * the backend/postmaster crashes with a fatal signal or exception.
+        */
+#if defined(WIN32) && defined(HAVE_MINIDUMP_TYPE)
+       pgwin32_install_crashdump_handler();
+#endif
+
        progname = get_progname(argv[0]);
 
        /*
@@ -81,14 +89,6 @@ main(int argc, char *argv[])
         */
        argv = save_ps_display_args(argc, argv);
 
-       /*
-        * If supported on the current platform, set up a handler to be called if
-        * the backend/postmaster crashes with a fatal signal or exception.
-        */
-#if defined(WIN32) && defined(HAVE_MINIDUMP_TYPE)
-       pgwin32_install_crashdump_handler();
-#endif
-
        /*
         * Fire up essential subsystems: error and memory management
         *