Blame SOURCES/rh1648241-abrt_friendly_hs_log_jdk7.patch

60df80
--- openjdk/hotspot/src/share/vm/utilities/vmError.cpp	2012-02-02 16:17:24.476664897 +0100
60df80
+++ openjdk/hotspot/src/share/vm/utilities/vmError.cpp	2012-02-02 16:17:24.476664897 +0100
60df80
@@ -929,6 +929,7 @@
60df80
         }
60df80
       }
60df80
 
60df80
+      /*
60df80
       if (fd == -1) {
60df80
         const char *cwd = os::get_current_directory(buffer, sizeof(buffer));
60df80
         size_t len = strlen(cwd);
60df80
@@ -938,6 +939,24 @@
60df80
                      os::file_separator(), os::current_process_id());
60df80
         fd = open(buffer, O_RDWR | O_CREAT | O_EXCL, 0666);
60df80
       }
60df80
+      */
60df80
+
60df80
+      if (fd == -1) {
60df80
+        const char * tmpdir = os::get_temp_directory();
60df80
+        // try temp directory if it exists.
60df80
+        if (tmpdir != NULL && tmpdir[0] != '\0') {
60df80
+          jio_snprintf(buffer, sizeof(buffer), "%s%sjvm-%u",
60df80
+                       tmpdir, os::file_separator(), os::current_process_id());
60df80
+          // if mkdir() failed, hs_err will be created in temporary directory
60df80
+          if (!mkdir(buffer, 0700)) { // only read+execute flags are needed
60df80
+                                      // but we need to write into the directory too
60df80
+            jio_snprintf(buffer, sizeof(buffer), "%s%sjvm-%u%shs_error.log",
60df80
+                           tmpdir, os::file_separator(), os::current_process_id(),
60df80
+                           os::file_separator());
60df80
+            fd = open(buffer, O_WRONLY | O_CREAT | O_EXCL, 0444); // read-only file 
60df80
+          }
60df80
+        }
60df80
+      }
60df80
 
60df80
       if (fd == -1) {
60df80
         const char * tmpdir = os::get_temp_directory();