Mercurial > hg > truffle
annotate src/share/vm/utilities/vmError.hpp @ 17716:cdb71841f4bc
6498581: ThreadInterruptTest3 produces wrong output on Windows
Summary: There is race condition between os::interrupt and os::is_interrupted on Windows. In JVM_Sleep(Thread.sleep), check if thread gets interrupted, it may see interrupted but not really interrupted so cause spurious waking up (early return from sleep). Fix by checking if interrupt event really gets set thus prevent false return. For intrinsic of _isInterrupted, on Windows, go fastpath only on bit not set.
Reviewed-by: acorn, kvn
Contributed-by: david.holmes@oracle.com, yumin.qi@oracle.com
author | minqi |
---|---|
date | Wed, 26 Feb 2014 15:20:41 -0800 |
parents | 38f750491293 |
children |
rev | line source |
---|---|
0 | 1 /* |
11060
068b406e307f
7060111: race condition in VMError::report_and_die()
fparain
parents:
10161
diff
changeset
|
2 * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. |
0 | 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 * | |
5 * This code is free software; you can redistribute it and/or modify it | |
6 * under the terms of the GNU General Public License version 2 only, as | |
7 * published by the Free Software Foundation. | |
8 * | |
9 * This code is distributed in the hope that it will be useful, but WITHOUT | |
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
12 * version 2 for more details (a copy is included in the LICENSE file that | |
13 * accompanied this code). | |
14 * | |
15 * You should have received a copy of the GNU General Public License version | |
16 * 2 along with this work; if not, write to the Free Software Foundation, | |
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | |
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 | 22 * |
23 */ | |
24 | |
1972 | 25 #ifndef SHARE_VM_UTILITIES_VMERROR_HPP |
26 #define SHARE_VM_UTILITIES_VMERROR_HPP | |
27 | |
28 #include "utilities/globalDefinitions.hpp" | |
29 | |
4917 | 30 class Decoder; |
0 | 31 class VM_ReportJavaOutOfMemory; |
32 | |
33 class VMError : public StackObj { | |
34 friend class VM_ReportJavaOutOfMemory; | |
4917 | 35 friend class Decoder; |
0 | 36 |
37 int _id; // Solaris/Linux signals: 0 - SIGRTMAX | |
38 // Windows exceptions: 0xCxxxxxxx system errors | |
39 // 0x8xxxxxxx system warnings | |
40 | |
41 const char * _message; | |
1490
f03d0a26bf83
6888954: argument formatting for assert() and friends
jcoomes
parents:
1384
diff
changeset
|
42 const char * _detail_msg; |
0 | 43 |
44 Thread * _thread; // NULL if it's native thread | |
45 | |
46 | |
47 // additional info for crashes | |
48 address _pc; // faulting PC | |
49 void * _siginfo; // ExceptionRecord on Windows, | |
50 // siginfo_t on Solaris/Linux | |
51 void * _context; // ContextRecord on Windows, | |
52 // ucontext_t on Solaris/Linux | |
53 | |
54 // additional info for VM internal errors | |
55 const char * _filename; | |
603
dbbe28fc66b5
6778669: Patch from Red Hat -- fixes compilation errors
twisti
parents:
513
diff
changeset
|
56 int _lineno; |
0 | 57 |
58 // used by fatal error handler | |
59 int _current_step; | |
60 const char * _current_step_info; | |
61 int _verbose; | |
1681
126ea7725993
6953477: Increase portability and flexibility of building Hotspot
bobv
parents:
1552
diff
changeset
|
62 // 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
|
63 // so use thread id instead of Thread* to identify thread. |
126ea7725993
6953477: Increase portability and flexibility of building Hotspot
bobv
parents:
1552
diff
changeset
|
64 static VMError* volatile first_error; |
126ea7725993
6953477: Increase portability and flexibility of building Hotspot
bobv
parents:
1552
diff
changeset
|
65 static volatile jlong first_error_tid; |
0 | 66 |
2204
63d374c54045
7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents:
2095
diff
changeset
|
67 // Core dump status, false if we have been unable to write a core/minidump for some reason |
63d374c54045
7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents:
2095
diff
changeset
|
68 static bool coredump_status; |
63d374c54045
7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents:
2095
diff
changeset
|
69 |
63d374c54045
7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents:
2095
diff
changeset
|
70 // When coredump_status is set to true this will contain the name/path to the core/minidump, |
63d374c54045
7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents:
2095
diff
changeset
|
71 // if coredump_status if false, this will (hopefully) contain a useful error explaining why |
63d374c54045
7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents:
2095
diff
changeset
|
72 // no core/minidump has been written to disk |
63d374c54045
7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents:
2095
diff
changeset
|
73 static char coredump_message[O_BUFLEN]; |
63d374c54045
7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents:
2095
diff
changeset
|
74 |
0 | 75 // used by reporting about OOM |
76 size_t _size; | |
77 | |
78 // set signal handlers on Solaris/Linux or the default exception filter | |
79 // on Windows, to handle recursive crashes. | |
80 void reset_signal_handlers(); | |
81 | |
82 // handle -XX:+ShowMessageBoxOnError. buf is used to format the message string | |
83 void show_message_box(char* buf, int buflen); | |
84 | |
85 // generate an error report | |
86 void report(outputStream* st); | |
87 | |
1384 | 88 // generate a stack trace |
89 static void print_stack_trace(outputStream* st, JavaThread* jt, | |
90 char* buf, int buflen, bool verbose = false); | |
91 | |
0 | 92 // accessor |
1490
f03d0a26bf83
6888954: argument formatting for assert() and friends
jcoomes
parents:
1384
diff
changeset
|
93 const char* message() const { return _message; } |
f03d0a26bf83
6888954: argument formatting for assert() and friends
jcoomes
parents:
1384
diff
changeset
|
94 const char* detail_msg() const { return _detail_msg; } |
10161
746b070f5022
8011661: Insufficient memory message says "malloc" when sometimes it should say "mmap"
ccheung
parents:
6842
diff
changeset
|
95 bool should_report_bug(unsigned int id) { |
746b070f5022
8011661: Insufficient memory message says "malloc" when sometimes it should say "mmap"
ccheung
parents:
6842
diff
changeset
|
96 return (id != OOM_MALLOC_ERROR) && (id != OOM_MMAP_ERROR); |
746b070f5022
8011661: Insufficient memory message says "malloc" when sometimes it should say "mmap"
ccheung
parents:
6842
diff
changeset
|
97 } |
0 | 98 |
11060
068b406e307f
7060111: race condition in VMError::report_and_die()
fparain
parents:
10161
diff
changeset
|
99 static fdStream out; |
068b406e307f
7060111: race condition in VMError::report_and_die()
fparain
parents:
10161
diff
changeset
|
100 static fdStream log; // error log used by VMError::report_and_die() |
068b406e307f
7060111: race condition in VMError::report_and_die()
fparain
parents:
10161
diff
changeset
|
101 |
0 | 102 public: |
10161
746b070f5022
8011661: Insufficient memory message says "malloc" when sometimes it should say "mmap"
ccheung
parents:
6842
diff
changeset
|
103 |
0 | 104 // Constructor for crashes |
2095
36c186bcc085
6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents:
1972
diff
changeset
|
105 VMError(Thread* thread, unsigned int sig, address pc, void* siginfo, |
36c186bcc085
6302804: Hotspot VM dies ungraceful death when C heap is exhausted in various places.
coleenp
parents:
1972
diff
changeset
|
106 void* context); |
0 | 107 // Constructor for VM internal errors |
1490
f03d0a26bf83
6888954: argument formatting for assert() and friends
jcoomes
parents:
1384
diff
changeset
|
108 VMError(Thread* thread, const char* filename, int lineno, |
f03d0a26bf83
6888954: argument formatting for assert() and friends
jcoomes
parents:
1384
diff
changeset
|
109 const char* message, const char * detail_msg); |
0 | 110 |
1490
f03d0a26bf83
6888954: argument formatting for assert() and friends
jcoomes
parents:
1384
diff
changeset
|
111 // Constructor for VM OOM errors |
f03d0a26bf83
6888954: argument formatting for assert() and friends
jcoomes
parents:
1384
diff
changeset
|
112 VMError(Thread* thread, const char* filename, int lineno, size_t size, |
10161
746b070f5022
8011661: Insufficient memory message says "malloc" when sometimes it should say "mmap"
ccheung
parents:
6842
diff
changeset
|
113 VMErrorType vm_err_type, const char* message); |
0 | 114 // Constructor for non-fatal errors |
115 VMError(const char* message); | |
116 | |
117 // return a string to describe the error | |
118 char *error_string(char* buf, int buflen); | |
119 | |
2204
63d374c54045
7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents:
2095
diff
changeset
|
120 // Report status of core/minidump |
63d374c54045
7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents:
2095
diff
changeset
|
121 static void report_coredump_status(const char* message, bool status); |
63d374c54045
7014918: Improve core/minidump handling in Hotspot
ctornqvi
parents:
2095
diff
changeset
|
122 |
0 | 123 // main error reporting function |
124 void report_and_die(); | |
125 | |
126 // reporting OutOfMemoryError | |
127 void report_java_out_of_memory(); | |
128 | |
129 // returns original flags for signal, if it was resetted, or -1 if | |
130 // signal was not changed by error reporter | |
131 static int get_resetted_sigflags(int sig); | |
132 | |
133 // returns original handler for signal, if it was resetted, or NULL if | |
134 // signal was not changed by error reporter | |
135 static address get_resetted_sighandler(int sig); | |
1681
126ea7725993
6953477: Increase portability and flexibility of building Hotspot
bobv
parents:
1552
diff
changeset
|
136 |
126ea7725993
6953477: Increase portability and flexibility of building Hotspot
bobv
parents:
1552
diff
changeset
|
137 // check to see if fatal error reporting is in progress |
126ea7725993
6953477: Increase portability and flexibility of building Hotspot
bobv
parents:
1552
diff
changeset
|
138 static bool fatal_error_in_progress() { return first_error != NULL; } |
12199
38f750491293
8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents:
11060
diff
changeset
|
139 |
38f750491293
8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents:
11060
diff
changeset
|
140 static jlong get_first_error_tid() { |
38f750491293
8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents:
11060
diff
changeset
|
141 return first_error_tid; |
38f750491293
8022335: Native stack walk while generating hs_err does not work on Windows x64
iklam
parents:
11060
diff
changeset
|
142 } |
0 | 143 }; |
1972 | 144 |
145 #endif // SHARE_VM_UTILITIES_VMERROR_HPP |