1 /*
2  * Copyright (c) 1997, 2018, Oracle and/or its affiliates. All rights reserved.
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  *
19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20  * or visit www.oracle.com if you need additional information or have any
21  * questions.
22  *
23  */
24 
25 #include "precompiled.hpp"
26 #include "jvm.h"
27 #include "memory/allocation.inline.hpp"
28 #include "runtime/os.hpp"
29 #include "utilities/decoder.hpp"
30 #include "utilities/vmError.hpp"
31 
32 #ifndef _WINDOWS
33 #if defined(__APPLE__)
34   #include "decoder_machO.hpp"
35 #elif defined(AIX)
36   #include "decoder_aix.hpp"
37 #else
38   #include "decoder_elf.hpp"
39 #endif
40 
41 AbstractDecoder*  Decoder::_shared_decoder = NULL;
42 AbstractDecoder*  Decoder::_error_handler_decoder = NULL;
43 NullDecoder       Decoder::_do_nothing_decoder;
44 
get_shared_instance()45 AbstractDecoder* Decoder::get_shared_instance() {
46   assert(shared_decoder_lock()->owned_by_self(), "Require DecoderLock to enter");
47 
48   if (_shared_decoder == NULL) {
49     _shared_decoder = create_decoder();
50   }
51   return _shared_decoder;
52 }
53 
get_error_handler_instance()54 AbstractDecoder* Decoder::get_error_handler_instance() {
55   if (_error_handler_decoder == NULL) {
56     _error_handler_decoder = create_decoder();
57   }
58   return _error_handler_decoder;
59 }
60 
61 
create_decoder()62 AbstractDecoder* Decoder::create_decoder() {
63   AbstractDecoder* decoder;
64 #if defined (__APPLE__)
65   decoder = new (std::nothrow)MachODecoder();
66 #elif defined(AIX)
67   decoder = new (std::nothrow)AIXDecoder();
68 #else
69   decoder = new (std::nothrow)ElfDecoder();
70 #endif
71 
72   if (decoder == NULL || decoder->has_error()) {
73     if (decoder != NULL) {
74       delete decoder;
75     }
76     decoder = &_do_nothing_decoder;
77   }
78   return decoder;
79 }
80 
is_first_error_thread()81 inline bool DecoderLocker::is_first_error_thread() {
82   return (os::current_thread_id() == VMError::get_first_error_tid());
83 }
84 
DecoderLocker()85 DecoderLocker::DecoderLocker() :
86   MutexLockerEx(DecoderLocker::is_first_error_thread() ?
87                 NULL : Decoder::shared_decoder_lock(),
88                 Mutex::_no_safepoint_check_flag) {
89   _decoder = is_first_error_thread() ?
90     Decoder::get_error_handler_instance() : Decoder::get_shared_instance();
91   assert(_decoder != NULL, "null decoder");
92 }
93 
shared_decoder_lock()94 Mutex* Decoder::shared_decoder_lock() {
95   assert(SharedDecoder_lock != NULL, "Just check");
96   return SharedDecoder_lock;
97 }
98 
decode(address addr,char * buf,int buflen,int * offset,const char * modulepath,bool demangle)99 bool Decoder::decode(address addr, char* buf, int buflen, int* offset, const char* modulepath, bool demangle) {
100   bool error_handling_thread = os::current_thread_id() == VMError::first_error_tid;
101   MutexLockerEx locker(error_handling_thread ? NULL : shared_decoder_lock(),
102                        Mutex::_no_safepoint_check_flag);
103   AbstractDecoder* decoder = error_handling_thread ?
104     get_error_handler_instance(): get_shared_instance();
105   assert(decoder != NULL, "null decoder");
106 
107   return decoder->decode(addr, buf, buflen, offset, modulepath, demangle);
108 }
109 
decode(address addr,char * buf,int buflen,int * offset,const void * base)110 bool Decoder::decode(address addr, char* buf, int buflen, int* offset, const void* base) {
111   bool error_handling_thread = os::current_thread_id() == VMError::first_error_tid;
112   MutexLockerEx locker(error_handling_thread ? NULL : shared_decoder_lock(),
113                        Mutex::_no_safepoint_check_flag);
114   AbstractDecoder* decoder = error_handling_thread ?
115     get_error_handler_instance(): get_shared_instance();
116   assert(decoder != NULL, "null decoder");
117 
118   return decoder->decode(addr, buf, buflen, offset, base);
119 }
120 
121 
demangle(const char * symbol,char * buf,int buflen)122 bool Decoder::demangle(const char* symbol, char* buf, int buflen) {
123   bool error_handling_thread = os::current_thread_id() == VMError::first_error_tid;
124   MutexLockerEx locker(error_handling_thread ? NULL : shared_decoder_lock(),
125                        Mutex::_no_safepoint_check_flag);
126   AbstractDecoder* decoder = error_handling_thread ?
127     get_error_handler_instance(): get_shared_instance();
128   assert(decoder != NULL, "null decoder");
129   return decoder->demangle(symbol, buf, buflen);
130 }
131 
print_state_on(outputStream * st)132 void Decoder::print_state_on(outputStream* st) {
133 }
134 
get_source_info(address pc,char * buf,size_t buflen,int * line)135 bool Decoder::get_source_info(address pc, char* buf, size_t buflen, int* line) {
136   return false;
137 }
138 
139 #endif // !_WINDOWS
140 
141