annotate src/share/vm/utilities/vmError.cpp @ 6972:bd7a7ce2e264

6830717: replay of compilations would help with debugging Summary: When java process crashed in compiler thread, repeat the compilation process will help finding root cause. This is done with using SA dump application class data and replay data from core dump, then use debug version of jvm to recompile the problematic java method. Reviewed-by: kvn, twisti, sspitsyn Contributed-by: yumin.qi@oracle.com
author minqi
date Mon, 12 Nov 2012 14:03:53 -0800
parents a1b8cf9cf970
children 679e6584c177 9deda4d8e126
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
4872
aa3d708d67c4 7141200: log some interesting information in ring buffers for crashes
never
parents: 4803
diff changeset
2 * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1490
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1490
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1490
diff changeset
21 * questions.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
22 *
a61af66fc99e Initial load
duke
parents:
diff changeset
23 */
a61af66fc99e Initial load
duke
parents:
diff changeset
24
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
25 #include "precompiled.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
26 #include "compiler/compileBroker.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
27 #include "gc_interface/collectedHeap.hpp"
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents: 4872
diff changeset
28 #include "prims/whitebox.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
29 #include "runtime/arguments.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
30 #include "runtime/frame.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
31 #include "runtime/init.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
32 #include "runtime/os.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
33 #include "runtime/thread.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
34 #include "runtime/vmThread.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
35 #include "runtime/vm_operations.hpp"
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 5984
diff changeset
36 #include "services/memTracker.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
37 #include "utilities/debug.hpp"
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents: 1972
diff changeset
38 #include "utilities/decoder.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
39 #include "utilities/defaultStream.hpp"
2199
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
40 #include "utilities/errorReporter.hpp"
4872
aa3d708d67c4 7141200: log some interesting information in ring buffers for crashes
never
parents: 4803
diff changeset
41 #include "utilities/events.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
42 #include "utilities/top.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1907
diff changeset
43 #include "utilities/vmError.hpp"
0
a61af66fc99e Initial load
duke
parents:
diff changeset
44
a61af66fc99e Initial load
duke
parents:
diff changeset
45 // List of environment variables that should be reported in error log file.
a61af66fc99e Initial load
duke
parents:
diff changeset
46 const char *env_list[] = {
a61af66fc99e Initial load
duke
parents:
diff changeset
47 // All platforms
a61af66fc99e Initial load
duke
parents:
diff changeset
48 "JAVA_HOME", "JRE_HOME", "JAVA_TOOL_OPTIONS", "_JAVA_OPTIONS", "CLASSPATH",
a61af66fc99e Initial load
duke
parents:
diff changeset
49 "JAVA_COMPILER", "PATH", "USERNAME",
a61af66fc99e Initial load
duke
parents:
diff changeset
50
3960
f08d439fab8c 7089790: integrate bsd-port changes
never
parents: 2302
diff changeset
51 // Env variables that are defined on Solaris/Linux/BSD
0
a61af66fc99e Initial load
duke
parents:
diff changeset
52 "LD_LIBRARY_PATH", "LD_PRELOAD", "SHELL", "DISPLAY",
a61af66fc99e Initial load
duke
parents:
diff changeset
53 "HOSTTYPE", "OSTYPE", "ARCH", "MACHTYPE",
a61af66fc99e Initial load
duke
parents:
diff changeset
54
a61af66fc99e Initial load
duke
parents:
diff changeset
55 // defined on Linux
a61af66fc99e Initial load
duke
parents:
diff changeset
56 "LD_ASSUME_KERNEL", "_JAVA_SR_SIGNUM",
a61af66fc99e Initial load
duke
parents:
diff changeset
57
3960
f08d439fab8c 7089790: integrate bsd-port changes
never
parents: 2302
diff changeset
58 // defined on Darwin
f08d439fab8c 7089790: integrate bsd-port changes
never
parents: 2302
diff changeset
59 "DYLD_LIBRARY_PATH", "DYLD_FALLBACK_LIBRARY_PATH",
f08d439fab8c 7089790: integrate bsd-port changes
never
parents: 2302
diff changeset
60 "DYLD_FRAMEWORK_PATH", "DYLD_FALLBACK_FRAMEWORK_PATH",
f08d439fab8c 7089790: integrate bsd-port changes
never
parents: 2302
diff changeset
61 "DYLD_INSERT_LIBRARIES",
f08d439fab8c 7089790: integrate bsd-port changes
never
parents: 2302
diff changeset
62
0
a61af66fc99e Initial load
duke
parents:
diff changeset
63 // defined on Windows
a61af66fc99e Initial load
duke
parents:
diff changeset
64 "OS", "PROCESSOR_IDENTIFIER", "_ALT_JAVA_HOME_DIR",
a61af66fc99e Initial load
duke
parents:
diff changeset
65
a61af66fc99e Initial load
duke
parents:
diff changeset
66 (const char *)0
a61af66fc99e Initial load
duke
parents:
diff changeset
67 };
a61af66fc99e Initial load
duke
parents:
diff changeset
68
a61af66fc99e Initial load
duke
parents:
diff changeset
69 // Fatal error handler for internal errors and crashes.
a61af66fc99e Initial load
duke
parents:
diff changeset
70 //
a61af66fc99e Initial load
duke
parents:
diff changeset
71 // The default behavior of fatal error handler is to print a brief message
a61af66fc99e Initial load
duke
parents:
diff changeset
72 // to standard out (defaultStream::output_fd()), then save detailed information
a61af66fc99e Initial load
duke
parents:
diff changeset
73 // into an error report file (hs_err_pid<pid>.log) and abort VM. If multiple
a61af66fc99e Initial load
duke
parents:
diff changeset
74 // threads are having troubles at the same time, only one error is reported.
a61af66fc99e Initial load
duke
parents:
diff changeset
75 // The thread that is reporting error will abort VM when it is done, all other
a61af66fc99e Initial load
duke
parents:
diff changeset
76 // threads are blocked forever inside report_and_die().
a61af66fc99e Initial load
duke
parents:
diff changeset
77
a61af66fc99e Initial load
duke
parents:
diff changeset
78 // Constructor for crashes
2095
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
79 VMError::VMError(Thread* thread, unsigned int sig, address pc, void* siginfo, void* context) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
80 _thread = thread;
a61af66fc99e Initial load
duke
parents:
diff changeset
81 _id = sig;
a61af66fc99e Initial load
duke
parents:
diff changeset
82 _pc = pc;
a61af66fc99e Initial load
duke
parents:
diff changeset
83 _siginfo = siginfo;
a61af66fc99e Initial load
duke
parents:
diff changeset
84 _context = context;
a61af66fc99e Initial load
duke
parents:
diff changeset
85
a61af66fc99e Initial load
duke
parents:
diff changeset
86 _verbose = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
87 _current_step = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
88 _current_step_info = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
89
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
90 _message = NULL;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
91 _detail_msg = NULL;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
92 _filename = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
93 _lineno = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
94
a61af66fc99e Initial load
duke
parents:
diff changeset
95 _size = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
96 }
a61af66fc99e Initial load
duke
parents:
diff changeset
97
a61af66fc99e Initial load
duke
parents:
diff changeset
98 // Constructor for internal errors
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
99 VMError::VMError(Thread* thread, const char* filename, int lineno,
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
100 const char* message, const char * detail_msg)
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
101 {
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
102 _thread = thread;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
103 _id = internal_error; // Value that's not an OS exception/signal
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
104 _filename = filename;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
105 _lineno = lineno;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
106 _message = message;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
107 _detail_msg = detail_msg;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
108
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
109 _verbose = false;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
110 _current_step = 0;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
111 _current_step_info = NULL;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
112
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
113 _pc = NULL;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
114 _siginfo = NULL;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
115 _context = NULL;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
116
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
117 _size = 0;
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
118 }
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
119
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
120 // Constructor for OOM errors
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
121 VMError::VMError(Thread* thread, const char* filename, int lineno, size_t size,
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
122 const char* message) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
123 _thread = thread;
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
124 _id = oom_error; // Value that's not an OS exception/signal
0
a61af66fc99e Initial load
duke
parents:
diff changeset
125 _filename = filename;
a61af66fc99e Initial load
duke
parents:
diff changeset
126 _lineno = lineno;
a61af66fc99e Initial load
duke
parents:
diff changeset
127 _message = message;
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
128 _detail_msg = NULL;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
129
a61af66fc99e Initial load
duke
parents:
diff changeset
130 _verbose = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
131 _current_step = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
132 _current_step_info = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
133
a61af66fc99e Initial load
duke
parents:
diff changeset
134 _pc = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
135 _siginfo = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
136 _context = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
137
a61af66fc99e Initial load
duke
parents:
diff changeset
138 _size = size;
a61af66fc99e Initial load
duke
parents:
diff changeset
139 }
a61af66fc99e Initial load
duke
parents:
diff changeset
140
a61af66fc99e Initial load
duke
parents:
diff changeset
141
a61af66fc99e Initial load
duke
parents:
diff changeset
142 // Constructor for non-fatal errors
a61af66fc99e Initial load
duke
parents:
diff changeset
143 VMError::VMError(const char* message) {
a61af66fc99e Initial load
duke
parents:
diff changeset
144 _thread = NULL;
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
145 _id = internal_error; // Value that's not an OS exception/signal
0
a61af66fc99e Initial load
duke
parents:
diff changeset
146 _filename = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
147 _lineno = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
148 _message = message;
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
149 _detail_msg = NULL;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
150
a61af66fc99e Initial load
duke
parents:
diff changeset
151 _verbose = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
152 _current_step = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
153 _current_step_info = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
154
a61af66fc99e Initial load
duke
parents:
diff changeset
155 _pc = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
156 _siginfo = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
157 _context = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
158
a61af66fc99e Initial load
duke
parents:
diff changeset
159 _size = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
160 }
a61af66fc99e Initial load
duke
parents:
diff changeset
161
a61af66fc99e Initial load
duke
parents:
diff changeset
162 // -XX:OnError=<string>, where <string> can be a list of commands, separated
a61af66fc99e Initial load
duke
parents:
diff changeset
163 // by ';'. "%p" is replaced by current process id (pid); "%%" is replaced by
a61af66fc99e Initial load
duke
parents:
diff changeset
164 // a single "%". Some examples:
a61af66fc99e Initial load
duke
parents:
diff changeset
165 //
a61af66fc99e Initial load
duke
parents:
diff changeset
166 // -XX:OnError="pmap %p" // show memory map
a61af66fc99e Initial load
duke
parents:
diff changeset
167 // -XX:OnError="gcore %p; dbx - %p" // dump core and launch debugger
a61af66fc99e Initial load
duke
parents:
diff changeset
168 // -XX:OnError="cat hs_err_pid%p.log | mail my_email@sun.com"
a61af66fc99e Initial load
duke
parents:
diff changeset
169 // -XX:OnError="kill -9 %p" // ?#!@#
a61af66fc99e Initial load
duke
parents:
diff changeset
170
a61af66fc99e Initial load
duke
parents:
diff changeset
171 // A simple parser for -XX:OnError, usage:
a61af66fc99e Initial load
duke
parents:
diff changeset
172 // ptr = OnError;
a61af66fc99e Initial load
duke
parents:
diff changeset
173 // while ((cmd = next_OnError_command(buffer, sizeof(buffer), &ptr) != NULL)
a61af66fc99e Initial load
duke
parents:
diff changeset
174 // ... ...
a61af66fc99e Initial load
duke
parents:
diff changeset
175 static char* next_OnError_command(char* buf, int buflen, const char** ptr) {
a61af66fc99e Initial load
duke
parents:
diff changeset
176 if (ptr == NULL || *ptr == NULL) return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
177
a61af66fc99e Initial load
duke
parents:
diff changeset
178 const char* cmd = *ptr;
a61af66fc99e Initial load
duke
parents:
diff changeset
179
a61af66fc99e Initial load
duke
parents:
diff changeset
180 // skip leading blanks or ';'
a61af66fc99e Initial load
duke
parents:
diff changeset
181 while (*cmd == ' ' || *cmd == ';') cmd++;
a61af66fc99e Initial load
duke
parents:
diff changeset
182
a61af66fc99e Initial load
duke
parents:
diff changeset
183 if (*cmd == '\0') return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
184
a61af66fc99e Initial load
duke
parents:
diff changeset
185 const char * cmdend = cmd;
a61af66fc99e Initial load
duke
parents:
diff changeset
186 while (*cmdend != '\0' && *cmdend != ';') cmdend++;
a61af66fc99e Initial load
duke
parents:
diff changeset
187
a61af66fc99e Initial load
duke
parents:
diff changeset
188 Arguments::copy_expand_pid(cmd, cmdend - cmd, buf, buflen);
a61af66fc99e Initial load
duke
parents:
diff changeset
189
a61af66fc99e Initial load
duke
parents:
diff changeset
190 *ptr = (*cmdend == '\0' ? cmdend : cmdend + 1);
a61af66fc99e Initial load
duke
parents:
diff changeset
191 return buf;
a61af66fc99e Initial load
duke
parents:
diff changeset
192 }
a61af66fc99e Initial load
duke
parents:
diff changeset
193
a61af66fc99e Initial load
duke
parents:
diff changeset
194
a61af66fc99e Initial load
duke
parents:
diff changeset
195 static void print_bug_submit_message(outputStream *out, Thread *thread) {
a61af66fc99e Initial load
duke
parents:
diff changeset
196 if (out == NULL) return;
a61af66fc99e Initial load
duke
parents:
diff changeset
197 out->print_raw_cr("# If you would like to submit a bug report, please visit:");
a61af66fc99e Initial load
duke
parents:
diff changeset
198 out->print_raw ("# ");
a61af66fc99e Initial load
duke
parents:
diff changeset
199 out->print_raw_cr(Arguments::java_vendor_url_bug());
a61af66fc99e Initial load
duke
parents:
diff changeset
200 // If the crash is in native code, encourage user to submit a bug to the
a61af66fc99e Initial load
duke
parents:
diff changeset
201 // provider of that code.
56
31d829b33f26 6549844: Wording problems in "An unexpected error ..."
coleenp
parents: 0
diff changeset
202 if (thread && thread->is_Java_thread() &&
31d829b33f26 6549844: Wording problems in "An unexpected error ..."
coleenp
parents: 0
diff changeset
203 !thread->is_hidden_from_external_view()) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
204 JavaThread* jt = (JavaThread*)thread;
a61af66fc99e Initial load
duke
parents:
diff changeset
205 if (jt->thread_state() == _thread_in_native) {
a61af66fc99e Initial load
duke
parents:
diff changeset
206 out->print_cr("# The crash happened outside the Java Virtual Machine in native code.\n# See problematic frame for where to report the bug.");
a61af66fc99e Initial load
duke
parents:
diff changeset
207 }
a61af66fc99e Initial load
duke
parents:
diff changeset
208 }
a61af66fc99e Initial load
duke
parents:
diff changeset
209 out->print_raw_cr("#");
a61af66fc99e Initial load
duke
parents:
diff changeset
210 }
a61af66fc99e Initial load
duke
parents:
diff changeset
211
2204
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
212 bool VMError::coredump_status;
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
213 char VMError::coredump_message[O_BUFLEN];
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
214
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
215 void VMError::report_coredump_status(const char* message, bool status) {
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
216 coredump_status = status;
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
217 strncpy(coredump_message, message, sizeof(coredump_message));
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
218 coredump_message[sizeof(coredump_message)-1] = 0;
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
219 }
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
220
0
a61af66fc99e Initial load
duke
parents:
diff changeset
221
a61af66fc99e Initial load
duke
parents:
diff changeset
222 // Return a string to describe the error
a61af66fc99e Initial load
duke
parents:
diff changeset
223 char* VMError::error_string(char* buf, int buflen) {
a61af66fc99e Initial load
duke
parents:
diff changeset
224 char signame_buf[64];
a61af66fc99e Initial load
duke
parents:
diff changeset
225 const char *signame = os::exception_name(_id, signame_buf, sizeof(signame_buf));
a61af66fc99e Initial load
duke
parents:
diff changeset
226
a61af66fc99e Initial load
duke
parents:
diff changeset
227 if (signame) {
a61af66fc99e Initial load
duke
parents:
diff changeset
228 jio_snprintf(buf, buflen,
a61af66fc99e Initial load
duke
parents:
diff changeset
229 "%s (0x%x) at pc=" PTR_FORMAT ", pid=%d, tid=" UINTX_FORMAT,
a61af66fc99e Initial load
duke
parents:
diff changeset
230 signame, _id, _pc,
a61af66fc99e Initial load
duke
parents:
diff changeset
231 os::current_process_id(), os::current_thread_id());
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
232 } else if (_filename != NULL && _lineno > 0) {
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
233 // skip directory names
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
234 char separator = os::file_separator()[0];
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
235 const char *p = strrchr(_filename, separator);
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
236 int n = jio_snprintf(buf, buflen,
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
237 "Internal Error at %s:%d, pid=%d, tid=" UINTX_FORMAT,
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
238 p ? p + 1 : _filename, _lineno,
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
239 os::current_process_id(), os::current_thread_id());
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
240 if (n >= 0 && n < buflen && _message) {
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
241 if (_detail_msg) {
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
242 jio_snprintf(buf + n, buflen - n, "%s%s: %s",
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
243 os::line_separator(), _message, _detail_msg);
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
244 } else {
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
245 jio_snprintf(buf + n, buflen - n, "%sError: %s",
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
246 os::line_separator(), _message);
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
247 }
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
248 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
249 } else {
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
250 jio_snprintf(buf, buflen,
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
251 "Internal Error (0x%x), pid=%d, tid=" UINTX_FORMAT,
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
252 _id, os::current_process_id(), os::current_thread_id());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
253 }
a61af66fc99e Initial load
duke
parents:
diff changeset
254
a61af66fc99e Initial load
duke
parents:
diff changeset
255 return buf;
a61af66fc99e Initial load
duke
parents:
diff changeset
256 }
a61af66fc99e Initial load
duke
parents:
diff changeset
257
1384
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
258 void VMError::print_stack_trace(outputStream* st, JavaThread* jt,
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
259 char* buf, int buflen, bool verbose) {
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
260 #ifdef ZERO
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
261 if (jt->zero_stack()->sp() && jt->top_zero_frame()) {
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
262 // StackFrameStream uses the frame anchor, which may not have
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
263 // been set up. This can be done at any time in Zero, however,
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
264 // so if it hasn't been set up then we just set it up now and
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
265 // clear it again when we're done.
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
266 bool has_last_Java_frame = jt->has_last_Java_frame();
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
267 if (!has_last_Java_frame)
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
268 jt->set_last_Java_frame();
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
269 st->print("Java frames:");
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
270
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
271 // If the top frame is a Shark frame and the frame anchor isn't
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
272 // set up then it's possible that the information in the frame
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
273 // is garbage: it could be from a previous decache, or it could
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
274 // simply have never been written. So we print a warning...
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
275 StackFrameStream sfs(jt);
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
276 if (!has_last_Java_frame && !sfs.is_done()) {
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
277 if (sfs.current()->zeroframe()->is_shark_frame()) {
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
278 st->print(" (TOP FRAME MAY BE JUNK)");
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
279 }
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
280 }
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
281 st->cr();
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
282
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
283 // Print the frames
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
284 for(int i = 0; !sfs.is_done(); sfs.next(), i++) {
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
285 sfs.current()->zero_print_on_error(i, st, buf, buflen);
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
286 st->cr();
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
287 }
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
288
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
289 // Reset the frame anchor if necessary
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
290 if (!has_last_Java_frame)
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
291 jt->reset_last_Java_frame();
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
292 }
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
293 #else
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
294 if (jt->has_last_Java_frame()) {
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
295 st->print_cr("Java frames: (J=compiled Java code, j=interpreted, Vv=VM code)");
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
296 for(StackFrameStream sfs(jt); !sfs.is_done(); sfs.next()) {
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
297 sfs.current()->print_on_error(st, buf, buflen, verbose);
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
298 st->cr();
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
299 }
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
300 }
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
301 #endif // ZERO
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
302 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
303
a61af66fc99e Initial load
duke
parents:
diff changeset
304 // This is the main function to report a fatal error. Only one thread can
a61af66fc99e Initial load
duke
parents:
diff changeset
305 // call this function, so we don't need to worry about MT-safety. But it's
a61af66fc99e Initial load
duke
parents:
diff changeset
306 // possible that the error handler itself may crash or die on an internal
a61af66fc99e Initial load
duke
parents:
diff changeset
307 // error, for example, when the stack/heap is badly damaged. We must be
a61af66fc99e Initial load
duke
parents:
diff changeset
308 // able to handle recursive errors that happen inside error handler.
a61af66fc99e Initial load
duke
parents:
diff changeset
309 //
a61af66fc99e Initial load
duke
parents:
diff changeset
310 // Error reporting is done in several steps. If a crash or internal error
a61af66fc99e Initial load
duke
parents:
diff changeset
311 // occurred when reporting an error, the nested signal/exception handler
a61af66fc99e Initial load
duke
parents:
diff changeset
312 // can skip steps that are already (or partially) done. Error reporting will
a61af66fc99e Initial load
duke
parents:
diff changeset
313 // continue from the next step. This allows us to retrieve and print
a61af66fc99e Initial load
duke
parents:
diff changeset
314 // information that may be unsafe to get after a fatal error. If it happens,
a61af66fc99e Initial load
duke
parents:
diff changeset
315 // you may find nested report_and_die() frames when you look at the stack
a61af66fc99e Initial load
duke
parents:
diff changeset
316 // in a debugger.
a61af66fc99e Initial load
duke
parents:
diff changeset
317 //
a61af66fc99e Initial load
duke
parents:
diff changeset
318 // In general, a hang in error handler is much worse than a crash or internal
a61af66fc99e Initial load
duke
parents:
diff changeset
319 // error, as it's harder to recover from a hang. Deadlock can happen if we
a61af66fc99e Initial load
duke
parents:
diff changeset
320 // try to grab a lock that is already owned by current thread, or if the
a61af66fc99e Initial load
duke
parents:
diff changeset
321 // owner is blocked forever (e.g. in os::infinite_sleep()). If possible, the
a61af66fc99e Initial load
duke
parents:
diff changeset
322 // error handler and all the functions it called should avoid grabbing any
a61af66fc99e Initial load
duke
parents:
diff changeset
323 // lock. An important thing to notice is that memory allocation needs a lock.
a61af66fc99e Initial load
duke
parents:
diff changeset
324 //
a61af66fc99e Initial load
duke
parents:
diff changeset
325 // We should avoid using large stack allocated buffers. Many errors happen
a61af66fc99e Initial load
duke
parents:
diff changeset
326 // when stack space is already low. Making things even worse is that there
a61af66fc99e Initial load
duke
parents:
diff changeset
327 // could be nested report_and_die() calls on stack (see above). Only one
a61af66fc99e Initial load
duke
parents:
diff changeset
328 // thread can report error, so large buffers are statically allocated in data
a61af66fc99e Initial load
duke
parents:
diff changeset
329 // segment.
a61af66fc99e Initial load
duke
parents:
diff changeset
330
a61af66fc99e Initial load
duke
parents:
diff changeset
331 void VMError::report(outputStream* st) {
a61af66fc99e Initial load
duke
parents:
diff changeset
332 # define BEGIN if (_current_step == 0) { _current_step = 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
333 # define STEP(n, s) } if (_current_step < n) { _current_step = n; _current_step_info = s;
a61af66fc99e Initial load
duke
parents:
diff changeset
334 # define END }
a61af66fc99e Initial load
duke
parents:
diff changeset
335
a61af66fc99e Initial load
duke
parents:
diff changeset
336 // don't allocate large buffer on stack
a61af66fc99e Initial load
duke
parents:
diff changeset
337 static char buf[O_BUFLEN];
a61af66fc99e Initial load
duke
parents:
diff changeset
338
a61af66fc99e Initial load
duke
parents:
diff changeset
339 BEGIN
a61af66fc99e Initial load
duke
parents:
diff changeset
340
56
31d829b33f26 6549844: Wording problems in "An unexpected error ..."
coleenp
parents: 0
diff changeset
341 STEP(10, "(printing fatal error message)")
0
a61af66fc99e Initial load
duke
parents:
diff changeset
342
2095
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
343 st->print_cr("#");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
344 if (should_report_bug(_id)) {
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
345 st->print_cr("# A fatal error has been detected by the Java Runtime Environment:");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
346 } else {
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
347 st->print_cr("# There is insufficient memory for the Java "
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
348 "Runtime Environment to continue.");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
349 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
350
a61af66fc99e Initial load
duke
parents:
diff changeset
351 STEP(15, "(printing type of error)")
a61af66fc99e Initial load
duke
parents:
diff changeset
352
a61af66fc99e Initial load
duke
parents:
diff changeset
353 switch(_id) {
a61af66fc99e Initial load
duke
parents:
diff changeset
354 case oom_error:
a61af66fc99e Initial load
duke
parents:
diff changeset
355 if (_size) {
2095
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
356 st->print("# Native memory allocation (malloc) failed to allocate ");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
357 jio_snprintf(buf, sizeof(buf), SIZE_FORMAT, _size);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
358 st->print(buf);
a61af66fc99e Initial load
duke
parents:
diff changeset
359 st->print(" bytes");
a61af66fc99e Initial load
duke
parents:
diff changeset
360 if (_message != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
361 st->print(" for ");
a61af66fc99e Initial load
duke
parents:
diff changeset
362 st->print(_message);
a61af66fc99e Initial load
duke
parents:
diff changeset
363 }
2095
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
364 st->cr();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
365 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
366 if (_message != NULL)
2095
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
367 st->print("# ");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
368 st->print_cr(_message);
a61af66fc99e Initial load
duke
parents:
diff changeset
369 }
2095
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
370 // In error file give some solutions
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
371 if (_verbose) {
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
372 st->print_cr("# Possible reasons:");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
373 st->print_cr("# The system is out of physical RAM or swap space");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
374 st->print_cr("# In 32 bit mode, the process size limit was hit");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
375 st->print_cr("# Possible solutions:");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
376 st->print_cr("# Reduce memory load on the system");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
377 st->print_cr("# Increase physical memory or swap space");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
378 st->print_cr("# Check if swap backing store is full");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
379 st->print_cr("# Use 64 bit Java on a 64 bit OS");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
380 st->print_cr("# Decrease Java heap size (-Xmx/-Xms)");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
381 st->print_cr("# Decrease number of Java threads");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
382 st->print_cr("# Decrease Java thread stack sizes (-Xss)");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
383 st->print_cr("# Set larger code cache with -XX:ReservedCodeCacheSize=");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
384 st->print_cr("# This output file may be truncated or incomplete.");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
385 } else {
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
386 return; // that's enough for the screen
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
387 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
388 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
389 case internal_error:
a61af66fc99e Initial load
duke
parents:
diff changeset
390 default:
a61af66fc99e Initial load
duke
parents:
diff changeset
391 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
392 }
a61af66fc99e Initial load
duke
parents:
diff changeset
393
a61af66fc99e Initial load
duke
parents:
diff changeset
394 STEP(20, "(printing exception/signal name)")
a61af66fc99e Initial load
duke
parents:
diff changeset
395
a61af66fc99e Initial load
duke
parents:
diff changeset
396 st->print_cr("#");
a61af66fc99e Initial load
duke
parents:
diff changeset
397 st->print("# ");
a61af66fc99e Initial load
duke
parents:
diff changeset
398 // Is it an OS exception/signal?
a61af66fc99e Initial load
duke
parents:
diff changeset
399 if (os::exception_name(_id, buf, sizeof(buf))) {
a61af66fc99e Initial load
duke
parents:
diff changeset
400 st->print("%s", buf);
a61af66fc99e Initial load
duke
parents:
diff changeset
401 st->print(" (0x%x)", _id); // signal number
a61af66fc99e Initial load
duke
parents:
diff changeset
402 st->print(" at pc=" PTR_FORMAT, _pc);
a61af66fc99e Initial load
duke
parents:
diff changeset
403 } else {
2095
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
404 if (should_report_bug(_id)) {
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
405 st->print("Internal Error");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
406 } else {
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
407 st->print("Out of Memory Error");
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
408 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
409 if (_filename != NULL && _lineno > 0) {
a61af66fc99e Initial load
duke
parents:
diff changeset
410 #ifdef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
411 // In product mode chop off pathname?
a61af66fc99e Initial load
duke
parents:
diff changeset
412 char separator = os::file_separator()[0];
a61af66fc99e Initial load
duke
parents:
diff changeset
413 const char *p = strrchr(_filename, separator);
a61af66fc99e Initial load
duke
parents:
diff changeset
414 const char *file = p ? p+1 : _filename;
a61af66fc99e Initial load
duke
parents:
diff changeset
415 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
416 const char *file = _filename;
a61af66fc99e Initial load
duke
parents:
diff changeset
417 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
418 size_t len = strlen(file);
a61af66fc99e Initial load
duke
parents:
diff changeset
419 size_t buflen = sizeof(buf);
a61af66fc99e Initial load
duke
parents:
diff changeset
420
a61af66fc99e Initial load
duke
parents:
diff changeset
421 strncpy(buf, file, buflen);
a61af66fc99e Initial load
duke
parents:
diff changeset
422 if (len + 10 < buflen) {
603
dbbe28fc66b5 6778669: Patch from Red Hat -- fixes compilation errors
twisti
parents: 511
diff changeset
423 sprintf(buf + len, ":%d", _lineno);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
424 }
a61af66fc99e Initial load
duke
parents:
diff changeset
425 st->print(" (%s)", buf);
a61af66fc99e Initial load
duke
parents:
diff changeset
426 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
427 st->print(" (0x%x)", _id);
a61af66fc99e Initial load
duke
parents:
diff changeset
428 }
a61af66fc99e Initial load
duke
parents:
diff changeset
429 }
a61af66fc99e Initial load
duke
parents:
diff changeset
430
a61af66fc99e Initial load
duke
parents:
diff changeset
431 STEP(30, "(printing current thread and pid)")
a61af66fc99e Initial load
duke
parents:
diff changeset
432
a61af66fc99e Initial load
duke
parents:
diff changeset
433 // process id, thread id
a61af66fc99e Initial load
duke
parents:
diff changeset
434 st->print(", pid=%d", os::current_process_id());
a61af66fc99e Initial load
duke
parents:
diff changeset
435 st->print(", tid=" UINTX_FORMAT, os::current_thread_id());
a61af66fc99e Initial load
duke
parents:
diff changeset
436 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
437
a61af66fc99e Initial load
duke
parents:
diff changeset
438 STEP(40, "(printing error message)")
a61af66fc99e Initial load
duke
parents:
diff changeset
439
2095
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
440 if (should_report_bug(_id)) { // already printed the message.
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
441 // error message
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
442 if (_detail_msg) {
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
443 st->print_cr("# %s: %s", _message ? _message : "Error", _detail_msg);
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
444 } else if (_message) {
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
445 st->print_cr("# Error: %s", _message);
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
446 }
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
447 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
448
a61af66fc99e Initial load
duke
parents:
diff changeset
449 STEP(50, "(printing Java version string)")
a61af66fc99e Initial load
duke
parents:
diff changeset
450
a61af66fc99e Initial load
duke
parents:
diff changeset
451 // VM version
a61af66fc99e Initial load
duke
parents:
diff changeset
452 st->print_cr("#");
473
3ad2b8576c4a 6689685: Hotspot crash error message should include libraries version
coleenp
parents: 420
diff changeset
453 JDK_Version::current().to_string(buf, sizeof(buf));
6181
f8de958e5b2c 7176856: add the JRE name to the error log
twisti
parents: 5984
diff changeset
454 const char* runtime_name = JDK_Version::runtime_name() != NULL ?
f8de958e5b2c 7176856: add the JRE name to the error log
twisti
parents: 5984
diff changeset
455 JDK_Version::runtime_name() : "";
6921
a1b8cf9cf970 8002078: hs_err_pid file should report full JDK version string
sla
parents: 6198
diff changeset
456 const char* runtime_version = JDK_Version::runtime_version() != NULL ?
a1b8cf9cf970 8002078: hs_err_pid file should report full JDK version string
sla
parents: 6198
diff changeset
457 JDK_Version::runtime_version() : "";
a1b8cf9cf970 8002078: hs_err_pid file should report full JDK version string
sla
parents: 6198
diff changeset
458 st->print_cr("# JRE version: %s (%s) (build %s)", runtime_name, buf, runtime_version);
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 56
diff changeset
459 st->print_cr("# Java VM: %s (%s %s %s %s)",
0
a61af66fc99e Initial load
duke
parents:
diff changeset
460 Abstract_VM_Version::vm_name(),
a61af66fc99e Initial load
duke
parents:
diff changeset
461 Abstract_VM_Version::vm_release(),
a61af66fc99e Initial load
duke
parents:
diff changeset
462 Abstract_VM_Version::vm_info_string(),
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 56
diff changeset
463 Abstract_VM_Version::vm_platform_string(),
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 56
diff changeset
464 UseCompressedOops ? "compressed oops" : ""
0
a61af66fc99e Initial load
duke
parents:
diff changeset
465 );
a61af66fc99e Initial load
duke
parents:
diff changeset
466
a61af66fc99e Initial load
duke
parents:
diff changeset
467 STEP(60, "(printing problematic frame)")
a61af66fc99e Initial load
duke
parents:
diff changeset
468
a61af66fc99e Initial load
duke
parents:
diff changeset
469 // Print current frame if we have a context (i.e. it's a crash)
a61af66fc99e Initial load
duke
parents:
diff changeset
470 if (_context) {
a61af66fc99e Initial load
duke
parents:
diff changeset
471 st->print_cr("# Problematic frame:");
a61af66fc99e Initial load
duke
parents:
diff changeset
472 st->print("# ");
a61af66fc99e Initial load
duke
parents:
diff changeset
473 frame fr = os::fetch_frame_from_context(_context);
a61af66fc99e Initial load
duke
parents:
diff changeset
474 fr.print_on_error(st, buf, sizeof(buf));
a61af66fc99e Initial load
duke
parents:
diff changeset
475 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
476 st->print_cr("#");
a61af66fc99e Initial load
duke
parents:
diff changeset
477 }
2204
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
478 STEP(63, "(printing core file information)")
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
479 st->print("# ");
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
480 if (coredump_status) {
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
481 st->print("Core dump written. Default location: %s", coredump_message);
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
482 } else {
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
483 st->print("Failed to write core dump. %s", coredump_message);
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
484 }
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
485 st->print_cr("");
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
486 st->print_cr("#");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
487
a61af66fc99e Initial load
duke
parents:
diff changeset
488 STEP(65, "(printing bug submit message)")
a61af66fc99e Initial load
duke
parents:
diff changeset
489
2095
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
490 if (should_report_bug(_id) && _verbose) {
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
491 print_bug_submit_message(st, _thread);
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
492 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
493
a61af66fc99e Initial load
duke
parents:
diff changeset
494 STEP(70, "(printing thread)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
495
a61af66fc99e Initial load
duke
parents:
diff changeset
496 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
497 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
498 st->print_cr("--------------- T H R E A D ---------------");
a61af66fc99e Initial load
duke
parents:
diff changeset
499 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
500 }
a61af66fc99e Initial load
duke
parents:
diff changeset
501
a61af66fc99e Initial load
duke
parents:
diff changeset
502 STEP(80, "(printing current thread)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
503
a61af66fc99e Initial load
duke
parents:
diff changeset
504 // current thread
a61af66fc99e Initial load
duke
parents:
diff changeset
505 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
506 if (_thread) {
a61af66fc99e Initial load
duke
parents:
diff changeset
507 st->print("Current thread (" PTR_FORMAT "): ", _thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
508 _thread->print_on_error(st, buf, sizeof(buf));
a61af66fc99e Initial load
duke
parents:
diff changeset
509 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
510 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
511 st->print_cr("Current thread is native thread");
a61af66fc99e Initial load
duke
parents:
diff changeset
512 }
a61af66fc99e Initial load
duke
parents:
diff changeset
513 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
514 }
a61af66fc99e Initial load
duke
parents:
diff changeset
515
a61af66fc99e Initial load
duke
parents:
diff changeset
516 STEP(90, "(printing siginfo)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
517
a61af66fc99e Initial load
duke
parents:
diff changeset
518 // signal no, signal code, address that caused the fault
a61af66fc99e Initial load
duke
parents:
diff changeset
519 if (_verbose && _siginfo) {
a61af66fc99e Initial load
duke
parents:
diff changeset
520 os::print_siginfo(st, _siginfo);
a61af66fc99e Initial load
duke
parents:
diff changeset
521 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
522 }
a61af66fc99e Initial load
duke
parents:
diff changeset
523
a61af66fc99e Initial load
duke
parents:
diff changeset
524 STEP(100, "(printing registers, top of stack, instructions near pc)")
a61af66fc99e Initial load
duke
parents:
diff changeset
525
a61af66fc99e Initial load
duke
parents:
diff changeset
526 // registers, top of stack, instructions near pc
a61af66fc99e Initial load
duke
parents:
diff changeset
527 if (_verbose && _context) {
a61af66fc99e Initial load
duke
parents:
diff changeset
528 os::print_context(st, _context);
a61af66fc99e Initial load
duke
parents:
diff changeset
529 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
530 }
a61af66fc99e Initial load
duke
parents:
diff changeset
531
1907
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
532 STEP(105, "(printing register info)")
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
533
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
534 // decode register contents if possible
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
535 if (_verbose && _context && Universe::is_fully_initialized()) {
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
536 os::print_register_info(st, _context);
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
537 st->cr();
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
538 }
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
539
0
a61af66fc99e Initial load
duke
parents:
diff changeset
540 STEP(110, "(printing stack bounds)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
541
a61af66fc99e Initial load
duke
parents:
diff changeset
542 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
543 st->print("Stack: ");
a61af66fc99e Initial load
duke
parents:
diff changeset
544
a61af66fc99e Initial load
duke
parents:
diff changeset
545 address stack_top;
a61af66fc99e Initial load
duke
parents:
diff changeset
546 size_t stack_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
547
a61af66fc99e Initial load
duke
parents:
diff changeset
548 if (_thread) {
a61af66fc99e Initial load
duke
parents:
diff changeset
549 stack_top = _thread->stack_base();
a61af66fc99e Initial load
duke
parents:
diff changeset
550 stack_size = _thread->stack_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
551 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
552 stack_top = os::current_stack_base();
a61af66fc99e Initial load
duke
parents:
diff changeset
553 stack_size = os::current_stack_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
554 }
a61af66fc99e Initial load
duke
parents:
diff changeset
555
a61af66fc99e Initial load
duke
parents:
diff changeset
556 address stack_bottom = stack_top - stack_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
557 st->print("[" PTR_FORMAT "," PTR_FORMAT "]", stack_bottom, stack_top);
a61af66fc99e Initial load
duke
parents:
diff changeset
558
a61af66fc99e Initial load
duke
parents:
diff changeset
559 frame fr = _context ? os::fetch_frame_from_context(_context)
a61af66fc99e Initial load
duke
parents:
diff changeset
560 : os::current_frame();
a61af66fc99e Initial load
duke
parents:
diff changeset
561
a61af66fc99e Initial load
duke
parents:
diff changeset
562 if (fr.sp()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
563 st->print(", sp=" PTR_FORMAT, fr.sp());
1684
66c5dadb4d61 6973308: Missing zero length check before repne scas in check_klass_subtype_slow_path()
kvn
parents: 1552
diff changeset
564 size_t free_stack_size = pointer_delta(fr.sp(), stack_bottom, 1024);
66c5dadb4d61 6973308: Missing zero length check before repne scas in check_klass_subtype_slow_path()
kvn
parents: 1552
diff changeset
565 st->print(", free space=" SIZE_FORMAT "k", free_stack_size);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
566 }
a61af66fc99e Initial load
duke
parents:
diff changeset
567
a61af66fc99e Initial load
duke
parents:
diff changeset
568 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
569 }
a61af66fc99e Initial load
duke
parents:
diff changeset
570
a61af66fc99e Initial load
duke
parents:
diff changeset
571 STEP(120, "(printing native stack)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
572
a61af66fc99e Initial load
duke
parents:
diff changeset
573 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
574 frame fr = _context ? os::fetch_frame_from_context(_context)
a61af66fc99e Initial load
duke
parents:
diff changeset
575 : os::current_frame();
a61af66fc99e Initial load
duke
parents:
diff changeset
576
a61af66fc99e Initial load
duke
parents:
diff changeset
577 // see if it's a valid frame
a61af66fc99e Initial load
duke
parents:
diff changeset
578 if (fr.pc()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
579 st->print_cr("Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)");
a61af66fc99e Initial load
duke
parents:
diff changeset
580
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents: 1972
diff changeset
581
0
a61af66fc99e Initial load
duke
parents:
diff changeset
582 int count = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
583 while (count++ < StackPrintLimit) {
a61af66fc99e Initial load
duke
parents:
diff changeset
584 fr.print_on_error(st, buf, sizeof(buf));
a61af66fc99e Initial load
duke
parents:
diff changeset
585 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
586 if (os::is_first_C_frame(&fr)) break;
a61af66fc99e Initial load
duke
parents:
diff changeset
587 fr = os::get_sender_for_C_frame(&fr);
a61af66fc99e Initial load
duke
parents:
diff changeset
588 }
a61af66fc99e Initial load
duke
parents:
diff changeset
589
a61af66fc99e Initial load
duke
parents:
diff changeset
590 if (count > StackPrintLimit) {
a61af66fc99e Initial load
duke
parents:
diff changeset
591 st->print_cr("...<more frames>...");
a61af66fc99e Initial load
duke
parents:
diff changeset
592 }
a61af66fc99e Initial load
duke
parents:
diff changeset
593
a61af66fc99e Initial load
duke
parents:
diff changeset
594 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
595 }
a61af66fc99e Initial load
duke
parents:
diff changeset
596 }
a61af66fc99e Initial load
duke
parents:
diff changeset
597
a61af66fc99e Initial load
duke
parents:
diff changeset
598 STEP(130, "(printing Java stack)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
599
a61af66fc99e Initial load
duke
parents:
diff changeset
600 if (_verbose && _thread && _thread->is_Java_thread()) {
1384
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
601 print_stack_trace(st, (JavaThread*)_thread, buf, sizeof(buf));
0
a61af66fc99e Initial load
duke
parents:
diff changeset
602 }
a61af66fc99e Initial load
duke
parents:
diff changeset
603
1119
547f81740344 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 1010
diff changeset
604 STEP(135, "(printing target Java thread stack)" )
547f81740344 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 1010
diff changeset
605
547f81740344 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 1010
diff changeset
606 // printing Java thread stack trace if it is involved in GC crash
1907
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
607 if (_verbose && _thread && (_thread->is_Named_thread())) {
1119
547f81740344 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 1010
diff changeset
608 JavaThread* jt = ((NamedThread *)_thread)->processed_thread();
547f81740344 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 1010
diff changeset
609 if (jt != NULL) {
547f81740344 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 1010
diff changeset
610 st->print_cr("JavaThread " PTR_FORMAT " (nid = " UINTX_FORMAT ") was being processed", jt, jt->osthread()->thread_id());
1384
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 1353
diff changeset
611 print_stack_trace(st, jt, buf, sizeof(buf), true);
1119
547f81740344 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 1010
diff changeset
612 }
547f81740344 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 1010
diff changeset
613 }
547f81740344 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 1010
diff changeset
614
0
a61af66fc99e Initial load
duke
parents:
diff changeset
615 STEP(140, "(printing VM operation)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
616
a61af66fc99e Initial load
duke
parents:
diff changeset
617 if (_verbose && _thread && _thread->is_VM_thread()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
618 VMThread* t = (VMThread*)_thread;
a61af66fc99e Initial load
duke
parents:
diff changeset
619 VM_Operation* op = t->vm_operation();
a61af66fc99e Initial load
duke
parents:
diff changeset
620 if (op) {
a61af66fc99e Initial load
duke
parents:
diff changeset
621 op->print_on_error(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
622 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
623 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
624 }
a61af66fc99e Initial load
duke
parents:
diff changeset
625 }
a61af66fc99e Initial load
duke
parents:
diff changeset
626
a61af66fc99e Initial load
duke
parents:
diff changeset
627 STEP(150, "(printing current compile task)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
628
a61af66fc99e Initial load
duke
parents:
diff changeset
629 if (_verbose && _thread && _thread->is_Compiler_thread()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
630 CompilerThread* t = (CompilerThread*)_thread;
a61af66fc99e Initial load
duke
parents:
diff changeset
631 if (t->task()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
632 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
633 st->print_cr("Current CompileTask:");
a61af66fc99e Initial load
duke
parents:
diff changeset
634 t->task()->print_line_on_error(st, buf, sizeof(buf));
a61af66fc99e Initial load
duke
parents:
diff changeset
635 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
636 }
a61af66fc99e Initial load
duke
parents:
diff changeset
637 }
a61af66fc99e Initial load
duke
parents:
diff changeset
638
a61af66fc99e Initial load
duke
parents:
diff changeset
639 STEP(160, "(printing process)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
640
a61af66fc99e Initial load
duke
parents:
diff changeset
641 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
642 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
643 st->print_cr("--------------- P R O C E S S ---------------");
a61af66fc99e Initial load
duke
parents:
diff changeset
644 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
645 }
a61af66fc99e Initial load
duke
parents:
diff changeset
646
a61af66fc99e Initial load
duke
parents:
diff changeset
647 STEP(170, "(printing all threads)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
648
a61af66fc99e Initial load
duke
parents:
diff changeset
649 // all threads
a61af66fc99e Initial load
duke
parents:
diff changeset
650 if (_verbose && _thread) {
a61af66fc99e Initial load
duke
parents:
diff changeset
651 Threads::print_on_error(st, _thread, buf, sizeof(buf));
a61af66fc99e Initial load
duke
parents:
diff changeset
652 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
653 }
a61af66fc99e Initial load
duke
parents:
diff changeset
654
a61af66fc99e Initial load
duke
parents:
diff changeset
655 STEP(175, "(printing VM state)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
656
a61af66fc99e Initial load
duke
parents:
diff changeset
657 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
658 // Safepoint state
a61af66fc99e Initial load
duke
parents:
diff changeset
659 st->print("VM state:");
a61af66fc99e Initial load
duke
parents:
diff changeset
660
a61af66fc99e Initial load
duke
parents:
diff changeset
661 if (SafepointSynchronize::is_synchronizing()) st->print("synchronizing");
a61af66fc99e Initial load
duke
parents:
diff changeset
662 else if (SafepointSynchronize::is_at_safepoint()) st->print("at safepoint");
a61af66fc99e Initial load
duke
parents:
diff changeset
663 else st->print("not at safepoint");
a61af66fc99e Initial load
duke
parents:
diff changeset
664
a61af66fc99e Initial load
duke
parents:
diff changeset
665 // Also see if error occurred during initialization or shutdown
a61af66fc99e Initial load
duke
parents:
diff changeset
666 if (!Universe::is_fully_initialized()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
667 st->print(" (not fully initialized)");
a61af66fc99e Initial load
duke
parents:
diff changeset
668 } else if (VM_Exit::vm_exited()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
669 st->print(" (shutting down)");
a61af66fc99e Initial load
duke
parents:
diff changeset
670 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
671 st->print(" (normal execution)");
a61af66fc99e Initial load
duke
parents:
diff changeset
672 }
a61af66fc99e Initial load
duke
parents:
diff changeset
673 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
674 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
675 }
a61af66fc99e Initial load
duke
parents:
diff changeset
676
a61af66fc99e Initial load
duke
parents:
diff changeset
677 STEP(180, "(printing owned locks on error)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
678
a61af66fc99e Initial load
duke
parents:
diff changeset
679 // mutexes/monitors that currently have an owner
a61af66fc99e Initial load
duke
parents:
diff changeset
680 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
681 print_owned_locks_on_error(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
682 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
683 }
a61af66fc99e Initial load
duke
parents:
diff changeset
684
a61af66fc99e Initial load
duke
parents:
diff changeset
685 STEP(190, "(printing heap information)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
686
a61af66fc99e Initial load
duke
parents:
diff changeset
687 if (_verbose && Universe::is_fully_initialized()) {
4073
53074c2c4600 7099849: G1: include heap region information in hs_err files
tonyp
parents: 3960
diff changeset
688 // Print heap information before vm abort. As we'd like as much
53074c2c4600 7099849: G1: include heap region information in hs_err files
tonyp
parents: 3960
diff changeset
689 // information as possible in the report we ask for the
53074c2c4600 7099849: G1: include heap region information in hs_err files
tonyp
parents: 3960
diff changeset
690 // extended (i.e., more detailed) version.
53074c2c4600 7099849: G1: include heap region information in hs_err files
tonyp
parents: 3960
diff changeset
691 Universe::print_on(st, true /* extended */);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
692 st->cr();
5984
fd09f2d8283e 7157141: crash in 64 bit with corrupted oops
never
parents: 5915
diff changeset
693
fd09f2d8283e 7157141: crash in 64 bit with corrupted oops
never
parents: 5915
diff changeset
694 Universe::heap()->barrier_set()->print_on(st);
fd09f2d8283e 7157141: crash in 64 bit with corrupted oops
never
parents: 5915
diff changeset
695 st->cr();
fd09f2d8283e 7157141: crash in 64 bit with corrupted oops
never
parents: 5915
diff changeset
696
fd09f2d8283e 7157141: crash in 64 bit with corrupted oops
never
parents: 5915
diff changeset
697 st->print_cr("Polling page: " INTPTR_FORMAT, os::get_polling_page());
fd09f2d8283e 7157141: crash in 64 bit with corrupted oops
never
parents: 5915
diff changeset
698 st->cr();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
699 }
a61af66fc99e Initial load
duke
parents:
diff changeset
700
1907
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
701 STEP(195, "(printing code cache information)" )
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
702
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
703 if (_verbose && Universe::is_fully_initialized()) {
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
704 // print code cache information before vm abort
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
705 CodeCache::print_bounds(st);
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
706 st->cr();
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
707 }
1e9a9d2e6509 6970683: improvements to hs_err output
never
parents: 1689
diff changeset
708
4872
aa3d708d67c4 7141200: log some interesting information in ring buffers for crashes
never
parents: 4803
diff changeset
709 STEP(200, "(printing ring buffers)" )
aa3d708d67c4 7141200: log some interesting information in ring buffers for crashes
never
parents: 4803
diff changeset
710
aa3d708d67c4 7141200: log some interesting information in ring buffers for crashes
never
parents: 4803
diff changeset
711 if (_verbose) {
aa3d708d67c4 7141200: log some interesting information in ring buffers for crashes
never
parents: 4803
diff changeset
712 Events::print_all(st);
aa3d708d67c4 7141200: log some interesting information in ring buffers for crashes
never
parents: 4803
diff changeset
713 st->cr();
aa3d708d67c4 7141200: log some interesting information in ring buffers for crashes
never
parents: 4803
diff changeset
714 }
aa3d708d67c4 7141200: log some interesting information in ring buffers for crashes
never
parents: 4803
diff changeset
715
aa3d708d67c4 7141200: log some interesting information in ring buffers for crashes
never
parents: 4803
diff changeset
716 STEP(205, "(printing dynamic libraries)" )
0
a61af66fc99e Initial load
duke
parents:
diff changeset
717
a61af66fc99e Initial load
duke
parents:
diff changeset
718 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
719 // dynamic libraries, or memory map
a61af66fc99e Initial load
duke
parents:
diff changeset
720 os::print_dll_info(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
721 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
722 }
a61af66fc99e Initial load
duke
parents:
diff changeset
723
a61af66fc99e Initial load
duke
parents:
diff changeset
724 STEP(210, "(printing VM options)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
725
a61af66fc99e Initial load
duke
parents:
diff changeset
726 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
727 // VM options
a61af66fc99e Initial load
duke
parents:
diff changeset
728 Arguments::print_on(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
729 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
730 }
a61af66fc99e Initial load
duke
parents:
diff changeset
731
5915
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents: 4872
diff changeset
732 STEP(215, "(printing warning if internal testing API used)" )
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents: 4872
diff changeset
733
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents: 4872
diff changeset
734 if (WhiteBox::used()) {
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents: 4872
diff changeset
735 st->print_cr("Unsupported internal testing APIs have been used.");
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents: 4872
diff changeset
736 st->cr();
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents: 4872
diff changeset
737 }
2d503de963b3 7148152: Add whitebox testing API to HotSpot
mgerdin
parents: 4872
diff changeset
738
0
a61af66fc99e Initial load
duke
parents:
diff changeset
739 STEP(220, "(printing environment variables)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
740
a61af66fc99e Initial load
duke
parents:
diff changeset
741 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
742 os::print_environment_variables(st, env_list, buf, sizeof(buf));
a61af66fc99e Initial load
duke
parents:
diff changeset
743 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
744 }
a61af66fc99e Initial load
duke
parents:
diff changeset
745
a61af66fc99e Initial load
duke
parents:
diff changeset
746 STEP(225, "(printing signal handlers)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
747
a61af66fc99e Initial load
duke
parents:
diff changeset
748 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
749 os::print_signal_handlers(st, buf, sizeof(buf));
a61af66fc99e Initial load
duke
parents:
diff changeset
750 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
751 }
a61af66fc99e Initial load
duke
parents:
diff changeset
752
a61af66fc99e Initial load
duke
parents:
diff changeset
753 STEP(230, "" )
a61af66fc99e Initial load
duke
parents:
diff changeset
754
a61af66fc99e Initial load
duke
parents:
diff changeset
755 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
756 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
757 st->print_cr("--------------- S Y S T E M ---------------");
a61af66fc99e Initial load
duke
parents:
diff changeset
758 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
759 }
a61af66fc99e Initial load
duke
parents:
diff changeset
760
a61af66fc99e Initial load
duke
parents:
diff changeset
761 STEP(240, "(printing OS information)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
762
a61af66fc99e Initial load
duke
parents:
diff changeset
763 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
764 os::print_os_info(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
765 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
766 }
a61af66fc99e Initial load
duke
parents:
diff changeset
767
a61af66fc99e Initial load
duke
parents:
diff changeset
768 STEP(250, "(printing CPU info)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
769 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
770 os::print_cpu_info(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
771 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
772 }
a61af66fc99e Initial load
duke
parents:
diff changeset
773
a61af66fc99e Initial load
duke
parents:
diff changeset
774 STEP(260, "(printing memory info)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
775
a61af66fc99e Initial load
duke
parents:
diff changeset
776 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
777 os::print_memory_info(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
778 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
779 }
a61af66fc99e Initial load
duke
parents:
diff changeset
780
a61af66fc99e Initial load
duke
parents:
diff changeset
781 STEP(270, "(printing internal vm info)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
782
a61af66fc99e Initial load
duke
parents:
diff changeset
783 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
784 st->print_cr("vm_info: %s", Abstract_VM_Version::internal_vm_info_string());
a61af66fc99e Initial load
duke
parents:
diff changeset
785 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
786 }
a61af66fc99e Initial load
duke
parents:
diff changeset
787
a61af66fc99e Initial load
duke
parents:
diff changeset
788 STEP(280, "(printing date and time)" )
a61af66fc99e Initial load
duke
parents:
diff changeset
789
a61af66fc99e Initial load
duke
parents:
diff changeset
790 if (_verbose) {
a61af66fc99e Initial load
duke
parents:
diff changeset
791 os::print_date_and_time(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
792 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
793 }
a61af66fc99e Initial load
duke
parents:
diff changeset
794
a61af66fc99e Initial load
duke
parents:
diff changeset
795 END
a61af66fc99e Initial load
duke
parents:
diff changeset
796
a61af66fc99e Initial load
duke
parents:
diff changeset
797 # undef BEGIN
a61af66fc99e Initial load
duke
parents:
diff changeset
798 # undef STEP
a61af66fc99e Initial load
duke
parents:
diff changeset
799 # undef END
a61af66fc99e Initial load
duke
parents:
diff changeset
800 }
a61af66fc99e Initial load
duke
parents:
diff changeset
801
1681
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1552
diff changeset
802 VMError* volatile VMError::first_error = NULL;
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1552
diff changeset
803 volatile jlong VMError::first_error_tid = -1;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
804
a61af66fc99e Initial load
duke
parents:
diff changeset
805 void VMError::report_and_die() {
a61af66fc99e Initial load
duke
parents:
diff changeset
806 // Don't allocate large buffer on stack
a61af66fc99e Initial load
duke
parents:
diff changeset
807 static char buffer[O_BUFLEN];
a61af66fc99e Initial load
duke
parents:
diff changeset
808
a61af66fc99e Initial load
duke
parents:
diff changeset
809 // An error could happen before tty is initialized or after it has been
a61af66fc99e Initial load
duke
parents:
diff changeset
810 // destroyed. Here we use a very simple unbuffered fdStream for printing.
a61af66fc99e Initial load
duke
parents:
diff changeset
811 // Only out.print_raw() and out.print_raw_cr() should be used, as other
a61af66fc99e Initial load
duke
parents:
diff changeset
812 // printing methods need to allocate large buffer on stack. To format a
a61af66fc99e Initial load
duke
parents:
diff changeset
813 // string, use jio_snprintf() with a static buffer or use staticBufferStream.
a61af66fc99e Initial load
duke
parents:
diff changeset
814 static fdStream out(defaultStream::output_fd());
a61af66fc99e Initial load
duke
parents:
diff changeset
815
a61af66fc99e Initial load
duke
parents:
diff changeset
816 // How many errors occurred in error handler when reporting first_error.
a61af66fc99e Initial load
duke
parents:
diff changeset
817 static int recursive_error_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
818
a61af66fc99e Initial load
duke
parents:
diff changeset
819 // We will first print a brief message to standard out (verbose = false),
a61af66fc99e Initial load
duke
parents:
diff changeset
820 // then save detailed information in log file (verbose = true).
a61af66fc99e Initial load
duke
parents:
diff changeset
821 static bool out_done = false; // done printing to standard out
a61af66fc99e Initial load
duke
parents:
diff changeset
822 static bool log_done = false; // done saving error log
2199
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
823 static bool transmit_report_done = false; // done error reporting
0
a61af66fc99e Initial load
duke
parents:
diff changeset
824 static fdStream log; // error log
a61af66fc99e Initial load
duke
parents:
diff changeset
825
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 5984
diff changeset
826 // disble NMT to avoid further exception
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 5984
diff changeset
827 MemTracker::shutdown(MemTracker::NMT_error_reporting);
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 5984
diff changeset
828
0
a61af66fc99e Initial load
duke
parents:
diff changeset
829 if (SuppressFatalErrorMessage) {
a61af66fc99e Initial load
duke
parents:
diff changeset
830 os::abort();
a61af66fc99e Initial load
duke
parents:
diff changeset
831 }
a61af66fc99e Initial load
duke
parents:
diff changeset
832 jlong mytid = os::current_thread_id();
a61af66fc99e Initial load
duke
parents:
diff changeset
833 if (first_error == NULL &&
a61af66fc99e Initial load
duke
parents:
diff changeset
834 Atomic::cmpxchg_ptr(this, &first_error, NULL) == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
835
a61af66fc99e Initial load
duke
parents:
diff changeset
836 // first time
a61af66fc99e Initial load
duke
parents:
diff changeset
837 first_error_tid = mytid;
a61af66fc99e Initial load
duke
parents:
diff changeset
838 set_error_reported();
a61af66fc99e Initial load
duke
parents:
diff changeset
839
2302
da091bb67459 7022037: Pause when exiting if debugger is attached on windows
sla
parents: 2204
diff changeset
840 if (ShowMessageBoxOnError || PauseAtExit) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
841 show_message_box(buffer, sizeof(buffer));
a61af66fc99e Initial load
duke
parents:
diff changeset
842
a61af66fc99e Initial load
duke
parents:
diff changeset
843 // User has asked JVM to abort. Reset ShowMessageBoxOnError so the
a61af66fc99e Initial load
duke
parents:
diff changeset
844 // WatcherThread can kill JVM if the error handler hangs.
a61af66fc99e Initial load
duke
parents:
diff changeset
845 ShowMessageBoxOnError = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
846 }
a61af66fc99e Initial load
duke
parents:
diff changeset
847
2204
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
848 // Write a minidump on Windows, check core dump limits on Linux/Solaris
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
849 os::check_or_create_dump(_siginfo, _context, buffer, sizeof(buffer));
63d374c54045 7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents: 2199
diff changeset
850
0
a61af66fc99e Initial load
duke
parents:
diff changeset
851 // reset signal handlers or exception filter; make sure recursive crashes
a61af66fc99e Initial load
duke
parents:
diff changeset
852 // are handled properly.
a61af66fc99e Initial load
duke
parents:
diff changeset
853 reset_signal_handlers();
a61af66fc99e Initial load
duke
parents:
diff changeset
854
a61af66fc99e Initial load
duke
parents:
diff changeset
855 } else {
511
dabd8d202164 4997835: RFE: crash dump will only be created when running w/ -XX:+ShowMessageBoxOnError
coleenp
parents: 473
diff changeset
856 // If UseOsErrorReporting we call this for each level of the call stack
dabd8d202164 4997835: RFE: crash dump will only be created when running w/ -XX:+ShowMessageBoxOnError
coleenp
parents: 473
diff changeset
857 // while searching for the exception handler. Only the first level needs
dabd8d202164 4997835: RFE: crash dump will only be created when running w/ -XX:+ShowMessageBoxOnError
coleenp
parents: 473
diff changeset
858 // to be reported.
dabd8d202164 4997835: RFE: crash dump will only be created when running w/ -XX:+ShowMessageBoxOnError
coleenp
parents: 473
diff changeset
859 if (UseOSErrorReporting && log_done) return;
dabd8d202164 4997835: RFE: crash dump will only be created when running w/ -XX:+ShowMessageBoxOnError
coleenp
parents: 473
diff changeset
860
0
a61af66fc99e Initial load
duke
parents:
diff changeset
861 // This is not the first error, see if it happened in a different thread
a61af66fc99e Initial load
duke
parents:
diff changeset
862 // or in the same thread during error reporting.
a61af66fc99e Initial load
duke
parents:
diff changeset
863 if (first_error_tid != mytid) {
a61af66fc99e Initial load
duke
parents:
diff changeset
864 jio_snprintf(buffer, sizeof(buffer),
a61af66fc99e Initial load
duke
parents:
diff changeset
865 "[thread " INT64_FORMAT " also had an error]",
a61af66fc99e Initial load
duke
parents:
diff changeset
866 mytid);
a61af66fc99e Initial load
duke
parents:
diff changeset
867 out.print_raw_cr(buffer);
a61af66fc99e Initial load
duke
parents:
diff changeset
868
a61af66fc99e Initial load
duke
parents:
diff changeset
869 // error reporting is not MT-safe, block current thread
a61af66fc99e Initial load
duke
parents:
diff changeset
870 os::infinite_sleep();
a61af66fc99e Initial load
duke
parents:
diff changeset
871
a61af66fc99e Initial load
duke
parents:
diff changeset
872 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
873 if (recursive_error_count++ > 30) {
a61af66fc99e Initial load
duke
parents:
diff changeset
874 out.print_raw_cr("[Too many errors, abort]");
a61af66fc99e Initial load
duke
parents:
diff changeset
875 os::die();
a61af66fc99e Initial load
duke
parents:
diff changeset
876 }
a61af66fc99e Initial load
duke
parents:
diff changeset
877
a61af66fc99e Initial load
duke
parents:
diff changeset
878 jio_snprintf(buffer, sizeof(buffer),
a61af66fc99e Initial load
duke
parents:
diff changeset
879 "[error occurred during error reporting %s, id 0x%x]",
a61af66fc99e Initial load
duke
parents:
diff changeset
880 first_error ? first_error->_current_step_info : "",
a61af66fc99e Initial load
duke
parents:
diff changeset
881 _id);
a61af66fc99e Initial load
duke
parents:
diff changeset
882 if (log.is_open()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
883 log.cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
884 log.print_raw_cr(buffer);
a61af66fc99e Initial load
duke
parents:
diff changeset
885 log.cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
886 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
887 out.cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
888 out.print_raw_cr(buffer);
a61af66fc99e Initial load
duke
parents:
diff changeset
889 out.cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
890 }
a61af66fc99e Initial load
duke
parents:
diff changeset
891 }
a61af66fc99e Initial load
duke
parents:
diff changeset
892 }
a61af66fc99e Initial load
duke
parents:
diff changeset
893
a61af66fc99e Initial load
duke
parents:
diff changeset
894 // print to screen
a61af66fc99e Initial load
duke
parents:
diff changeset
895 if (!out_done) {
a61af66fc99e Initial load
duke
parents:
diff changeset
896 first_error->_verbose = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
897
a61af66fc99e Initial load
duke
parents:
diff changeset
898 staticBufferStream sbs(buffer, sizeof(buffer), &out);
a61af66fc99e Initial load
duke
parents:
diff changeset
899 first_error->report(&sbs);
a61af66fc99e Initial load
duke
parents:
diff changeset
900
a61af66fc99e Initial load
duke
parents:
diff changeset
901 out_done = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
902
a61af66fc99e Initial load
duke
parents:
diff changeset
903 first_error->_current_step = 0; // reset current_step
a61af66fc99e Initial load
duke
parents:
diff changeset
904 first_error->_current_step_info = ""; // reset current_step string
a61af66fc99e Initial load
duke
parents:
diff changeset
905 }
a61af66fc99e Initial load
duke
parents:
diff changeset
906
a61af66fc99e Initial load
duke
parents:
diff changeset
907 // print to error log file
a61af66fc99e Initial load
duke
parents:
diff changeset
908 if (!log_done) {
a61af66fc99e Initial load
duke
parents:
diff changeset
909 first_error->_verbose = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
910
a61af66fc99e Initial load
duke
parents:
diff changeset
911 // see if log file is already open
a61af66fc99e Initial load
duke
parents:
diff changeset
912 if (!log.is_open()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
913 // open log file
a61af66fc99e Initial load
duke
parents:
diff changeset
914 int fd = -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
915
a61af66fc99e Initial load
duke
parents:
diff changeset
916 if (ErrorFile != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
917 bool copy_ok =
a61af66fc99e Initial load
duke
parents:
diff changeset
918 Arguments::copy_expand_pid(ErrorFile, strlen(ErrorFile), buffer, sizeof(buffer));
a61af66fc99e Initial load
duke
parents:
diff changeset
919 if (copy_ok) {
2199
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
920 fd = open(buffer, O_RDWR | O_CREAT | O_TRUNC, 0666);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
921 }
a61af66fc99e Initial load
duke
parents:
diff changeset
922 }
a61af66fc99e Initial load
duke
parents:
diff changeset
923
a61af66fc99e Initial load
duke
parents:
diff changeset
924 if (fd == -1) {
a61af66fc99e Initial load
duke
parents:
diff changeset
925 const char *cwd = os::get_current_directory(buffer, sizeof(buffer));
a61af66fc99e Initial load
duke
parents:
diff changeset
926 size_t len = strlen(cwd);
a61af66fc99e Initial load
duke
parents:
diff changeset
927 // either user didn't specify, or the user's location failed,
a61af66fc99e Initial load
duke
parents:
diff changeset
928 // so use the default name in the current directory
a61af66fc99e Initial load
duke
parents:
diff changeset
929 jio_snprintf(&buffer[len], sizeof(buffer)-len, "%shs_err_pid%u.log",
a61af66fc99e Initial load
duke
parents:
diff changeset
930 os::file_separator(), os::current_process_id());
2199
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
931 fd = open(buffer, O_RDWR | O_CREAT | O_TRUNC, 0666);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
932 }
a61af66fc99e Initial load
duke
parents:
diff changeset
933
a61af66fc99e Initial load
duke
parents:
diff changeset
934 if (fd == -1) {
a61af66fc99e Initial load
duke
parents:
diff changeset
935 const char * tmpdir = os::get_temp_directory();
2130
34d64ad817f4 7009828: Fix for 6938627 breaks visualvm monitoring when -Djava.io.tmpdir is defined
coleenp
parents: 2095
diff changeset
936 // try temp directory if it exists.
34d64ad817f4 7009828: Fix for 6938627 breaks visualvm monitoring when -Djava.io.tmpdir is defined
coleenp
parents: 2095
diff changeset
937 if (tmpdir != NULL && tmpdir[0] != '\0') {
34d64ad817f4 7009828: Fix for 6938627 breaks visualvm monitoring when -Djava.io.tmpdir is defined
coleenp
parents: 2095
diff changeset
938 jio_snprintf(buffer, sizeof(buffer), "%s%shs_err_pid%u.log",
34d64ad817f4 7009828: Fix for 6938627 breaks visualvm monitoring when -Djava.io.tmpdir is defined
coleenp
parents: 2095
diff changeset
939 tmpdir, os::file_separator(), os::current_process_id());
2199
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
940 fd = open(buffer, O_RDWR | O_CREAT | O_TRUNC, 0666);
2130
34d64ad817f4 7009828: Fix for 6938627 breaks visualvm monitoring when -Djava.io.tmpdir is defined
coleenp
parents: 2095
diff changeset
941 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
942 }
a61af66fc99e Initial load
duke
parents:
diff changeset
943
a61af66fc99e Initial load
duke
parents:
diff changeset
944 if (fd != -1) {
a61af66fc99e Initial load
duke
parents:
diff changeset
945 out.print_raw("# An error report file with more information is saved as:\n# ");
a61af66fc99e Initial load
duke
parents:
diff changeset
946 out.print_raw_cr(buffer);
a61af66fc99e Initial load
duke
parents:
diff changeset
947 os::set_error_file(buffer);
a61af66fc99e Initial load
duke
parents:
diff changeset
948
a61af66fc99e Initial load
duke
parents:
diff changeset
949 log.set_fd(fd);
a61af66fc99e Initial load
duke
parents:
diff changeset
950 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
951 out.print_raw_cr("# Can not save log file, dump to screen..");
a61af66fc99e Initial load
duke
parents:
diff changeset
952 log.set_fd(defaultStream::output_fd());
2199
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
953 /* Error reporting currently needs dumpfile.
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
954 * Maybe implement direct streaming in the future.*/
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
955 transmit_report_done = true;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
956 }
a61af66fc99e Initial load
duke
parents:
diff changeset
957 }
a61af66fc99e Initial load
duke
parents:
diff changeset
958
a61af66fc99e Initial load
duke
parents:
diff changeset
959 staticBufferStream sbs(buffer, O_BUFLEN, &log);
a61af66fc99e Initial load
duke
parents:
diff changeset
960 first_error->report(&sbs);
a61af66fc99e Initial load
duke
parents:
diff changeset
961 first_error->_current_step = 0; // reset current_step
a61af66fc99e Initial load
duke
parents:
diff changeset
962 first_error->_current_step_info = ""; // reset current_step string
a61af66fc99e Initial load
duke
parents:
diff changeset
963
2199
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
964 // Run error reporting to determine whether or not to report the crash.
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
965 if (!transmit_report_done && should_report_bug(first_error->_id)) {
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
966 transmit_report_done = true;
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
967 FILE* hs_err = ::fdopen(log.fd(), "r");
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
968 if (NULL != hs_err) {
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
969 ErrorReporter er;
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
970 er.call(hs_err, buffer, O_BUFLEN);
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
971 }
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
972 }
d8a72fbc4be7 7003401: Implement VM error-reporting functionality on erroneous termination
kamg
parents: 2130
diff changeset
973
0
a61af66fc99e Initial load
duke
parents:
diff changeset
974 if (log.fd() != defaultStream::output_fd()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
975 close(log.fd());
a61af66fc99e Initial load
duke
parents:
diff changeset
976 }
a61af66fc99e Initial load
duke
parents:
diff changeset
977
a61af66fc99e Initial load
duke
parents:
diff changeset
978 log.set_fd(-1);
a61af66fc99e Initial load
duke
parents:
diff changeset
979 log_done = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
980 }
a61af66fc99e Initial load
duke
parents:
diff changeset
981
a61af66fc99e Initial load
duke
parents:
diff changeset
982
a61af66fc99e Initial load
duke
parents:
diff changeset
983 static bool skip_OnError = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
984 if (!skip_OnError && OnError && OnError[0]) {
a61af66fc99e Initial load
duke
parents:
diff changeset
985 skip_OnError = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
986
a61af66fc99e Initial load
duke
parents:
diff changeset
987 out.print_raw_cr("#");
a61af66fc99e Initial load
duke
parents:
diff changeset
988 out.print_raw ("# -XX:OnError=\"");
a61af66fc99e Initial load
duke
parents:
diff changeset
989 out.print_raw (OnError);
a61af66fc99e Initial load
duke
parents:
diff changeset
990 out.print_raw_cr("\"");
a61af66fc99e Initial load
duke
parents:
diff changeset
991
a61af66fc99e Initial load
duke
parents:
diff changeset
992 char* cmd;
a61af66fc99e Initial load
duke
parents:
diff changeset
993 const char* ptr = OnError;
a61af66fc99e Initial load
duke
parents:
diff changeset
994 while ((cmd = next_OnError_command(buffer, sizeof(buffer), &ptr)) != NULL){
a61af66fc99e Initial load
duke
parents:
diff changeset
995 out.print_raw ("# Executing ");
3960
f08d439fab8c 7089790: integrate bsd-port changes
never
parents: 2302
diff changeset
996 #if defined(LINUX) || defined(_ALLBSD_SOURCE)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
997 out.print_raw ("/bin/sh -c ");
a61af66fc99e Initial load
duke
parents:
diff changeset
998 #elif defined(SOLARIS)
a61af66fc99e Initial load
duke
parents:
diff changeset
999 out.print_raw ("/usr/bin/sh -c ");
a61af66fc99e Initial load
duke
parents:
diff changeset
1000 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
1001 out.print_raw ("\"");
a61af66fc99e Initial load
duke
parents:
diff changeset
1002 out.print_raw (cmd);
a61af66fc99e Initial load
duke
parents:
diff changeset
1003 out.print_raw_cr("\" ...");
a61af66fc99e Initial load
duke
parents:
diff changeset
1004
a61af66fc99e Initial load
duke
parents:
diff changeset
1005 os::fork_and_exec(cmd);
a61af66fc99e Initial load
duke
parents:
diff changeset
1006 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1007
a61af66fc99e Initial load
duke
parents:
diff changeset
1008 // done with OnError
a61af66fc99e Initial load
duke
parents:
diff changeset
1009 OnError = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1010 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1011
6972
bd7a7ce2e264 6830717: replay of compilations would help with debugging
minqi
parents: 6921
diff changeset
1012 static bool skip_replay = false;
bd7a7ce2e264 6830717: replay of compilations would help with debugging
minqi
parents: 6921
diff changeset
1013 if (DumpReplayDataOnError && _thread && _thread->is_Compiler_thread() && !skip_replay) {
bd7a7ce2e264 6830717: replay of compilations would help with debugging
minqi
parents: 6921
diff changeset
1014 skip_replay = true;
bd7a7ce2e264 6830717: replay of compilations would help with debugging
minqi
parents: 6921
diff changeset
1015 ciEnv* env = ciEnv::current();
bd7a7ce2e264 6830717: replay of compilations would help with debugging
minqi
parents: 6921
diff changeset
1016 if (env != NULL) {
bd7a7ce2e264 6830717: replay of compilations would help with debugging
minqi
parents: 6921
diff changeset
1017 env->dump_replay_data();
bd7a7ce2e264 6830717: replay of compilations would help with debugging
minqi
parents: 6921
diff changeset
1018 }
bd7a7ce2e264 6830717: replay of compilations would help with debugging
minqi
parents: 6921
diff changeset
1019 }
bd7a7ce2e264 6830717: replay of compilations would help with debugging
minqi
parents: 6921
diff changeset
1020
2095
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
1021 static bool skip_bug_url = !should_report_bug(first_error->_id);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1022 if (!skip_bug_url) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1023 skip_bug_url = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
1024
a61af66fc99e Initial load
duke
parents:
diff changeset
1025 out.print_raw_cr("#");
a61af66fc99e Initial load
duke
parents:
diff changeset
1026 print_bug_submit_message(&out, _thread);
a61af66fc99e Initial load
duke
parents:
diff changeset
1027 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1028
a61af66fc99e Initial load
duke
parents:
diff changeset
1029 if (!UseOSErrorReporting) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1030 // os::abort() will call abort hooks, try it first.
a61af66fc99e Initial load
duke
parents:
diff changeset
1031 static bool skip_os_abort = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
1032 if (!skip_os_abort) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1033 skip_os_abort = true;
2095
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
1034 bool dump_core = should_report_bug(first_error->_id);
36c186bcc085 6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents: 2022
diff changeset
1035 os::abort(dump_core);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1036 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1037
a61af66fc99e Initial load
duke
parents:
diff changeset
1038 // if os::abort() doesn't abort, try os::die();
a61af66fc99e Initial load
duke
parents:
diff changeset
1039 os::die();
a61af66fc99e Initial load
duke
parents:
diff changeset
1040 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1041 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1042
a61af66fc99e Initial load
duke
parents:
diff changeset
1043 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
1044 * OnOutOfMemoryError scripts/commands executed while VM is a safepoint - this
a61af66fc99e Initial load
duke
parents:
diff changeset
1045 * ensures utilities such as jmap can observe the process is a consistent state.
a61af66fc99e Initial load
duke
parents:
diff changeset
1046 */
a61af66fc99e Initial load
duke
parents:
diff changeset
1047 class VM_ReportJavaOutOfMemory : public VM_Operation {
a61af66fc99e Initial load
duke
parents:
diff changeset
1048 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
1049 VMError *_err;
a61af66fc99e Initial load
duke
parents:
diff changeset
1050 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
1051 VM_ReportJavaOutOfMemory(VMError *err) { _err = err; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1052 VMOp_Type type() const { return VMOp_ReportJavaOutOfMemory; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1053 void doit();
a61af66fc99e Initial load
duke
parents:
diff changeset
1054 };
a61af66fc99e Initial load
duke
parents:
diff changeset
1055
a61af66fc99e Initial load
duke
parents:
diff changeset
1056 void VM_ReportJavaOutOfMemory::doit() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1057 // Don't allocate large buffer on stack
a61af66fc99e Initial load
duke
parents:
diff changeset
1058 static char buffer[O_BUFLEN];
a61af66fc99e Initial load
duke
parents:
diff changeset
1059
a61af66fc99e Initial load
duke
parents:
diff changeset
1060 tty->print_cr("#");
a61af66fc99e Initial load
duke
parents:
diff changeset
1061 tty->print_cr("# java.lang.OutOfMemoryError: %s", _err->message());
a61af66fc99e Initial load
duke
parents:
diff changeset
1062 tty->print_cr("# -XX:OnOutOfMemoryError=\"%s\"", OnOutOfMemoryError);
a61af66fc99e Initial load
duke
parents:
diff changeset
1063
a61af66fc99e Initial load
duke
parents:
diff changeset
1064 // make heap parsability
a61af66fc99e Initial load
duke
parents:
diff changeset
1065 Universe::heap()->ensure_parsability(false); // no need to retire TLABs
a61af66fc99e Initial load
duke
parents:
diff changeset
1066
a61af66fc99e Initial load
duke
parents:
diff changeset
1067 char* cmd;
a61af66fc99e Initial load
duke
parents:
diff changeset
1068 const char* ptr = OnOutOfMemoryError;
a61af66fc99e Initial load
duke
parents:
diff changeset
1069 while ((cmd = next_OnError_command(buffer, sizeof(buffer), &ptr)) != NULL){
a61af66fc99e Initial load
duke
parents:
diff changeset
1070 tty->print("# Executing ");
a61af66fc99e Initial load
duke
parents:
diff changeset
1071 #if defined(LINUX)
a61af66fc99e Initial load
duke
parents:
diff changeset
1072 tty->print ("/bin/sh -c ");
a61af66fc99e Initial load
duke
parents:
diff changeset
1073 #elif defined(SOLARIS)
a61af66fc99e Initial load
duke
parents:
diff changeset
1074 tty->print ("/usr/bin/sh -c ");
a61af66fc99e Initial load
duke
parents:
diff changeset
1075 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
1076 tty->print_cr("\"%s\"...", cmd);
a61af66fc99e Initial load
duke
parents:
diff changeset
1077
a61af66fc99e Initial load
duke
parents:
diff changeset
1078 os::fork_and_exec(cmd);
a61af66fc99e Initial load
duke
parents:
diff changeset
1079 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1080 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1081
a61af66fc99e Initial load
duke
parents:
diff changeset
1082 void VMError::report_java_out_of_memory() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1083 if (OnOutOfMemoryError && OnOutOfMemoryError[0]) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1084 MutexLocker ml(Heap_lock);
a61af66fc99e Initial load
duke
parents:
diff changeset
1085 VM_ReportJavaOutOfMemory op(this);
a61af66fc99e Initial load
duke
parents:
diff changeset
1086 VMThread::execute(&op);
a61af66fc99e Initial load
duke
parents:
diff changeset
1087 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1088 }