annotate src/share/vm/utilities/vmError.hpp @ 1994:6cd6d394f280

7001033: assert(gch->gc_cause() == GCCause::_scavenge_alot || !gch->incremental_collection_failed()) 7002546: regression on SpecJbb2005 on 7b118 comparing to 7b117 on small heaps Summary: Relaxed assertion checking related to incremental_collection_failed flag to allow for ExplicitGCInvokesConcurrent behaviour where we do not want a failing scavenge to bail to a stop-world collection. Parameterized incremental_collection_will_fail() so we can selectively use, or not use, as appropriate, the statistical prediction at specific use sites. This essentially reverts the scavenge bail-out logic to what it was prior to some recent changes that had inadvertently started using the statistical prediction which can be noisy in the presence of bursty loads. Added some associated verbose non-product debugging messages. Reviewed-by: johnc, tonyp
author ysr
date Tue, 07 Dec 2010 21:55:53 -0800
parents f95d63e2154a
children 36c186bcc085
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1490
diff changeset
2 * Copyright (c) 2003, 2010, 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: 1681
diff changeset
25 #ifndef SHARE_VM_UTILITIES_VMERROR_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
26 #define SHARE_VM_UTILITIES_VMERROR_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
27
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
28 #include "utilities/globalDefinitions.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
29
0
a61af66fc99e Initial load
duke
parents:
diff changeset
30
a61af66fc99e Initial load
duke
parents:
diff changeset
31 class VM_ReportJavaOutOfMemory;
a61af66fc99e Initial load
duke
parents:
diff changeset
32
a61af66fc99e Initial load
duke
parents:
diff changeset
33 class VMError : public StackObj {
a61af66fc99e Initial load
duke
parents:
diff changeset
34 friend class VM_ReportJavaOutOfMemory;
a61af66fc99e Initial load
duke
parents:
diff changeset
35
a61af66fc99e Initial load
duke
parents:
diff changeset
36 enum ErrorType {
a61af66fc99e Initial load
duke
parents:
diff changeset
37 internal_error = 0xe0000000,
a61af66fc99e Initial load
duke
parents:
diff changeset
38 oom_error = 0xe0000001
a61af66fc99e Initial load
duke
parents:
diff changeset
39 };
a61af66fc99e Initial load
duke
parents:
diff changeset
40 int _id; // Solaris/Linux signals: 0 - SIGRTMAX
a61af66fc99e Initial load
duke
parents:
diff changeset
41 // Windows exceptions: 0xCxxxxxxx system errors
a61af66fc99e Initial load
duke
parents:
diff changeset
42 // 0x8xxxxxxx system warnings
a61af66fc99e Initial load
duke
parents:
diff changeset
43
a61af66fc99e Initial load
duke
parents:
diff changeset
44 const char * _message;
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
45 const char * _detail_msg;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
46
a61af66fc99e Initial load
duke
parents:
diff changeset
47 Thread * _thread; // NULL if it's native thread
a61af66fc99e Initial load
duke
parents:
diff changeset
48
a61af66fc99e Initial load
duke
parents:
diff changeset
49
a61af66fc99e Initial load
duke
parents:
diff changeset
50 // additional info for crashes
a61af66fc99e Initial load
duke
parents:
diff changeset
51 address _pc; // faulting PC
a61af66fc99e Initial load
duke
parents:
diff changeset
52 void * _siginfo; // ExceptionRecord on Windows,
a61af66fc99e Initial load
duke
parents:
diff changeset
53 // siginfo_t on Solaris/Linux
a61af66fc99e Initial load
duke
parents:
diff changeset
54 void * _context; // ContextRecord on Windows,
a61af66fc99e Initial load
duke
parents:
diff changeset
55 // ucontext_t on Solaris/Linux
a61af66fc99e Initial load
duke
parents:
diff changeset
56
a61af66fc99e Initial load
duke
parents:
diff changeset
57 // additional info for VM internal errors
a61af66fc99e Initial load
duke
parents:
diff changeset
58 const char * _filename;
603
dbbe28fc66b5 6778669: Patch from Red Hat -- fixes compilation errors
twisti
parents: 513
diff changeset
59 int _lineno;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
60
a61af66fc99e Initial load
duke
parents:
diff changeset
61 // used by fatal error handler
a61af66fc99e Initial load
duke
parents:
diff changeset
62 int _current_step;
a61af66fc99e Initial load
duke
parents:
diff changeset
63 const char * _current_step_info;
a61af66fc99e Initial load
duke
parents:
diff changeset
64 int _verbose;
1681
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1552
diff changeset
65 // First error, and its thread id. We must be able to handle native thread,
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1552
diff changeset
66 // so use thread id instead of Thread* to identify thread.
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1552
diff changeset
67 static VMError* volatile first_error;
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1552
diff changeset
68 static volatile jlong first_error_tid;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
69
a61af66fc99e Initial load
duke
parents:
diff changeset
70 // used by reporting about OOM
a61af66fc99e Initial load
duke
parents:
diff changeset
71 size_t _size;
a61af66fc99e Initial load
duke
parents:
diff changeset
72
a61af66fc99e Initial load
duke
parents:
diff changeset
73 // set signal handlers on Solaris/Linux or the default exception filter
a61af66fc99e Initial load
duke
parents:
diff changeset
74 // on Windows, to handle recursive crashes.
a61af66fc99e Initial load
duke
parents:
diff changeset
75 void reset_signal_handlers();
a61af66fc99e Initial load
duke
parents:
diff changeset
76
a61af66fc99e Initial load
duke
parents:
diff changeset
77 // handle -XX:+ShowMessageBoxOnError. buf is used to format the message string
a61af66fc99e Initial load
duke
parents:
diff changeset
78 void show_message_box(char* buf, int buflen);
a61af66fc99e Initial load
duke
parents:
diff changeset
79
a61af66fc99e Initial load
duke
parents:
diff changeset
80 // generate an error report
a61af66fc99e Initial load
duke
parents:
diff changeset
81 void report(outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
82
1384
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 628
diff changeset
83 // generate a stack trace
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 628
diff changeset
84 static void print_stack_trace(outputStream* st, JavaThread* jt,
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 628
diff changeset
85 char* buf, int buflen, bool verbose = false);
c544d979f886 6944503: Improved Zero crash dump
twisti
parents: 628
diff changeset
86
0
a61af66fc99e Initial load
duke
parents:
diff changeset
87 // accessor
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
88 const char* message() const { return _message; }
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
89 const char* detail_msg() const { return _detail_msg; }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
90
a61af66fc99e Initial load
duke
parents:
diff changeset
91 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
92 // Constructor for crashes
a61af66fc99e Initial load
duke
parents:
diff changeset
93 VMError(Thread* thread, int sig, address pc, void* siginfo, void* context);
a61af66fc99e Initial load
duke
parents:
diff changeset
94 // Constructor for VM internal errors
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
95 VMError(Thread* thread, const char* filename, int lineno,
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
96 const char* message, const char * detail_msg);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
97
1490
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
98 // Constructor for VM OOM errors
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
99 VMError(Thread* thread, const char* filename, int lineno, size_t size,
f03d0a26bf83 6888954: argument formatting for assert() and friends
jcoomes
parents: 1384
diff changeset
100 const char* message);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
101 // Constructor for non-fatal errors
a61af66fc99e Initial load
duke
parents:
diff changeset
102 VMError(const char* message);
a61af66fc99e Initial load
duke
parents:
diff changeset
103
a61af66fc99e Initial load
duke
parents:
diff changeset
104 // return a string to describe the error
a61af66fc99e Initial load
duke
parents:
diff changeset
105 char *error_string(char* buf, int buflen);
a61af66fc99e Initial load
duke
parents:
diff changeset
106
a61af66fc99e Initial load
duke
parents:
diff changeset
107 // main error reporting function
a61af66fc99e Initial load
duke
parents:
diff changeset
108 void report_and_die();
a61af66fc99e Initial load
duke
parents:
diff changeset
109
a61af66fc99e Initial load
duke
parents:
diff changeset
110 // reporting OutOfMemoryError
a61af66fc99e Initial load
duke
parents:
diff changeset
111 void report_java_out_of_memory();
a61af66fc99e Initial load
duke
parents:
diff changeset
112
a61af66fc99e Initial load
duke
parents:
diff changeset
113 // returns original flags for signal, if it was resetted, or -1 if
a61af66fc99e Initial load
duke
parents:
diff changeset
114 // signal was not changed by error reporter
a61af66fc99e Initial load
duke
parents:
diff changeset
115 static int get_resetted_sigflags(int sig);
a61af66fc99e Initial load
duke
parents:
diff changeset
116
a61af66fc99e Initial load
duke
parents:
diff changeset
117 // returns original handler for signal, if it was resetted, or NULL if
a61af66fc99e Initial load
duke
parents:
diff changeset
118 // signal was not changed by error reporter
a61af66fc99e Initial load
duke
parents:
diff changeset
119 static address get_resetted_sighandler(int sig);
1681
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1552
diff changeset
120
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1552
diff changeset
121 // check to see if fatal error reporting is in progress
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1552
diff changeset
122 static bool fatal_error_in_progress() { return first_error != NULL; }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
123 };
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
124
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
125 #endif // SHARE_VM_UTILITIES_VMERROR_HPP