hotspot/src/share/vm/utilities/decoder.hpp
author minqi
Mon, 12 Nov 2012 14:03:53 -0800
changeset 14477 95e66ea71f71
parent 13340 40c424a6ff53
child 19952 bc974e92f881
permissions -rw-r--r--
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
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
7447
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
     1
/*
11761
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
     2
 * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
7447
32c42d627f41 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.
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
     4
 *
32c42d627f41 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
32c42d627f41 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
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
     7
 * published by the Free Software Foundation.
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
     8
 *
32c42d627f41 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
32c42d627f41 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
32c42d627f41 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
32c42d627f41 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
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    13
 * accompanied this code).
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    14
 *
32c42d627f41 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
32c42d627f41 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,
32c42d627f41 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.
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    18
 *
32c42d627f41 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
32c42d627f41 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
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    21
 * questions.
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    22
 *
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    23
 */
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    24
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    25
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    26
#ifndef SHARE_VM_UTILITIES_DECODER_HPP
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    27
#define SHARE_VM_UTILITIES_DECODER_HPP
7447
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    28
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    29
#include "memory/allocation.hpp"
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    30
#include "runtime/mutex.hpp"
7447
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    31
13195
be27e1b6a4b9 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 11761
diff changeset
    32
class AbstractDecoder : public CHeapObj<mtInternal> {
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    33
public:
7447
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    34
  // status code for decoding native C frame
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    35
  enum decoder_status {
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    36
         not_available = -10,  // real decoder is not available
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    37
         no_error = 0,         // successfully decoded frames
7447
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    38
         out_of_memory,        // out of memory
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    39
         file_invalid,         // invalid elf file
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    40
         file_not_found,       // could not found symbol file (on windows), such as jvm.pdb or jvm.map
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    41
         helper_not_found,     // could not load dbghelp.dll (Windows only)
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    42
         helper_func_error,    // decoding functions not found (Windows only)
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    43
         helper_init_error     // SymInitialize failed (Windows only)
7447
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    44
  };
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
    45
11761
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    46
  // decode an pc address to corresponding function name and an offset from the beginning of
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    47
  // the function
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    48
  virtual bool decode(address pc, char* buf, int buflen, int* offset,
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    49
    const char* modulepath = NULL) = 0;
13340
40c424a6ff53 7186778: MachO decoder implementation for MacOSX
zgu
parents: 13195
diff changeset
    50
  virtual bool decode(address pc, char* buf, int buflen, int* offset, const void* base) = 0;
40c424a6ff53 7186778: MachO decoder implementation for MacOSX
zgu
parents: 13195
diff changeset
    51
11761
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    52
  // demangle a C++ symbol
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    53
  virtual bool demangle(const char* symbol, char* buf, int buflen) = 0;
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    54
  // if the decoder can decode symbols in vm
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    55
  virtual bool can_decode_C_frame_in_vm() const = 0;
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    56
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    57
  virtual decoder_status status() const {
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    58
    return _decoder_status;
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    59
  }
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    60
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    61
  virtual bool has_error() const {
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    62
    return is_error(_decoder_status);
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    63
  }
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    64
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    65
  static bool is_error(decoder_status status) {
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    66
    return (status > 0);
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    67
  }
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    68
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    69
protected:
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    70
  decoder_status  _decoder_status;
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    71
};
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    72
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    73
// Do nothing decoder
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    74
class NullDecoder : public AbstractDecoder {
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
    75
public:
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    76
  NullDecoder() {
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    77
    _decoder_status = not_available;
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    78
  }
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    79
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    80
  ~NullDecoder() {};
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    81
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    82
  virtual bool decode(address pc, char* buf, int buflen, int* offset,
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    83
    const char* modulepath = NULL) {
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    84
    return false;
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    85
  }
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    86
13340
40c424a6ff53 7186778: MachO decoder implementation for MacOSX
zgu
parents: 13195
diff changeset
    87
  virtual bool decode(address pc, char* buf, int buflen, int* offset, const void* base) {
40c424a6ff53 7186778: MachO decoder implementation for MacOSX
zgu
parents: 13195
diff changeset
    88
    return false;
40c424a6ff53 7186778: MachO decoder implementation for MacOSX
zgu
parents: 13195
diff changeset
    89
  }
40c424a6ff53 7186778: MachO decoder implementation for MacOSX
zgu
parents: 13195
diff changeset
    90
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    91
  virtual bool demangle(const char* symbol, char* buf, int buflen) {
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    92
    return false;
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    93
  }
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    94
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    95
  virtual bool can_decode_C_frame_in_vm() const {
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    96
    return false;
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    97
  }
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    98
};
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
    99
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
   100
11761
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   101
class Decoder : AllStatic {
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
   102
public:
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
   103
  static bool decode(address pc, char* buf, int buflen, int* offset, const char* modulepath = NULL);
13340
40c424a6ff53 7186778: MachO decoder implementation for MacOSX
zgu
parents: 13195
diff changeset
   104
  static bool decode(address pc, char* buf, int buflen, int* offset, const void* base);
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
   105
  static bool demangle(const char* symbol, char* buf, int buflen);
7447
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
   106
  static bool can_decode_C_frame_in_vm();
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
   107
11761
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   108
  // shutdown shared instance
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
   109
  static void shutdown();
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
   110
protected:
11761
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   111
  // shared decoder instance, _shared_instance_lock is needed
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   112
  static AbstractDecoder* get_shared_instance();
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   113
  // a private instance for error handler. Error handler can be
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   114
  // triggered almost everywhere, including signal handler, where
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   115
  // no lock can be taken. So the shared decoder can not be used
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   116
  // in this scenario.
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   117
  static AbstractDecoder* get_error_handler_instance();
7447
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
   118
11761
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   119
  static AbstractDecoder* create_decoder();
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
   120
private:
11761
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   121
  static AbstractDecoder*     _shared_decoder;
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   122
  static AbstractDecoder*     _error_handler_decoder;
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   123
  static NullDecoder          _do_nothing_decoder;
7447
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
   124
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
   125
protected:
11761
bf460b379a6a 7141259: Native stack is missing in hs_err
zgu
parents: 11483
diff changeset
   126
  static Mutex*               _shared_decoder_lock;
7447
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
   127
};
32c42d627f41 7003748: Decode C stack frames when symbols are presented (PhoneHome project)
zgu
parents:
diff changeset
   128
11483
4d3f4bca0019 7071311: Decoder enhancement
zgu
parents: 10565
diff changeset
   129
#endif // SHARE_VM_UTILITIES_DECODER_HPP