annotate src/share/vm/utilities/decoder.cpp @ 6862:8a5ea0a9ccc4

7127708: G1: change task num types from int to uint in concurrent mark Summary: Change the type of various task num fields, parameters etc to unsigned and rename them to be more consistent with the other collectors. Code changes were also reviewed by Vitaly Davidovich. Reviewed-by: johnc Contributed-by: Kaushik Srenevasan <kaushik@twitter.com>
author johnc
date Sat, 06 Oct 2012 01:17:44 -0700
parents 3b01d0321dfa
children b9a9ed0f8eeb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
1 /*
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
2 * Copyright (c) 1997, 2010, Oracle and/or its affiliates. All rights reserved.
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
4 *
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
7 * published by the Free Software Foundation.
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
8 *
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
13 * accompanied this code).
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
14 *
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
18 *
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
21 * questions.
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
22 *
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
23 */
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
24
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
25 #include "precompiled.hpp"
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
26 #include "prims/jvm.h"
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
27 #include "runtime/mutexLocker.hpp"
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
28 #include "runtime/os.hpp"
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
29 #include "utilities/decoder.hpp"
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
30 #include "utilities/vmError.hpp"
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
31
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
32 #if defined(_WINDOWS)
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
33 #include "decoder_windows.hpp"
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
34 #elif defined(__APPLE__)
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
35 #include "decoder_machO.hpp"
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
36 #else
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
37 #include "decoder_elf.hpp"
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
38 #endif
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
39
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
40 AbstractDecoder* Decoder::_shared_decoder = NULL;
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
41 AbstractDecoder* Decoder::_error_handler_decoder = NULL;
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
42 NullDecoder Decoder::_do_nothing_decoder;
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
43 Mutex* Decoder::_shared_decoder_lock = new Mutex(Mutex::native,
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
44 "SharedDecoderLock");
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
45
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
46 AbstractDecoder* Decoder::get_shared_instance() {
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
47 assert(_shared_decoder_lock != NULL && _shared_decoder_lock->owned_by_self(),
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
48 "Require DecoderLock to enter");
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
49
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
50 if (_shared_decoder == NULL) {
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
51 _shared_decoder = create_decoder();
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
52 }
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
53 return _shared_decoder;
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
54 }
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
55
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
56 AbstractDecoder* Decoder::get_error_handler_instance() {
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
57 if (_error_handler_decoder == NULL) {
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
58 _error_handler_decoder = create_decoder();
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
59 }
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
60 return _error_handler_decoder;
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
61 }
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
62
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
63
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
64 AbstractDecoder* Decoder::create_decoder() {
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
65 AbstractDecoder* decoder;
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
66 #if defined(_WINDOWS)
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
67 decoder = new (std::nothrow) WindowsDecoder();
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
68 #elif defined (__APPLE__)
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
69 decoder = new (std::nothrow)MachODecoder();
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
70 #else
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
71 decoder = new (std::nothrow)ElfDecoder();
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
72 #endif
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
73
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
74 if (decoder == NULL || decoder->has_error()) {
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
75 if (decoder != NULL) {
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
76 delete decoder;
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
77 }
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
78 decoder = &_do_nothing_decoder;
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
79 }
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
80 return decoder;
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
81 }
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
82
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
83 bool Decoder::decode(address addr, char* buf, int buflen, int* offset, const char* modulepath) {
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
84 assert(_shared_decoder_lock != NULL, "Just check");
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
85 bool error_handling_thread = os::current_thread_id() == VMError::first_error_tid;
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
86 MutexLockerEx locker(error_handling_thread ? NULL : _shared_decoder_lock, true);
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
87 AbstractDecoder* decoder = error_handling_thread ?
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
88 get_error_handler_instance(): get_shared_instance();
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
89 assert(decoder != NULL, "null decoder");
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
90
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
91 return decoder->decode(addr, buf, buflen, offset, modulepath);
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
92 }
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
93
6258
3b01d0321dfa 7186778: MachO decoder implementation for MacOSX
zgu
parents: 4917
diff changeset
94 bool Decoder::decode(address addr, char* buf, int buflen, int* offset, const void* base) {
3b01d0321dfa 7186778: MachO decoder implementation for MacOSX
zgu
parents: 4917
diff changeset
95 assert(_shared_decoder_lock != NULL, "Just check");
3b01d0321dfa 7186778: MachO decoder implementation for MacOSX
zgu
parents: 4917
diff changeset
96 bool error_handling_thread = os::current_thread_id() == VMError::first_error_tid;
3b01d0321dfa 7186778: MachO decoder implementation for MacOSX
zgu
parents: 4917
diff changeset
97 MutexLockerEx locker(error_handling_thread ? NULL : _shared_decoder_lock, true);
3b01d0321dfa 7186778: MachO decoder implementation for MacOSX
zgu
parents: 4917
diff changeset
98 AbstractDecoder* decoder = error_handling_thread ?
3b01d0321dfa 7186778: MachO decoder implementation for MacOSX
zgu
parents: 4917
diff changeset
99 get_error_handler_instance(): get_shared_instance();
3b01d0321dfa 7186778: MachO decoder implementation for MacOSX
zgu
parents: 4917
diff changeset
100 assert(decoder != NULL, "null decoder");
3b01d0321dfa 7186778: MachO decoder implementation for MacOSX
zgu
parents: 4917
diff changeset
101
3b01d0321dfa 7186778: MachO decoder implementation for MacOSX
zgu
parents: 4917
diff changeset
102 return decoder->decode(addr, buf, buflen, offset, base);
3b01d0321dfa 7186778: MachO decoder implementation for MacOSX
zgu
parents: 4917
diff changeset
103 }
3b01d0321dfa 7186778: MachO decoder implementation for MacOSX
zgu
parents: 4917
diff changeset
104
3b01d0321dfa 7186778: MachO decoder implementation for MacOSX
zgu
parents: 4917
diff changeset
105
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
106 bool Decoder::demangle(const char* symbol, char* buf, int buflen) {
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
107 assert(_shared_decoder_lock != NULL, "Just check");
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
108 bool error_handling_thread = os::current_thread_id() == VMError::first_error_tid;
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
109 MutexLockerEx locker(error_handling_thread ? NULL : _shared_decoder_lock, true);
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
110 AbstractDecoder* decoder = error_handling_thread ?
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
111 get_error_handler_instance(): get_shared_instance();
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
112 assert(decoder != NULL, "null decoder");
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
113 return decoder->demangle(symbol, buf, buflen);
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
114 }
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
115
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
116 bool Decoder::can_decode_C_frame_in_vm() {
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
117 assert(_shared_decoder_lock != NULL, "Just check");
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
118 bool error_handling_thread = os::current_thread_id() == VMError::first_error_tid;
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
119 MutexLockerEx locker(error_handling_thread ? NULL : _shared_decoder_lock, true);
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
120 AbstractDecoder* decoder = error_handling_thread ?
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
121 get_error_handler_instance(): get_shared_instance();
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
122 assert(decoder != NULL, "null decoder");
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
123 return decoder->can_decode_C_frame_in_vm();
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
124 }
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
125
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
126 /*
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
127 * Shutdown shared decoder and replace it with
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
128 * _do_nothing_decoder. Do nothing with error handler
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
129 * instance, since the JVM is going down.
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
130 */
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
131 void Decoder::shutdown() {
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
132 assert(_shared_decoder_lock != NULL, "Just check");
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
133 MutexLockerEx locker(_shared_decoder_lock, true);
4803
d7e3846464d0 7071311: Decoder enhancement
zgu
parents: 3960
diff changeset
134
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
135 if (_shared_decoder != NULL &&
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
136 _shared_decoder != &_do_nothing_decoder) {
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
137 delete _shared_decoder;
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
138 }
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
139
4917
db006a85bf91 7141259: Native stack is missing in hs_err
zgu
parents: 4803
diff changeset
140 _shared_decoder = &_do_nothing_decoder;
2022
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
141 }
2d4762ec74af 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
142